第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

用CSS來找出兩張圖的差異

標(biāo)簽:
C

本文源自对Image diffing using CSS的理解。

现在有以下两张图片,找出它们之间的差异。

图片描述

图片描述

方法是,将两张图片重叠,高亮出不同的部分。用CSS 主要有两种方法。

方法一:在位于上面的图上设置如下样式

-webkit-filter: invert(100%) opacity(50%);
        filter: invert(100%) opacity(50%);

作用后的效果如下图

用filter的效果

其中,灰色的部分为相同的部分,并且灰色的部分的颜色值为rgb(127.5, 127.5, 127.5)

原理如下。
假设:图1上某点的颜色值为rgb(cr1, cg1, cb1),图2上相同位置的点的颜色值为rgb(cr2, cg2, cb2),图1为在上面的图片。

当图1作用filter: invert(100%)时,该点的颜色值为 rgb(255 - cr1 + cr2, 255 - cg1 + cg2, 255 - cb1 + cb2)

当作用opacity(50%)时,该点的颜色值为rgb((255 - cr1 + cr2)/2, (255 - cg1 + cg2)/2, (255 - cb1 + cb2)/2)

由此可知,如果图1上某点的颜色和对应的图2上某点的颜色值一样的话,该点的颜色值为rgb(255/2, 255/2, 255/2),即 rgb(127.5, 127.5, 127.5)

方法2:在位于上面的图上设置如下样式

        mix-blend-mode: difference;

作用后的效果如下图

用mix-blend-mode.png的效果

其中,黑色的部分为相同的部分。

原理可见这里的描述

应用

有了这个技巧,我们在做页面时,方便的找出做的页面与设计稿不一样的地方。毕竟,人眼并不擅长找两个图片中的细微的不同

开个脑洞,现在,我们需要某个页面是否在两个不同浏览器上的UI 像素级完全的一致。
那么我们可以这样实现

  1. 用无头浏览器分别在不同的浏览器的UI进行截图
  2. 创建一个页面,该页面放的是,两张重叠的截图,并设置filter: invert(100%) opacity(50%);。然后再进行截图。
  3. 读取截图,若截图的每个像素点颜色均为rgb(127.5, 127.5, 127.5),则说明该页面在两个浏览器上UI像素级一致。

PhantomCSS可以做类似的事。

點(diǎn)擊查看更多內(nèi)容
10人點(diǎn)贊

若覺得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
Web前端工程師
手記
粉絲
115
獲贊與收藏
6940

關(guān)注作者,訂閱最新文章

閱讀免費(fèi)教程

感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消