亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 深入了解canvas在移動端繪制模糊的問題解決

深入了解canvas在移動端繪制模糊的問題解決

熱門標(biāo)簽:欣鼎電銷機器人 效果 高德地圖標(biāo)注商戶怎么標(biāo) 惡搞電話機器人 電話機器人技術(shù) 智能電銷機器人被禁用了么 ok電銷機器人 黃石ai電銷機器人呼叫中心 如何查看地圖標(biāo)注 地圖標(biāo)注軟件打印出來

由于一些移動端的兼容性原因,我們某個項目需要前端將pdf轉(zhuǎn)換成在移動端頁面可直接觀看的界面。為了方便解決,我們采用了pdf.js這個插件,該插件可以將pdf轉(zhuǎn)換成canvas繪制在頁面上。不過,在測試過程中卻發(fā)現(xiàn),在移動端的瀏覽器上, 繪制的內(nèi)容展示十分模糊(如下圖),經(jīng)過分析之后發(fā)現(xiàn)是由于移動端高清屏幕引起的。 在解決問題之后以文字方式記述原因和探究結(jié)果

在解釋問題之前,首先需要了解一些移動端顯示和cavans的小知識,方便后面探究。如果想直接看結(jié)果的話看可以拉到最后。

關(guān)于屏幕的一些基礎(chǔ)知識

物理像素(DP)

物理像素也稱設(shè)備像素,我們常聽到的手機的分辨率及為物理像素,比如 iPhone 7的物理分辨率為750 * 1334。屏幕是由像素點組成的,也就是說屏幕的水平方向有750的像素點,垂直方向上有1334個像素點

設(shè)備獨立像素(DIP)

也稱為邏輯像素,比如Iphone4和Iphone3GS的尺寸都是3.5寸,iphone4的物理分辨率是640 * 980,而3gs只有320 * 480,假如我們按照真實布局取繪制一個320px寬度的圖像時,在iphone4上只有一半有內(nèi)容,剩下的一半則是一片空白,為了避免這種問題,我們引入了邏輯像素,將兩種手機的邏輯像素都設(shè)置為320px,方便繪制

設(shè)備像素比(DPR)

上面的設(shè)備獨立像素說到底是為了方便計算,我們統(tǒng)一了設(shè)備的邏輯像素,但是每個邏輯像素所代表的物理像素卻不是確定的,為了確定在未縮放情況下,物理像素和邏輯像素的關(guān)系,我們引入了設(shè)備像素比(DPR)這個概念

設(shè)備像素比 = 設(shè)備像素 / 邏輯像素
DPR = DP / DIP

上面說了很多理論,下面附個圖解釋一下

從上面的圖可以看出,在同樣大小的邏輯像素下,高清屏所具有的物理像素更多。普通屏幕下,1個邏輯像素對應(yīng)1個物理像素,而在dpr = 2的高清屏幕下,1個邏輯像素由4個物理像素組成。這也是為什么高清屏更加細膩的原因。

關(guān)于canvas的一些基礎(chǔ)知識

 canvas繪制的是位圖

這是一個所有了解過canvas的人都應(yīng)該知道的知識點,也是接下來我們將要分析問題的核心。

關(guān)于位圖的解釋我們放在后面,現(xiàn)在我們只要知道canvas繪制的圖像是位圖。

canvas的width和height屬性

canvas的width和height屬性是初學(xué)者非常容易搞錯的內(nèi)容。這兩個屬性經(jīng)常會與css中的width和height屬性混淆。

比如我們有如下代碼(1):

<canvas width="600" height="300" style="width: 300px; height: 150px"></canvas>
  • style中的width和height分別代表canvas這個元素在界面上所占據(jù)的寬高, 即樣式上的寬高
  • attribute中的width和height 則代表canvas實際像素的寬高

如果還無法理解的話,可以想象成以下的代碼(2):

<!-- logo.png的像素為600 * 300  -->
<img  style="width: 300px; height: 150px" src="logo.png" /> 

