Harry
Harry

Reputation: 399

How to rotate a base64 image in reactjs before passing into a component?

I am trying to rotate a base 64 image 90 deg but am not able to do it. I want to rotate it before I pass it to an image component. I have an image stored but it is in base64 and I have to pass it to another page to a component but before doing so I have to rotate it 90 degrees.

I can rotate the image inside the component using styling such that it will rotate 90 degree=> transform: 'rotate(90deg)'

but I want to rotate the image and then pass it to the component.

I tried using the code from another similar problem in stackoverflow using javascript. but it wouldnt work.

Sample image string




Expected result: I want the image to be rotated by 90 degrees by using code.

Actual result: I am not able to rotate it at all.

Upvotes: 1

Views: 4845

Answers (3)

Mojahed Elbakre
Mojahed Elbakre

Reputation: 81

Image processing in javascript can be done using canvas element. To solve your problem, you need to rotate your image and result in a new image. To get help from canvas to do that, we can follow simple algorithm

  • get original image base64 code
  • create in-fly image from that code using Image constructor
  • create in-fly canvas and get its context
  • Now we need to get the maximum dimension to overcome edge cover as we need to do transformation for our canvas
  • we have special case for rotation with 90, 270 deg as this will inverse width with height, so we need to handle that
  • do transformation for the canvas to cover image after rotate
  • rotate the canvas, and return its content as base64
  • load the image and send the result in the callback
function rotateImage(imageBase64, rotation, cb) {
           var img = new Image();
            img.src = imageBase64;
            img.onload = () => {
              var canvas = document.createElement("canvas");
              const maxDim = Math.max(img.height, img.width);
              if ([90, 270].indexOf(rotation) > -1) {
                canvas.width = img.height;
                canvas.height = img.width;
              } else {
                canvas.width = img.width;
                canvas.height = img.height;
              }
              var ctx = canvas.getContext("2d");
              ctx.setTransform(1, 0, 0, 1, maxDim / 2, maxDim / 2);
              ctx.rotate(90 * (Math.PI / 180));
              ctx.drawImage(img, -maxDim / 2, -maxDim / 2);
              cb(canvas.toDataURL("image/jpeg"))
            };
}

Upvotes: 2

Mosè Raguzzini
Mosè Raguzzini

Reputation: 15821

If you do not want to use a canvas, you can pass the whole image with style to your component, eg:

<MyComponent
  img={
    <img src={myBase64Img} style={{ transform: 'rotate(90deg)'}} />
  }
/>  

Upvotes: 0

gcasar
gcasar

Reputation: 759

To achieve what you're describing you'd need to render the image to a canvas, rotate it and than call canvas.toDataURL("image/png"). This will present a significant overhead...

I suggest you solve this by making a RotatedComponent that wraps with a css transformation as you suggested.

If you still want to do it:

Upvotes: 0

Related Questions