This is how you can rotate the image.
#Auto rotate based on EXIF
Some smartphones uses EXIF-information to let applications know how the image is rotated. This is in general handled by image processing tools. But if you, for example, take a image with your iPhone and email the image to yourself and then adds it to your website, then it will not adhere to the EXIF-information.
Let us see how it works.
You need the EXIF extension to support auto-rotation of JPEG-images.
|Image taken with iPhone.
|Same image but auto rotated using EXIF.
#Rotate based on angle
If you need to rotate the image, you do so by adding the angle to rotate. This is how you use the same source image as above, and rotate it “by hand” to make it look okey.
|Image from iPhoto, rotated -90°.
|Image from iPhoto, rotated 0°.
|Image from iPhoto, rotated 90°.
|Image from iPhoto, rotated 180°.
|Image from iPhoto, rotated 270°.
#Rotate before or after processing?
Hmmm, in the example above, you got two different results on the resulting image dimension. Why? Well,
aro, auto-rotate rotates the source image before its resized and
r, rotate rotates the image after its resized.
The difference can be spelled out as this.
- Before. Take the image, rotate it, then give it its final dimensions which makes some sense with respect to the width and height you are expecting.
- After. Take the image, resize it and then rotate the image. The target size you expect is there, but inverted - you get a portrait image and turn it to a landscape image and width and height are swapped.
|Rotate before or after resizing|
|Rotate before, final dimension as expected (same as
||Rotate after, expected dimensions are inverted, width becomes height and height becomes width.
So, normally this makes sense, but if you get in trouble, remember that rotate before, or after, processing and resizing, gives different results.
#Rotate non perpendicular angle
If you rotate the image in a non perpendicular angle you need to fill the background with a color. You control what color to use with
|Rotate and fill remaining space|
|Use auto rotation to get it right in the first place.
|Rotate 15 degrees, before processing. Resulting image keeps its dimensions,
|Rotate 15 degrees, after processing. Resulting image gets unknown dimensions.
|Rotate 15 degrees, after processing. Use
|Rotate 15 degrees, after processing. Combine with