canvas繪圖不清晰的解決方案
現(xiàn)象描述
同樣大小的圖片(60x60px)用canvas和DOM繪制,結(jié)果發(fā)現(xiàn)canvas的畫面質(zhì)量要差很多。結(jié)果如下圖所示。

上圖中,左側(cè)紅框中的金幣采用DOM繪制,右側(cè)和下方的金幣和文字等使用canvas繪制,結(jié)果canvas繪制的圖片模糊不清。
原因分析
假設(shè)dpr = 2;圖片大小為60x60px;對(duì)dpr有一定的了解基礎(chǔ)。
1.DOM呈現(xiàn)圖片過(guò)程
圖片——》瀏覽器css像素(顯示尺寸)——》屏幕實(shí)際像素
60x60 30x30 60x60
圖片像素——》實(shí)際像素
1: 1
2.canvas繪制過(guò)程
圖片像素——》canvas像素(畫布尺寸)——》css像素(顯示尺寸)——》屏幕實(shí)際像素
60x60 30x30 30x30 60x60
圖片像素——》畫布像素——》實(shí)際像素
4: 1: 4
也就是說(shuō),canvas的繪制過(guò)程中圖片到畫布的過(guò)程中進(jìn)行了像素的抽稀,畫布到屏幕像素時(shí)又進(jìn)行了插值,所以造成圖片質(zhì)量下降。
解決方案
放大畫布的尺寸,但是canvas顯示尺寸不變;
圖片像素——》canvas像素(畫布尺寸)——》css像素(顯示尺寸)——》屏幕實(shí)際像素
60x60 60x60 30x30 60x60
圖片像素——》實(shí)際像素
1: 1
而canvas的設(shè)計(jì)的時(shí)候正好有對(duì)象的屬性來(lái)分別管理畫布尺寸和顯示尺寸;canvas的width、height屬性用于管理畫布尺寸;canvas的style屬性中的width、height正好是顯示尺寸。
也就是說(shuō)解決方案就是設(shè)置舞臺(tái)的尺寸和圖片像素的尺寸一致,顯示尺寸為正常顯示尺寸;假設(shè)canvas的顯示尺寸為窗口寬度,創(chuàng)建canvas的時(shí)候指定canvas的width屬性為2 * body.clientHeight;style.widht為body.clientHeight + 'px';
改變后的效果圖如下:

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!
相關(guān)文章
js removeChild 障眼法 可能出現(xiàn)的錯(cuò)誤
js removeChild 障眼法之可能出現(xiàn)的錯(cuò)誤,大家看下代碼就知道了。2009-10-10
JavaScript進(jìn)階之前端文件上傳和下載示例詳解
這篇文章主要為大家介紹了JavaScript進(jìn)階之前端文件上傳和下載示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
基于substring()和substr()的使用以及區(qū)別(實(shí)例講解)
下面小編就為大家分享一篇基于substring()和substr()的使用以及區(qū)別實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
使用JS實(shí)現(xiàn)圖片輪播的實(shí)例(前后首尾相接)
下面小編就為大家?guī)?lái)一篇使用JS實(shí)現(xiàn)圖片輪播的實(shí)例(前后首尾相接)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09

