欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

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

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

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

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

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

關于屏幕的一些基礎知識

物理像素(DP)

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

設備獨立像素(DIP)

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

設備像素比(DPR)

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

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

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

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

關于canvas的一些基礎知識

 canvas繪制的是位圖

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

關于位圖的解釋我們放在后面,現在我們只要知道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屏幕下是如何填充的:

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

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

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

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

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

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

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

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

原因總結

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

解決思路

了解了問題出現的原因,解決問題就很容易,解決該問題最重要的一點是讓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);

經驗總結

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

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

標簽:金昌 阿壩 赤峰 萍鄉 聊城 盤錦 綏化 中山

巨人網絡通訊聲明:本文標題《深入了解canvas在移動端繪制模糊的問題解決》,本文關鍵詞  深入,了解,canvas,在,移動,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《深入了解canvas在移動端繪制模糊的問題解決》相關的同類信息!
  • 本頁收集關于深入了解canvas在移動端繪制模糊的問題解決的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    亚洲欧美视频一区| 女同性αv亚洲女同志| 一本加勒比北条麻妃| 欧美日韩成人一区| 一区二区三区在线观看动漫| 成人av网址在线| 国语对白在线播放| 国产精品入口麻豆原神| 成人综合激情网| 中文字幕求饶的少妇| 91国产精品成人| 亚洲色图制服诱惑| 97精品久久久午夜一区二区三区 | 国产欧美日本一区视频| 国产一区二区伦理| 国产三级aaa| 国产精品卡一卡二| 成人爱爱电影网址| 日本韩国一区二区| 一区二区三区国产| 久草视频福利在线| 欧美一区二区三区在线电影| 日本成人在线网站| 亚洲精品国产精品国自产网站| 久久综合久久鬼色| 国产剧情av麻豆香蕉精品| 国产中文av在线| 亚洲女与黑人做爰| 亚洲天堂av网站| 欧美α欧美αv大片| 国内国产精品久久| 极品盗摄国产盗摄合集| 一区二区三区在线免费视频| 大尺度做爰床戏呻吟舒畅| 日韩精品在线网站| 国产精品99久久不卡二区| 色综合视频一区二区三区高清| 亚洲精品精品亚洲| 波多野结衣先锋影音| 久久综合九色综合97_久久久| 国产精品一区二区在线播放| 国产波霸爆乳一区二区| 亚洲国产一区视频| 久久久久久久久久久久久久久| 日本一区二区三区国色天香 | 黄色一级片中国| 亚洲制服丝袜在线| 欧美特黄一区二区三区| 欧美极品少妇xxxxⅹ高跟鞋 | 欧美国产一区视频在线观看| www.欧美色图| 日韩一区二区在线免费观看| 国产精品99久| 欧美日本在线观看| 国产真实乱子伦精品视频| 色综合久久天天| 日韩av一区二区三区四区| 亚洲 欧美 国产 另类| 亚洲免费观看高清在线观看| free性中国hd国语露脸| 国产精品久久久久一区二区三区共| 韩国三级丰满少妇高潮| 精品国产一区二区三区忘忧草| 成人午夜av电影| 91精品国产乱| 高清视频一区二区| 欧美一区二区三区免费在线看| 国产精品18久久久久久久网站| 欧美日韩精品欧美日韩精品一| 国内久久婷婷综合| 欧美日韩精品欧美日韩精品一| 国产伦精品一区二区三区免费| 欧美性大战久久| 国产一区二区三区免费| 欧美乱妇一区二区三区不卡视频| 国产一区二区h| 88在线观看91蜜桃国自产| 国产精品一区久久久久| 日韩情涩欧美日韩视频| aaa国产一区| 久久这里都是精品| 日本wwwwwww| 国产精品成人免费在线| 成人乱码一区二区三区av| 亚洲一区二区三区视频在线播放| 亚洲女人毛茸茸高潮| 视频一区在线视频| 91黄色免费观看| 国产精品一区二区你懂的| 欧美一级黄色片| 91丨九色丨黑人外教| 国产欧美日韩在线| 欧美老熟妇乱大交xxxxx| 亚洲成人av福利| 色素色在线综合| 国产精品99久久久久久久女警| 日韩精品中文字幕一区二区三区| 麻豆短视频在线观看| 自拍偷在线精品自拍偷无码专区 | 日欧美一区二区| 欧美在线看片a免费观看| 国产98色在线|日韩| www久久久久| 国产亚洲无码精品| 亚洲成av人片在线观看| 在线观看日韩国产| 粉嫩aⅴ一区二区三区四区| 久久免费看少妇高潮| 特大黑人巨人吊xxxx| 亚洲一区二区三区激情| 91福利精品视频| 成人sese在线| 国产精品毛片高清在线完整版| 91资源在线播放| 久久精品国产一区二区三区免费看| 欧美精品自拍偷拍| 国产无套精品一区二区三区| 亚洲美女偷拍久久| 在线精品视频免费观看| av不卡免费电影| 69堂成人精品免费视频| 无码国产精品久久一区免费| 一区二区久久久久久| 在线看国产一区二区| 91麻豆福利精品推荐| 亚洲欧美电影一区二区| 色丁香久综合在线久综合在线观看| 成人午夜激情影院| 亚洲欧美日韩小说| 在线观看不卡视频| 成人免费播放视频| 亚洲一级二级三级在线免费观看| 欧美午夜精品理论片a级按摩| 99国产精品国产精品毛片| 亚洲免费观看在线视频| 欧美日韩亚洲综合在线| 国模无码视频一区| 日本伊人色综合网| www激情久久| 国产jizz18女人高潮| 国产69精品一区二区亚洲孕妇| 亚洲国产成人午夜在线一区| 国产一二三区精品| 国产成人av影院| ●精品国产综合乱码久久久久| 色狠狠色噜噜噜综合网| 国产sm在线观看| 视频一区视频二区在线观看| 日韩欧美中文字幕公布| 一级黄色片网址| 丰满亚洲少妇av| 亚洲精品成a人| 制服丝袜成人动漫| 午夜精产品一区二区在线观看的| 国产精品一区二区你懂的| 中文字幕日本乱码精品影院| 欧洲精品视频在线观看| 在线播放av网址| 麻豆精品一区二区av白丝在线| 国产午夜亚洲精品不卡| 色综合中文字幕国产| 男生和女生一起差差差视频| 日韩成人免费电影| 欧美激情一区二区三区| 色噜噜狠狠一区二区三区果冻| av av在线| 国产在线国偷精品产拍免费yy| 国产欧美日韩视频一区二区| 欧洲激情一区二区| 女~淫辱の触手3d动漫| 成人三级伦理片| 午夜精品久久久久久久99水蜜桃| 欧美精品一区二区精品网| 成人性生活毛片| 制服丝袜在线第一页| 国产一区二区三区蝌蚪| 亚洲六月丁香色婷婷综合久久| 欧美一区二区大片| 久久久久久久久久97| 91超薄肉色丝袜交足高跟凉鞋| 蜜乳av一区二区| 亚洲视频综合在线| 日韩欧美黄色影院| 疯狂试爱三2浴室激情视频| 9.1在线观看免费| 国产精品一级在线| 亚洲成人在线免费| 欧美国产日韩精品免费观看| 欧美剧情片在线观看| 91香蕉国产视频| 欧洲熟妇的性久久久久久| 国产一区二区久久| 天涯成人国产亚洲精品一区av| 国产欧美精品一区aⅴ影院| 欧美日韩一卡二卡三卡| 永久免费观看片现看| 美女网站视频在线观看| 丁香亚洲综合激情啪啪综合| 日本伊人色综合网| 亚洲一区二区视频|