“幻影坦克”图片的原理和任意两张图片合成幻影坦克图的完备性讨论

简书里看不了幻影坦克,点了也没用

大概很久很久以前有过一阵子很火的一种图片,大概就是一张图片,在预览的时候看起来是一张图,然而点进去看详情的话是另一张图。正好最近这种图不知道为啥就又火了,那就来讲讲这种图的原理。

“幻影坦克”图实际上是一张有特殊透明度分布的图片,而它实现“预览一张,详情一张”的原理实际上有点无聊:由于这张图的透明度分布,可以让图片在不同的背景色下看起来是不同的。而所谓的预览和详情不同只是利用了许多app移动端的设计:预览时的背景是白色,而全屏查看大图时,则会选择黑色作为图片背景。而在不同透明度下就显出了不同的图案。


上图在黑色和红色背景下的表现

于是幻影坦克很多问题就很好解释了:为什么幻影坦克图不生效?(只有两张图中的某一张)可能是因为:
1、某些途径下复制/保存文件会丢失alpha通道也就是透明度信息,强制把背景变成黑色,那自然是没有。
2、图片所在的平台没有使用“预览白色背景,详情黑色背景”的设计。

然而!

我们工程师自然不会满足于这样流于表象的定性解释,如果我们要把两张图合在一起,那么有什么通用的解决方案呢?
好,首先我们通过查阅资料找到了透明度叠加的公式:
Alpha混合公式如下:
R(C)=(1-alpha) * R(B) + alpha * R(A)
G(C)=(1-alpha) * G(B) + alpha * G(A)
B(C)=(1-alpha) * B(B) + alpha * B(A)
于是我们取红色为例,假设我们的目标表图(预览图)的某个坐标的像素点的红色为r1,目标里图(详情图)的某个坐标的像素点为r2。而我们图片本身的红色为r,透明度为alpha,则对于黑色、白色背景而言,上式变为:
r1 = alpha * r
r2 = 255(1 - alpha) + aplha * r

很容易解得方程:
alpha = (r1 - r2) / 255 + 1
r = r1 / alpha = r1 / ((r1 - r2) / 255 + 1) (alpha≠0)

*当alpha = 0时,r有无限根

于是我们获得了一个映射,对任意两张目标图片,已知其像素分布的情况下,都可以得到幻影图对应坐标下的颜色和对比度。

于是,我们的图片方案就完成啦!可喜可贺可喜可贺……

(然而事情并没有这么简单)
需要注意到一件事情,颜色和透明度的取值是有范围的。对于色值r而言,取值范围在[0, 255],而对于透明度,取值在[0, 1]。
首先我们看alpha的取值范围:
0 <= alpha <= 1
将alpha的解带入可得:
0 <= (r1 - r2) / 255 + 1 <= 1
化简得
-255 <= r1 - r2 <= 0
注意到由于r1和r2都是色值,因此取值范围都是[0, 255]。因此显然r1 - r2 >= -255总是满足,因此alpha的取值范围约束使得目标图片的色值有一条件:
r2 >= r1

接下来看r,对r,有
0 <= r <= 255
代入r之后,化简可得:
0 <= r1 / (r1 - r2 + 255) <= 1
由刚才alpha的约束和开头alpha=0情况的讨论可知:r1 - r2 > -255,而r1 >= 0。因此 r1 >= 0,r1 - r2 + 255 > 0。于是 r1 - r2 + 255 >= 0始终成立。
对r1 / (r1 - r2 + 255) <= 1,根据上述讨论可化为:
r1 <= r1 - r2 + 255
得到r2 <= 255,亦始终满足。

于是制作幻影坦克图的完备性如下。
对任意两张图片1和2,若满足:
图1在任意一点的rgb色值均大于图2在相同点的色值,则可以以图1为表图,图2为里图做成一张幻影坦克图。

那完了呀!幻影坦克图对目标图片有要求,那岂不是很多表情包都做不了了?

不要慌!

我们是程序员嘛,我们最擅长的事情就是解决不了的问题让产品改需求。细心的同学可能已经发现了一件事,就是幻影图的表图看起来都比较白,里图看起来都比较黑。如果更细心一点去拿取色器看,会发现:里图里的白色部分和表图里的黑色部分都不是纯黑纯白,甚至都不算是黑色或者白色,而是在128左右的灰色。

这下破案了,解决不了问题可以改变问题嘛。我们更改一下需求,把需求的目标图都强行变成满足色值要求的图片不就行了?
于是我们给目标表图叠上一层半透明白色,给目标里图叠上一层半透明黑色,之前的r1、r2就变成了r1'、r2’:
r1' = r1 / 2
r2' = r2 / 2 + 128
由于r1 r2都在0到255之间,这样就可以让r1'和r2'都满足幻影坦克的成图条件,之后根据映射进行生成,就可以了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,928评论 6 509
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,748评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,282评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,065评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,101评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,855评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,521评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,414评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,931评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,053评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,191评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,873评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,529评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,074评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,188评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,491评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,173评论 2 357

推荐阅读更多精彩内容