也许是印度的程序员铁子们知道咱快过年了, “特意” 在 iOS 18.2 的系统更新上,新增了一个挺喜庆的 bug。
事情是这样的,有些网友的 iPhone 更新到了 iOS 18.2,在相册里查看图片、截图,然后查看截图、再截图,套娃几次,图片颜色就会越来越红。

我愿称之为果粉的春节限定。。。调侃归调侃,托尼其实挺好奇这个 bug 到底是因为啥?
网上有种说法是这样的, iPhone 在相册里查看图片时,用的是 sRGB 色域,而在系统截图的时候,图片则保存成 P3 色域模式。问题是 P3 的色彩描述范围比 sRGB 大,所以 sRGB 理解的红色跟 P3 理解的红色是不一样的。
就比如说, sRGB 色域下的纯红标记为(255 , 0 , 0),括号中的(R , G , B)值,就是颜色在色彩空间中的位置坐标。如果将它正确映射到到 P3 色域的话,纯红应该被标记为(234 , 51 , 35)。
目前来看, iPhone 在颜色的映射上不知道出了啥差错,总之就是没对应上。重复截图就相当于在俩不一致的色域范围之间反复横跳,不断叠加这个 bug ,就导致颜色偏差越来越大,照片最后就 “ 红温 ” 了。。。

当然这只是网友的一个说法,不过托尼也简单测试了一下。
我先是找到了一张原始色域为 sRGB 的图片,然后发现,假如在全屏显示的状态下截图,就不会变红。但是如果带一点系统 UI ( 比如状态栏和后台界面啥的 ),就会截图成 P3 色域,再截图就会越来越红,大概率就是系统界面的 P3 色域映射出了问题。
全屏状态下截图,依旧为 sRGB 色域;露出系统 UI 状态下截图,就保存成了 P3 色域

以前都没啥问题,现在突然有这个 bug ,很难不让人联想到苹果前一阵儿宣布的系统新功能——

是这么回事儿,苹果在 WWDC24 全球开发者大会上,推出了新 HDR 标准—— Adaptive HDR ( 自适应高动态范围 )。这个新标准,不光相册、信息、快速查看和预览支持 HDR ,甚至连截图和录屏的文件也要支持 HDR 的渲染和显示。。。

于是苹果的截图就用上了色域更广、色彩更多的 P3 色域,但目前看来代码没调好。按照预想的剧情,苹果本是想秀一把自家高标准的,但是实际情况,却是整出了新 bug。
不过,具体原因到底是不是这么一回事,可能还得等苹果官方的结论,不过刷到这次 iOS 18 出 bug 的新闻之后,托尼脑袋里立马就想到了当年安卓的一档子事。
稍微上了点岁数的差友们可能还有印象,在那个贴吧、论坛斗图盛行的年代,很多表情包每多保存、上传一次,画面就会变糊一点,到最后,甚至颜色还会诡异地变绿, “ 电子包浆 ” 就是这么来的。

为啥图片会变糊?表面上的原因大家都知道,无非是用户在上传照片时没有选择原图,再加上平台为了节省存储空间和网络带宽,对图片进行了压缩处理。
但实际上,即使是压缩,最多也就是清晰度变差,也不应该变绿。所以本质上,还是当年的安卓在进行转换的时候,压缩算法捅出了大篓子。

具体来说,大部分显示设备,比如咱手里的手机、显示屏啥的,都是基于 RGB 色彩模式工作的。但在图像和视频存储传输的过程中,有一种更简略的、更省计算量的色彩模式,叫做 YUV。对这部分感兴趣的差友,可以自行搜索一下,托尼这里就不啰嗦了。
总之~在正常情况下,由 RGB 转向 YUV 色彩模式的算法已经很成熟了。就算数据转换过程中有点儿画质损失,也不至于出啥幺蛾子。
但是安卓这边压缩图片的接口,准确的说是一个叫做 Skia 的图像库,为了优化运行速度,想了个偷懒方案:
标准的 JPEG 图像在做色彩空间转换的时候,会用至少 16 比特精度 ( 也就是 2^16 种不同的亮度或色度级别 ),但 Skia 降低到了 8 比特。
仅展示位深的对比效果
是的,就是直接降低运算精度,纯偷懒。。。这就导致颜色偏差会越来越大。
再加上安卓为了加快运算过程,在算法方面也出了一些问题。一般来说,绝大多数的 RGB 值经过复杂的公式,转换到 YUV 值时,都会出现小数,但是 安卓选择了直接舍弃小数点后面的部分取整。。。注意是直接舍弃,这个操作直接让用惯了 “ 四舍五入 ” 的托尼喷出一口老血。
于是最后造成的结果就是:亮度值 Y 不断变小,图片不断变暗,色度值 UV 也变小了,颜色就不断向绿色偏移。

再经过斗图传播时图片的不断保存、上传,色彩空间变换算法反复压缩,图片就越来越绿。这个 bug 直到 2016 年 4 月中旬 ( Android 7 )才被修复,留下的梗也流传至今。

相信通过安卓这个编码错误转换的例子,大家已经看出来了,计算机上的色彩显示是一个非常复杂的过程,尤其是现在还有好多种常用的不同色域。
比如标准的 sRGB ,还有厂商们推崇的色域更广的 P3,或者当你看 HDR 视频的时候,要切换的 BT2020 色域等等。。。
显示这门功课变得越来越复杂,不光苹果和安卓在色彩空间这件事上翻过车,实际上,微软到现在也还有问题呢。。。
比如我们每天都在用的 Windows 电脑和 Chrome 浏览器,就有一个已经持续存在了两年,都没有得到修复的 bug:在使用 HDR 显示器的时候,画面经常会映射出一种 “ 惨白 ” 的错误显示效果 ( 图左 ),就导致托尼虽然买了支持 HDR 的显示器,但日常使用还是要关闭 HDR 选项。。。
已经熟练掌握通过截屏的方式稳定复现该 bug

