中文字幕第五页-中文字幕第页-中文字幕韩国-中文字幕最新-国产尤物二区三区在线观看-国产尤物福利视频一区二区

高分屏下canvas模糊問題的示例分析-創新互聯

這篇文章將為大家詳細講解有關高分屏下canvas模糊問題的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

專注于為中小企業提供做網站、成都做網站服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業姚安免費做網站提供優質的服務。我們立足成都,凝聚了一批互聯網行業人才,有力地推動了成百上千家企業的穩健成長,幫助中小企業通過網站建設實現規模擴充和轉變。

前言

最近在做項目的時候發現,在公司電腦上沒問題,在自己電腦上確有問題。做的是canvas的項目,在自己電腦上運行的時候,發現,會出現點擊選不中的問題還有,canvas刷新會有殘影問題。首先可以確定,這兩個問題都是canvas元素邊界有問題,但是從代碼上來看是沒問題的,因此我就猜測是否和屏幕有關,畢竟canvas某些問題確實和屏幕有關甚至和硬件顯卡有關。

devicePixelRatio屬性


果然找出一個屬性不同: devicePixelRatio;
然后仔細研究了下這個屬性的含義,mdn上解釋如下:

此屬性返回當前顯示設備的物理像素分辨率與CSS像素分辨率的比值。該值也可以被解釋為像素大小的比例:即一個CSS像素的大小相對于一個物理像素的大小的比值。

公司的臺式機的devicePixelRatio為1,而我自己的電腦為1.25;因為我的電腦是高清屏的,那么什么是高清屏呢?
高清顯示屏原理如下:

  1. 一種具備超高像素密度的液晶屏

  2. 同樣大小的屏幕上顯示的像素點由1個變為多個

那么我們就能知道,高清屏上一個像素點變成devicePixelRatio個像素點,因此canvas畫布也會收到影響,同樣的圖片,在高清屏上會變大,但是canvas實際尺寸沒有變大,因為圖片會縮放,導致模糊。

canvas寬高與css寬高

那么如何解決canvas高分屏問題呢?既然高分屏下canvas的像素點會變多,導致畫布縮放,那么我們能不能通過某種方法把canvas縮放回去呢?答案是可以的。
我們首先認識一下canvas的像素,我們先繪制一段文字

<canvas id="canvas1" width="300" height="150"></canvas>
....


ctx1.beginPath();
ctx1.font = '20px arial';
ctx1.fillText('Html5 canvas', 50, 50);

這樣我們就得到如下:

高分屏下canvas模糊問題的示例分析

我們在創建一個畫布,這次我們通過css設置畫布的寬高:

<canvas id="canvas2" style="width: 200px; height: 200px"></canvas>
.....



ctx2.beginPath();
ctx2.font = '20px arial';
ctx2.fillText('Html5 canvas', 50, 50);

這次我們得到如下效果:

高分屏下canvas模糊問題的示例分析

我們可以很明顯看到畫布上的文字有明顯的縮放,這是為什么呢?我們可以這么理解: canvas是繪制圖片的,我們使用canvas繪制完圖片后,首先生成一張根據canvas的寬高的圖片,然后通過dom樹由css渲染出來,因此canvas的寬高是圖片的實際寬高,css的寬高是實際渲染出來的尺寸。那么我們回過頭來理解devicePixelRatio,這個屬性返回的是設備的物理像素分辨率與CSS像素分辨率的比值,我們的canvas繪制出來后圖片因為高清屏設備的影響,導致圖片變大,然而我們在瀏覽器的渲染窗口并沒有變大,因此圖片會擠壓縮放使得canvas畫布會變得模糊,盡然高分屏的像素點變多了,導致圖片變大,那么我們可以通過設置canvas的寬高設置devicePixelRatio倍的畫布大小,然后設置canvas縮放比例為devicePixelRatio倍,保持和canvas等比例放大,然后這樣我們相當于在繪制圖片的時候就縮放圖片變大,然后通過css渲染又會縮放回去,這樣canvas的大小就不會失真了。代碼如下:

function makeHighRes(canvas) {
    var ctx = canvas.getContext('2d');
    // Get the device pixel ratio, falling back to 1.               
    var dpr = window.devicePixelRatio || window.webkitDevicePixelRatio || window.mozDevicePixelRatio || 1;

    // Get the size of the canvas in CSS pixels.
    var oldWidth = canvas.width;
    var oldHeight = canvas.height;
    // Give the canvas pixel dimensions of their CSS
    // size * the device pixel ratio.
    canvas.width = Math.round(oldWidth * dpr);
    canvas.height = Math.round(oldHeight * dpr);
    canvas.style.width = oldWidth + 'px';
    canvas.style.height = oldHeight + 'px';
    // Scale all drawing operations by the dpr, so you
    // don't have to worry about the difference.
    ctx.scale(dpr, dpr);
    return ctx;
}

另外:網上有一些解決辦法比較古老,使用了backingStoreRatio 這個屬性,這個屬性已經廢棄!
此外我們也可以使用這個庫 hidpi-canvas-polyfill,他也是使用的我們這個方法來改變canvas繪制視圖的,不過庫中還把所有canvas繪制api都縮放了相應的devicePixelRatio倍,考慮很完善。

關于“高分屏下canvas模糊問題的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

標題名稱:高分屏下canvas模糊問題的示例分析-創新互聯
轉載源于:http://m.2m8n56k.cn/article2/dipoic.html

成都網站建設公司_創新互聯,為您提供ChatGPT、網站導航、云服務器外貿建站搜索引擎優化、外貿網站建設

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

商城網站建設
主站蜘蛛池模板: 自拍自录videosfree自拍自录 | 国产成人免费福利网站 | 国产午夜精品理论片免费观看 | 最新久久免费视频 | 亚色成人| 久久精品国产一区二区三区日韩 | 国产在线观看免费人成小说 | 一级待一黄aaa大片在线还看 | 一级做a爰片性色毛片中国 一级做a爰性色毛片 | 中国一级做a爱片免费 | 日韩欧美一区二区三区免费观看 | 欧美亚洲欧美区 | 欧美一级片播放 | 亚洲综合色一区二区三区小说 | 免费一级视频在线播放 | 国产v片在线播放免费观 | 日韩精品中文字幕视频一区 | 亚洲品质自拍网站 | 国产成人国产在线观看入口 | 国产农村一二三区 | 中文国产成人精品久久96 | 日本特黄特色免费大片 | xxxww在线播放 | 寡妇野外啪啪一区二区 | 在线视频观看一区 | 国产短裙黑色丝袜在线观看下 | 91精品国产色综合久久不 | 中文在线三级中文字幕 | 黄影院 | 91免费看视频 | 久草视频中文 | 亚洲欧美日本国产综合在线 | 午夜国产精品不卡在线观看 | 91热视频在线观看 | 成年人毛片| 欧美日韩视频在线第一区二区三区 | 欧美一区二区aa大片 | 美女视频大全网站免费 | 国产欧美一区二区另类精品 | 亚洲欧美在线综合一区二区三区 | 欧美中文字幕一区二区三区 |