canvas默認的width和height是300 * 150,對其設(shè)置了css之后, canvas會根據(jù)設(shè)置css寬高進行縮放(注意不是裁剪) ,這一點和img標(biāo)簽一樣

上述代碼(1)其實還可以再換一種更通俗的解釋方式,就是1個邏輯像素實際上由2個canvas像素填充。

模糊原因的初步探討

上面是對所需基礎(chǔ)知識的一些簡介,下面開始正式進行探究。

首先我們提到使用canvas繪制圖像的是位圖,而我們平常用的jpg,png也是位圖。那么什么是位圖?

位圖又叫像素圖或柵格圖,它是通過記錄圖像中每一個點的顏色、深度、透明度等信息來存儲和顯示圖像。具象一點講,可以將位圖想象成一個巨大的拼圖,這個拼圖有無數(shù)的拼塊,每個拼塊代表了一個純色的像素點。 理論上,1個位圖像素對應(yīng)著1個物理像素 。但假如說你使用了高清屏,比如蘋果的retina屏去查看一幅圖畫,又會是什么樣子呢?

假設(shè)我們有如下代碼,該代碼將展示在iphone4的retina屏上:

<canvas width="320" height="150" style="width: 320px; height: 150px"></canvas>

iphone4本身的物理像素為640 * 980,而設(shè)備獨立像素為320 * 480,這代表著1個css像素實際由4個物理像素構(gòu)成,canvas的像素為320 * 150,其css像素為320 * 150,則代表1個css像素將會由1個canvas元素構(gòu)成,這樣進行換算, 在retina屏幕下,1個canvas像素(或者說是1個位圖像素)將會填充4個物理像素,由于單個位圖像素不可以再進一步分割,所以只能就近取色,從而導(dǎo)致圖片模糊 。

如果還有疑惑的話,以下的圖片可以說明位圖在retina屏幕下是如何填充的:

上圖中左側(cè)的是在普通屏幕下的顯示規(guī)則,可以看出有4個位圖像素點,而右側(cè)的高清屏幕下則有16個像素點。由于像素點不可切割的原因,顏色產(chǎn)生了改變。

但是還有一點沒有解釋清楚,就是為什么圖片會就近取色而不是直接取原值,這也是導(dǎo)致模糊的幕后黑手。

幕后黑手---平滑處理技術(shù)

下面是我的某位大佬同學(xué)幫我解釋的,剛才我們說了每個位圖元素實際上一個純色的像素點?,F(xiàn)在假設(shè)我們需要在一個css大小為4px * 4px,dpr為1普通屏幕上繪制一個數(shù)字“0”,那么我們繪制的樣子應(yīng)該如下圖,其中1代表黑色像素點,0代表白色像素點。

可以看出在dpr比較小的情況下,我們的“0”這個圖案還比較明顯,現(xiàn)在假如我們css大小不變,但是改成在retina屏幕下繪制圖像,效果又會變成什么樣呢?

我們已知在retina屏幕下,一個css像素代表4個物理像素,假如我們不做任何處理,直接按照上面矩陣排列,將矩陣擴大的話,會發(fā)現(xiàn)在retina屏幕下,我們的圖案鋸齒感非常明顯,圖像明顯缺乏了一絲順化。

假如我們對圖像稍作改變,改成下圖這樣

圖像感覺瞬間柔和了, 但是原本應(yīng)該4個0充斥的地方變成了3個1加上1個0。這其實就是所謂的圖像平滑處理,為了解決鋸齒感覺,將原本的顏色改變,在充斥著較多顏色的圖片上,為了更自然,圖片的連接處變成了近似的顏色,這也解釋了為什么上面填充顏色的時候不是使用本色而是使用近似色。

原因總結(jié)