讲到这里,可能有一部分小伙伴会有疑问,不是一直都夸苹果的色彩管理方案做得好?那这些问题苹果也有么?
网站里的图片长这个样子,但不是下面这张压缩过的哦

虽然安卓手机,或者其他设备做到了广色域显示,但是没完全打通第三方,很多时候就只能尴尬地孤芳自赏,在系统相册里 “ 独美 ” 。。。但在苹果阵营,就不需要区分设备、界面和 APP ,用户能得到基本一致的显示效果。

而且直到今天,绝大多数安卓手机和 Windows 电脑,在查看 sRGB 之外的色彩空间内容时,要么需要研究复杂的配置文件,要么需要安装专业软件。。。可以说基本没啥色彩管理可言。
最后回到 iPhone 截图变红的问题,根据目前获取到的信息,托尼基本相信,就是引入截图 HDR 导致的。希望苹果能尽快修复这个 bug,毕竟,苹果已经是所有各家系统里,在色彩管理、 HDR 等等方面走得最远的厂商了。。。
撰文:Levi
编辑:米罗 & 面线


APP专享直播
热门推荐
国家卫健委主任雷海潮:今年将发放育儿补贴 有关操作方案正在起草 收起国家卫健委主任雷海潮:今年将发放育儿补贴 有关操作方案正在起草
- 2025年03月07日
- 05:25
- APP专享
- 扒圈小记
6,684
刘国梁呼吁严惩畸形饭圈文化
- 2025年03月07日
- 04:56
- APP专享
- 扒圈小记
3,610
韩国首尔中央地方法院批准尹锡悦提出的拘留取消申请
- 2025年03月07日
- 05:06
- APP专享
- 北京时间
2,186

24小时滚动播报最新的财经资讯和视频,更多粉丝福利扫描二维码关注(sinafinance)
投资研报 扫码订阅
股市直播
-
数字江恩今天 09:44:18
简单来说,3384后已经震荡了2周时间了,再震荡主要也就是下周一二而已。所以下周前半周关注3336+-10区间支撑,只要不跌破,大盘还会继续向上运行。 -
数字江恩今天 09:44:12
30分钟图来看,15分钟级别的abc只是将大盘拉回了前三角形的轮谷线位置,而宽幅震荡则是在红色轮谷线下的横盘震荡箱体。下周5分钟图的3336+-10只要不跌破,那么横盘震荡完毕,大盘必将站上红色轮谷线。至于站上红色轮谷线后的首轮高度,下周末再说不迟。【更多独家重磅股市观点请点击】 -
数字江恩今天 09:44:00
这是3384之后的5分钟震荡结构,简单来说,下周出还可以有震荡,但是不应该明显超过图上第一轮的回踩,即第一轮最低点3337不应该跌破超过10个点了,3336+-10支撑,也就是不有效跌破5周线,这个震荡结构都将要完美而开始新的1上涨。【更多独家重磅股市观点请点击】 -
数字江恩今天 09:43:47
首先看15分钟图,对前3494的下跌,核心图上蓝色轮峰线不应该再次跌回,本周四拉起来后,以纪念馆不再是问题。预期3140后运行abc+宽幅震荡+12345的结构,目前宽幅震荡并未超出限制,便5分钟图看震荡细部结构。【更多独家重磅股市观点请点击】 -
数字江恩今天 09:43:25
板块来看,本周变化较大,没有持续性热点。工业母机、部分机器人(sz300024)细分如减速器相对来说持续性较好,其余的板块都是涨涨跌跌。 -
数字江恩今天 09:43:19
大盘本周缩量明显,但是在10周线支撑之上,反包了上周的小阴线。下周,5周线将运行到3350,而10周线将运行到3300位置,是下周的支撑,目前若要向上运行,已经不应该再摸到10周线了。当下5周线金叉10周线,对应周K线小幅横盘震荡,并且持续收盘再5周线以上,算是健康的了。只是本周明显缩量,下周初还会有确认。 -
数字江恩今天 09:43:05
下周行情展望2025.03.07 -
趋势领涨今天 09:26:48
中午我们提示,下午大盘会有回落,结果出现了回落,但因为对周末消息面的预期,再加上维稳的原因,所以,尾盘又出现了回升,但很多个股只有回落,没有回升,所以,大盘调整没有结束,原则上,可以持有部分仓位,等下周确定方向以后再说,今天到此。 -
趋势起航今天 08:41:39
【趋势VIP上线预热】华源证券资深投教导师趋势起航直播间将推出《龙头起爆点》VIP,供大家学习,预计下周三之前上线!《龙头起爆点》VIP服务包含:每周3-5只龙头股布局(仓位+区间+逻辑),尊享私密互动,且龙头股策略上最多同时持仓3只,结束一只再更新一只,并全程跟踪。欢迎大家届时支撑! -
北京红竹今天 08:35:11
3、1.82万亿成交额又继续维持1.5万亿以上了,上涨1714家,下跌3556家,涨停62家,跌停12家。只要市场跌停超过12家,那么市场就不具备短线操作情况。对于短线来说,一天KTV、一天ICU很正常。具备情绪就干,不具备就休息。