浏览器自动旋转改变图片的方向的原因是由于Exif信息导致的;
一、Exif是什么?
Exif(Exchangeable image file format)是可交换图像文件格式,主要是为了数码相机(包括手机拍出)的照片设定的,可以记录拍出照片的一些属性信息和拍摄数据。
二、为什么旋转?
手机拍的相关照片会在EXIF中保留图片旋转角度orientation,img标签展示图片就是旋转的。浏览器单独打开图片会帮你处理旋转,所以看到的是打开图片是正常的,所以这也就是我们看到的图片在浏览器中打开的时候指向不对的问题。
三、解决方案
1、使用软件删除照片中包含的Exif信息,这种软件特别多,我们在此就不介绍了。
2、使用css的image-orientation: from-image,不过很遗憾的就是该属性只对firefox和Opera浏览器有效;
3、上述1中的解决方案只适合页面固定的图片,有一定的局限性,第二种方案有浏览器的限制,所以我们通过第三种方案来解决,就是通过获取照片中的Exif信息,然后对照片做出一定的旋转,使其恢复我们本身想要的展示效果。
<1>、通过FileReader,读取文件信息
function getFileInfo(file) {
var reader = new FileReader();
reader.readAsArrayBuffer(file);
reader.onload = function () {
var oritetion = getOritetion(reader.result); //将图片信息传入获取旋转角度的函数中
console.log(o