通過了上述的解釋,現(xiàn)在我們來總結(jié)以下結(jié)論,在移動端盛行,高清屏基本上已經(jīng)普及的現(xiàn)在,1px的css像素實際上代表了4個甚至更多的物理像素。但是由于我們的代碼問題,我們1px的css像素和1個canvas像素畫上了等號,也就導(dǎo)致了1個canvas像素實際需要填充4個甚至更多物理像素,為了保證圖像平滑處理,在填充剩余的物理像素時采用了原先顏色的近似值,導(dǎo)致了圖像的模糊。

解決思路

了解了問題出現(xiàn)的原因,解決問題就很容易,解決該問題最重要的一點是讓1個canvas像素和一個物理像素掛等號

高版本的瀏覽器的window對象下都掛著一個devicePixelRatio屬性,該屬性就是上面所說的dpr,

在canvas元素css寬高確定的情況下,我們可以這么做

let canvas = document.getElementById('canvas');
let ctx = canvas.getContext('2d');
let dpr = window.devicePixelRatio; // 假設(shè)dpr為2
// 獲取css的寬高
let { width: cssWidth, height: cssHeight } = canvas.getBoundingClientRect();
// 根據(jù)dpr,擴大canvas畫布的像素,使1個canvas像素和1個物理像素相等
canvas.width = dpr * cssWidth;
canvas.height = dpr * cssHeight;
// 由于畫布擴大,canvas的坐標(biāo)系也跟著擴大,如果按照原先的坐標(biāo)系繪圖內(nèi)容會縮小
// 所以需要將繪制比例放大
ctx.scale(dpr,dpr);

經(jīng)驗總結(jié)

