0

i am a newbie to programming,

I have an HTML code for displaying base64 image the image is dynamic link, always come with different sizes

I need to resize that image and create preview mode with smaller image with an aspect ratio ex: my original image on html are 600x300 I need to preview it 300x150 my original image HTML are 1000x500 I need to preview 500x250

I have a javascript for resizing but can't figure out how to get image base64 from my HTML code

Please who can give me some help on these to archive my goal

I cant paste HTMl code here because is to long please check HTMl on codepin

https://codepen.io/Gilavani/pen/JjLXBOb

function resizedataURL(datas, wantedWidth, wantedHeight)
{
    // We create an image to receive the Data URI
    var img = document.createElement('img');

    // When the event "onload" is triggered we can resize the image.
    img.onload = function()
        {        
            // We create a canvas and get its context.
            var canvas = document.createElement('canvas');
            var ctx = canvas.getContext('2d');

            // We set the dimensions at the wanted size.
            canvas.width = wantedWidth;
            canvas.height = wantedHeight;

            // We resize the image with the canvas method drawImage();
            ctx.drawImage(this, 0, 0, wantedWidth, wantedHeight);

            var dataURI = canvas.toDataURL();

            /////////////////////////////////////////
            // Use and treat your Data URI here !! //
            /////////////////////////////////////////
        };

    // We put the Data URI in the image's src attribute
    img.src = datas;
}

Thanks you in Advice Best Regards

Artem.
  • 1
  • 1

1 Answers1

0

    let srcImg = document.getElementById("orignal").src;
    let prev = document.getElementById("preview");
    function resizedataURL(datas, wantedWidth, wantedHeight)
    {
        prev.src = datas;
        prev.onload = function()
        {
          var canvas = document.createElement('canvas');
          var ctx = canvas.getContext('2d');
          canvas.width = wantedWidth;
          canvas.height = wantedHeight;
          ctx.drawImage(this, 0, 0, wantedWidth, wantedHeight);
          prev.src = canvas.toDataURL();
        };
    }
    resizedataURL(srcImg, 150,150);
<html>
  <body>
    <img id="orignal" src="">
    <h2>Preview</h2>
    <img id="preview" src="#">
    </body>
  </html>
Ryヅ
  • 27
  • 8
  • Code-only answers are considered low quality. Without sufficient explanation, your answer is hard to understand. If the OP can't understand your answer, then he also won't be able to reproduce your possible solution. As such it would be worthless to him/her or any further readers. Please add a sufficient explanation of your possible solution. – tacoshy Jul 11 '22 at 12:55
  • Hello @Ryヅ thanks you for your answear, i may not explain well my topic, please image base64 are dynamic and always come with different size, its possible to check the size and return the smaller preview with aspect ratio ?? – Artem. Jul 11 '22 at 13:30
  • [link](https://stackoverflow.com/questions/17774928/js-get-image-width-and-height-from-the-base64-code)check this – Chang Alex Jul 11 '22 at 17:09