关于图片文件旋转JPEG与EXIF信息
比如某相机拍摄出来的相片,文件分辨率比如宽度7360像素,高度4912像素
十进制表示为 DEC : 7360 * 4912
十六进制则为 HEX : 1CC0 * 1330
默认情况下,会在00000030:07标志位(不同设备或程序生成的图片的标志位会有所不同,由EXIF内容而定)上存放01值表示原始文件的位置,无论这张图是横着拍的还是坚着拍的,初始值为01
那么图片,在Windows 10操作系统下,通过操作系统自带的“相片”程序进行旋转时,仅仅对此标志位进行改变,而图片的内容不会做任何改变,包括旋转后的宽度与高度也不会做改变,包括JPEG和EXIF中的宽度与高度信息。
1、向右旋转90度,标志位为06
2、再向右旋转90度,即旋转了180度,标志位为03
3、再向右旋转90度,即旋转了270度,标志位为08
4、再向右旋转90度,即旋转了360度,回到原图,标志位还原为01
然而,在Windows 10进行旋转的图片,如果在Windows XP或Windows 7上面通过“相片”进行查看仍然显示为未旋转前的图片,因为不识别这个标志位。
资源管理器在显示分辨率那一栏中也自然是无法识别,低版本的程序无法识别高版本的标志位导致的问题。
于是,在处理旋转过后的图片,通过JDK 8.0版本去读取javax.imageio.ImageIO.read(new File(fileName)).getWidth/getHeight宽度和高度时,也是无法获知到底是不是旋转过的。
包括其他比如HypeSnap 5.6.0版本的一些旧程序,在打开时都会由于不支持这种方式而导致仍是未旋转的问题。
但是,如果是在Windows XP或Windows 7当中,对图片文件进行旋转时,文件的内容做了全面的变化。旋转后的宽度与高度也会改变并保存到EXIF中,图片内容的改变。这样旋转后的文件在其他操作系统上进行打开时都是正确的旋转后的结果。
解法:比如新版本的HypeSnap 8.16.17版本已经可以支持这个特殊的标志位,能够正确识别并展现

这篇博客探讨了JPEG图片在不同Windows系统下旋转时,如何通过EXIF信息来标识旋转状态。Windows 10仅更改标志位,而低版本系统可能无法识别,导致显示问题。内容讨论了旧版程序不支持新标志位的情况,以及解决这个问题的方法。同时提到了JPEG/EXIF文件格式的相关规范。
1万+

被折叠的 条评论
为什么被折叠?



