亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

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

2024-08-26 00:21:27
字體:
來源:轉載
供稿:網友

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

canvas,移動端,繪制模糊

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

關于屏幕的一些基礎知識

物理像素(DP)

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

設備獨立像素(DIP)

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

設備像素比(DPR)

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

設備像素比 = 設備像素 / 邏輯像素DPR = DP / DIP

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

canvas,移動端,繪制模糊

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

關于canvas的一些基礎知識

 canvas繪制的是位圖

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

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

canvas的width和height屬性

canvas的width和height屬性是初學者非常容易搞錯的內容。這兩個屬性經常會與css中的width和height屬性混淆。

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

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

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

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

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

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

模糊原因的初步探討

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

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

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

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

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

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

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

canvas,移動端,繪制模糊

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

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

幕后黑手---平滑處理技術

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

canvas,移動端,繪制模糊

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

canvas,移動端,繪制模糊

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

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

canvas,移動端,繪制模糊

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

原因總結

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

解決思路

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

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

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

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

經驗總結

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到HTML教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
中文av一区二区三区| 91精品国产成人| 欧美一区二区在线视频观看| 国产在线精品一区| 欧美xxxxx牲另类人与| 亚洲第一精品区| 亚洲2区在线| jlzzjlzz欧美大全| 亚洲第一精品区| 国产老女人av| 正在播放一区| 久久精品国产一区二区三区不卡| 欧美成人精品一区二区男人看| 999久久欧美人妻一区二区| 日皮视频免费观看| 伊人色综合久久天天五月婷| 精品国产一区二区三区麻豆免费观看完整版| 永久免费毛片在线观看| 牛牛视频精品一区二区不卡| 国产在线拍揄自揄拍无码| 日韩成人一区| 在线观看男女av免费网址| 久久中文字幕精品| 亚洲va国产日韩欧美精品色婷婷| 亚洲国产欧美日韩在线| 99热精品国产| 久久综合五月婷婷| 奇米精品一区二区三区在线观看一| 欧美男男freegayvideosroom| 国产精品久久人| 欧美一区二区三区激情| 国产精品麻豆欧美日韩ww| 日韩av高清在线播放| 日韩一区欧美小说| 97国产精品免费视频| 国产精品成人久久久久| 超碰影院在线观看| 嫩草成人www欧美| 国产精品成人观看视频免费| 国产精品日本欧美一区二区三区| 99re在线观看视频| 蜜芽tv福利在线视频| 亚洲国产欧美自拍| 在线观看美女av| 日本黄色小视频在线观看| 精品久久中文| 最美情侣韩剧在线播放| 日韩午夜av| 国产精品美女一区二区| 91久久精品一区二区三区| 日韩欧美激情四射| 欧美激情在线| 久久久久国产精品午夜一区| 日本一区高清不卡| 精品国产乱码久久久久久樱花| 影音先锋男人每日资源站| 国产精品69av| 污污的视频网站在线观看| 欧美精品一区二区三区久久久竹菊| 电影k8一区二区三区久久| 午夜国产精品影院在线观看| 中文字幕视频在线观看| 成年人在线观看视频免费| 欧美人体做爰大胆视频| 欧美日韩国产成人精品| 91大神福利视频在线| 欧美精品色一区二区三区| 女王人厕视频2ⅴk| 久久黄色精品视频| 欧美精品www| 免费成人在线视频网站| 欧美黄色免费在线观看| 亚洲人成午夜免电影费观看| 欧美日韩国产精品一区二区不卡中文| 成人免费福利视频| 丝袜在线观看| 亚洲第一二区| 国产在线播放av| 欧美一级免费大片| 波多野结衣在线网站| 欧美韩国日本精品一区二区三区| 国产午夜精品久久| 91免费综合在线| 另类一区二区三区| 欧美激情精品| 亚洲欧美精品伊人久久| 日韩大片在线免费观看| 99精品一级欧美片免费播放| 精品午夜一区二区| 久久电影视频| 欧美午夜寂寞| 成年人视频网站在线| 麻豆精品免费视频入口| 国产欧美日韩综合一区在线观看| 亚洲天堂av在线免费| 国产精品超碰97尤物18| av超碰在线观看| 精品国产精品久久一区免费式| 暧暧视频在线免费观看| 中文字幕免费在线不卡| 欧美成人另类视频| 成人亚洲欧美日韩在线观看| 亚洲无线一线二线三线区别av| 中文字幕无码日韩专区免费| 免费av在线一区二区| 精品国模在线视频| 午夜黄色福利视频| 加勒比在线日本| 一本大道综合伊人精品热热| 国内精品久久影院| 精品日韩一区二区| 色综合电影网| 99国产超薄肉色丝袜交足的后果| 亚洲一区二区三区涩| 丝袜在线视频| 欧美69wwwcom| 91精品国产乱码久久久| 另类专区亚洲| 一本一道波多野毛片中文在线| 涩爱av色老久久精品偷偷鲁| 波多野结衣视频观看| 免费高清视频在线观看| www.午夜激情| 欧美黄色片在线观看| 一区二区欧美久久| 亚洲一区成人在线| 91人妻一区二区三区蜜臀| 天天天干夜夜夜操| 国内精彩免费自拍视频在线观看网址| 理论片午夜视频在线观看| 人体私拍套图hdxxxx| 亚洲女人毛片| 中文在线免费一区三区高中清不卡| 嫩草影院永久一二三入口| 一级黄色片在线免费观看| 精品久久久久久久久久久久久久久久| 操操操日日日| 日韩女优电影在线观看| 免费男女羞羞的视频网站中文字幕妖精视频| 国产乱人视频免费播放| 一区二区三区无码高清视频| 国产在线视视频有精品| 永久免费的av网站| 日韩精品在线看| 国产老女人精品毛片久久| 欧美亚洲第一区| 人人视频精品| 亚洲成人午夜在线| 欧美天堂亚洲电影院在线观看| **三级三级97片毛片| 国产成人亚洲综合a∨猫咪| 黑人巨大狂躁日本妞在线观看| 91淫黄看大片| 亚洲综合色视频在线观看| 99高清视频有精品视频| 自拍偷拍亚洲图片| www.精品视频| 黄色在线观看网| 欧美一级黑人aaaaaaa做受| 日韩免费va| 99精品久久久久久中文字幕| 久久精品亚洲一区| 中文字幕在线观看成人| 国产精品一区二区黑丝| 日韩美脚连裤袜丝袜在线| 黄网站在线观| 青青操在线视频| 国产小视频免费在线观看| 国产精品视频你懂的| 久草热在线观看| 中文字幕一区二区三区在线观看| 久久韩剧网电视剧| 天堂中文在线资源| 99re6热只有精品免费观看| 欧美xxx.com| 国产 欧美 日韩 在线| 亚洲成在人线免费视频| av无码久久久久久不卡网站| 日本少妇吞精囗交| 日本一区二区视频在线观看| 国产综合久久久久影院| 久久久久久久久久一区二区| 天天久久夜夜| 亚洲人一二三区| 亚洲欧美另类久久久精品2019| 91传媒免费观看| 国a精品视频大全| 国语对白做受69| 欧美激情四色| 91福利免费在线| 亚洲男人天堂av网| 欧美日韩在线中文| 四虎成人免费影院| 亚洲av毛片成人精品| 成人h视频在线观看播放| 91麻豆精品国产91久久综合| 97久草视频| 欧美精品一区二区蜜臀亚洲| www免费在线观看视频| 亚洲缚视频在线观看| 亚洲女人久久久| 免费在线观看的av| 99在线视频免费| 天堂资源最新版在线视频观看免费网| 久久99久久99精品中文字幕| 精品人妻少妇嫩草av无码专区| 日韩精品一区二区三区老鸭窝| av在线亚洲一区| 国产美女一区| 国产中文字幕乱人伦在线观看| 国产乱淫av一区二区三区| 欧洲av无码放荡人妇网站| av手机免费在线观看| 亚洲少妇30p| 一区二区三区四区高清视频| 黑人精品无码一区二区三区AV| 成人黄色在线电影| 国产成人在线一区| 最近免费中文字幕大全免费版视频| 成人午夜激情视频| 色香蕉成人二区免费| 婷婷综合网站| 888av在线| 久久亚洲不卡| 少妇人妻偷人精品一区二区| 精品国产91久久久久久久妲己| 国产精品a久久久久| 国产一区二区99| 欧美一级特黄aaaaaa在线看片| 国产拍揄自揄精品视频麻豆| 久久色在线视频| 国产视频久久久久久| 四虎精品永久免费| 麻豆久久久久久久久久| 国产精品久久免费观看| 久久夜精品香蕉| 久久免费午夜影院| 熟女丰满老熟女熟妇| 亚洲人高潮女人毛茸茸| 精品久久久久久久久久ntr影视| 国产乱码精品一区二区三区精东| 国产成人精品国内自产拍免费看| 成人一区不卡| 久久精品国产成人一区二区三区| 伊人伊人av电影| 国产在线精品一区二区不卡| 成人免费视频播放| 国产免费一区二区视频| 欧美日产在线观看| 国产一区二区三区不卡在线| 尤物视频免费| 久久99久久99| 麻豆视频免费在线播放| 欧美精品激情在线| missav|免费高清av在线看| 欧美三级午夜理伦三级| 精品黑人一区二区三区| 日本国产在线播放| 少妇高潮一区二区三区| 五十路亲子中出中文字幕| 国产手机av在线| 欧美人与性动交α欧美精品| 岳张嘴把我的精子吞下去| 超级碰在线观看| 久久精品亚洲一区二区三区浴池| 欧美性bbb| 亚洲成a天堂v人片| 国产精品久久无码一三区| 一二三区在线观看| 亚洲老妇激情| 韩国三级在线一区| 91精品视频免费| 欧美性xxxxx极品视频| 在线人成日本视频| 一个人免费观看日本www视频| 久久不射2019中文字幕| 免费观看的成年网址| 国产熟女一区二区| 中文字幕精品三区| 六月丁香激情综合| 久久精品一区二区三区中文字幕| 久久久综合av| 久久久久久久久久久久电影| 久久精品久久久久电影| 久热精品在线| 男人午夜视频在线观看| 91在线免费视频观看| 永久免费在线观看视频| 久久嫩草精品久久久精品| 日韩一区二区三区免费播放| 国产精品久久精品日日| 性欧美高清come| 国产福利电影在线播放| 国产精品视频久久一区| 国产精品主播| 成人免费福利| 理论视频在线| 国产精品美女久久久久高潮| 欧洲精品一区| 久久综合网hezyo| wwww在线观看| 中文在线一区二区三区| 久久av资源网站| 高清av电影| 五十路熟女丰满大屁股| 热久久中文字幕| 欧美一级网站| 中文字幕亚洲高清| 免费观看精品视频| 国产va在线播放| 国产午夜精品一区二区三区四区| 亚洲老头同性xxxxx| 日本精品久久| 精品国自产拍在线观看| 鲁片一区二区三区| 青青草免费观看完整版高清| 久久国产高清视频| 一区二区国产在线观看| 黄色高清视频网站| 日韩欧美激情电影| 秋霞精品一区二区三区| 国产一区二区三区奇米久涩| 在线视频不卡一区二区三区| 亚洲免费成人网| 亚洲成人av一区| 欧美中文字幕不卡| 亚洲黄色成人久久久| 性综艺节目av在线播放|