浏览器自动旋转图片的问题(Exif的oritetion原因)

本文探讨了浏览器中图片自动旋转的原因,即Exif信息中的orientation属性。详细解释了Exif的含义,阐述了手机拍摄照片保存旋转角度导致浏览器显示异常的现象。并提出了三种解决方法,包括删除Exif信息、使用特定CSS属性和通过读取Exif信息并用canvas旋转图片以修正方向。
摘要由CSDN通过智能技术生成

浏览器自动旋转改变图片的方向的原因是由于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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值