1

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.

Harry
  • 389
  • 1
  • 6
  • 18
  • What have you tried? Do you have some code? – J. Stott Jul 30 '19 at 10:36
  • https://stackoverflow.com/a/17043361/11368483 – red Jul 30 '19 at 10:37
  • 1
    I have tried to rotate it using css that is transform .. rotate property, but that is in the component. I want to rotate using code and then pass it to image component. this is a base64 image. so I just want to know how to rotate it by 90 degrees. so no code. and thank you scott for trying to help me – Harry Jul 30 '19 at 10:39
  • @red I have already tried that solution, it doesn't work in reactjs and it uses canvas. thank you for trying to help – Harry Jul 30 '19 at 10:41
  • Be sure to get a reference to your canvas element, there is no reason the link would not work in reactjs – gcasar Jul 30 '19 at 10:45
  • it returns getContext as null because canvas doesn't load before code I think, so it doesn't work – Harry Jul 30 '19 at 10:47
  • https://blog.cloudboost.io/using-html5-canvas-with-react-ff7d93f5dc76 I suggest you look at this – gcasar Jul 30 '19 at 11:40
  • thank you greg, will look into it – Harry Jul 30 '19 at 11:45

3 Answers3

2

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"))
            };
}
  • This solution is work unless you are not plan to use canvas. – Mojahed Elbakre Jul 30 '19 at 17:46
  • You should explain a little more your answer. Just from this it's really hard to tell how or why your answer works. – ifconfig Jul 30 '19 at 18:10
  • While this code may solve the question, [including an explanation](//meta.stackexchange.com/q/114762) of how and why this solves the problem would really help to improve the quality of your post, and probably result in more up-votes. Remember that you are answering the question for readers in the future, not just the person asking now. Please [edit] your answer to add explanations and give an indication of what limitations and assumptions apply. – Dharman Jul 30 '19 at 22:47
  • hmmm, ok. Done! – Mojahed Elbakre Jul 31 '19 at 12:27
0

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:

gcasar
  • 729
  • 1
  • 9
  • 22
  • is there no other way than using a canvas? I am storing the string in an array , but dont know how to rotate it – Harry Jul 30 '19 at 10:44
  • Not that I know of short of parsing the png data yourself. If this was a bmp it would be trivial, but png is compressed. – gcasar Jul 30 '19 at 10:48
  • oh, thank you Greg. I really just want to rotate it 90 degrees before passing it to a component. as once it is in component it doesn't act the way I want it. so I have to rotate it before it reaches the component. – Harry Jul 30 '19 at 10:51
0

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)'}} />
  }
/>  
Mosè Raguzzini
  • 15,399
  • 1
  • 31
  • 43
  • I already tried this and it rotates on viewing it but I want to save it as a rotated file. rotating it on the component is not giving me the result I want. Thank you Mose for trying to help me. really appreciate it. – Harry Jul 30 '19 at 10:57
  • If you want to save it as rotated, canvas is the most viable way and it's how is done in 100% on FE env I've seen – Mosè Raguzzini Jul 30 '19 at 10:58
  • 1
    The canvas can be offscreen (you don't have to render it to screen to get the rotated image and send it to the server) – Mosè Raguzzini Jul 30 '19 at 10:58
  • canvas way is given in this solution stackoverflow.com/a/17043361/11368483 . and I tried it, but it is returning getcontext as null, and I don't know why. that's why I stopped approaching it that way and that solution is written for jquery code not reactjs – Harry Jul 30 '19 at 11:03
  • 1
    @Harry, nothing stops your from using jQuery with reactjs. By the way, there's no other way you can rotate the image but canvas – lucifer63 Jul 30 '19 at 11:27