很多時候,我們發(fā)現(xiàn)了問題,不能之集中于問題的解決,而是應(yīng)該深入去了解問題發(fā)生的原因,這樣才能更好的在這行走下去。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:金昌 阿壩 赤峰 萍鄉(xiāng) 聊城 盤錦 綏化 中山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《深入了解canvas在移動端繪制模糊的問題解決》,本文關(guān)鍵詞  深入,了解,canvas,在,移動,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《深入了解canvas在移動端繪制模糊的問題解決》相關(guān)的同類信息!
  • 本頁收集關(guān)于深入了解canvas在移動端繪制模糊的問題解決的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    免费一级生活片| 日韩专区第一页| 精品国产三级a| 色综合久久天天综合| 台湾美女古装一级毛片| 97视频免费在线| 午夜欧美福利| 成人免费网站久久久| 成人a大片高清在线观看| a级毛片免费全部播放| 欧美大片aaaa一级毛片| 99色精品| 欧美一级视| 国产一区二区精品久久| 国产激情视频在线观看| 亚洲精品久久玖玖玖玖| 沈樵在线观看福利| 日本乱中文字幕系列| 美女免费精品高清毛片在线视| 久久成人性色生活片| 国产a网| 国产视频一区二区三区四区| 99久久精品国产免费| 青草国产在线观看| 99色视频在线观看| 日本免费区| 午夜在线影院| 日本乱中文字幕系列| 精品久久久久久综合网| 国产福利免费视频| 国产极品精频在线观看| 国产极品精频在线观看| 国产不卡在线观看视频| 黄视频网站在线看| 精品国产亚一区二区三区| 日日夜夜婷婷| 成人在免费观看视频国产| 韩国三级视频在线观看| 国产网站在线| 国产视频一区二区在线播放| 国产麻豆精品免费密入口| 久久99爰这里有精品国产| 色综合久久天天综合观看| 日本乱中文字幕系列| 韩国三级香港三级日本三级la| 国产不卡在线观看视频| 精品视频在线看| 久久久久久久免费视频| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 沈樵在线观看福利| 日日日夜夜操| 国产91精品一区二区| 夜夜操网| 亚洲 欧美 成人日韩| 亚洲第一页乱| 亚洲 激情| 日本免费乱人伦在线观看 | 99久久精品国产高清一区二区 | 久久国产精品永久免费网站| 久草免费在线观看| 日韩免费片| 国产成人精品综合在线| 国产视频网站在线观看| 国产一区二区精品久久91| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 四虎久久精品国产| 成人高清护士在线播放| 国产激情一区二区三区| 韩国毛片免费大片| 美女免费精品高清毛片在线视| 精品久久久久久影院免费| 欧美1区| 九九久久99综合一区二区| 成人影视在线播放| 亚洲精品影院久久久久久| 麻豆系列 在线视频| 国产视频一区二区三区四区| 91麻豆精品国产片在线观看| 精品国产三级a| 日本伦理黄色大片在线观看网站| 国产精品免费久久| 国产一区免费在线观看| 国产麻豆精品hdvideoss| 二级片在线观看| 久久久成人网| 国产高清在线精品一区a| 精品视频在线观看视频免费视频| 青草国产在线观看| 成人免费一级纶理片| 精品视频免费在线| 一级片免费在线观看视频| 色综合久久天天综线观看| 99久久网站| 九九九网站| 色综合久久天天综线观看| 精品在线视频播放| 九九免费高清在线观看视频| 午夜在线观看视频免费 成人| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 毛片高清| 天天做人人爱夜夜爽2020毛片| 欧美国产日韩精品| 青青久久精品| 欧美国产日韩精品| 高清一级做a爱过程不卡视频| 成人免费网站久久久| 国产激情一区二区三区| 亚洲女人国产香蕉久久精品 | 久久久久久久久综合影视网| 国产伦精品一区三区视频| 久久福利影视| 日本在线不卡视频| 免费一级片网站| 久久99这里只有精品国产| 成人a大片在线观看| 青草国产在线| 精品国产香蕉在线播出| 九九干| 国产原创中文字幕| 亚飞与亚基在线观看| 国产a视频| 亚欧视频在线| 国产高清视频免费| 欧美另类videosbestsex高清| 国产91视频网| 91麻豆tv| 精品国产三级a| 中文字幕97| 97视频免费在线观看| 天堂网中文字幕| 欧美电影免费| 国产成a人片在线观看视频| 久久99青青久久99久久| 午夜欧美成人香蕉剧场| 国产不卡在线观看| 999久久66久6只有精品| 午夜激情视频在线播放| 欧美1区| 天天做人人爱夜夜爽2020毛片| 黄色免费网站在线| 一本高清在线| 欧美另类videosbestsex视频 | 国产视频久久久久| 韩国三级视频在线观看| 99色精品| 国产不卡在线观看| 国产综合成人观看在线| 在线观看成人网 | 亚洲第一页乱| 日本免费看视频| 深夜做爰性大片中文| 成人免费福利片在线观看| 欧美a免费| 青草国产在线观看| 精品久久久久久影院免费| 亚洲精品永久一区| 国产不卡高清在线观看视频| 国产a网| 99久久精品费精品国产一区二区| 美女免费精品高清毛片在线视| 黄视频网站免费看| 国产91丝袜高跟系列| 成人高清护士在线播放| 日本在线www| 日本乱中文字幕系列| 国产一区二区精品久久91| 国产欧美精品| 日韩中文字幕在线播放| 成人免费观看男女羞羞视频| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 日本乱中文字幕系列| 99热热久久| 日韩av成人| 亚飞与亚基在线观看| 亚欧乱色一区二区三区| 精品国产一区二区三区精东影业| 日韩在线观看网站| 国产国语在线播放视频| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 亚州视频一区二区| 免费毛片播放| 国产高清在线精品一区a| 精品在线观看一区| 亚州视频一区二区| 国产不卡高清在线观看视频| 欧美a级片视频| 国产精品免费久久| 国产美女在线观看| 国产精品免费久久| 成人免费观看的视频黄页| 黄视频网站在线免费观看| 国产91精品系列在线观看| 日本免费乱人伦在线观看 | 九九久久99综合一区二区| 亚洲女人国产香蕉久久精品 | 亚洲 国产精品 日韩| 91麻豆精品国产自产在线 | 韩国毛片免费| 亚洲天堂免费| a级精品九九九大片免费看|