麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > HTML5 > 正文

高清屏下canvas重置尺寸引發的問題的解決

2024-09-05 07:23:04
字體:
來源:轉載
供稿:網友

我們知道,清空canvas畫布內容有以下兩個方法。

第一種方法是cearRect函數:

context.cearRect(0,0,canvas.width,canvas.height)

第二種方法就是用原值重新設置一下canvas的寬(或者高)

canvas.width = canvas.width// or canvas.height = canvas.height

第二種方法可以起作用,是因為canvas的一個特點:

每當畫布的高度或寬度被重設時,畫布內容就會被清空。相關內容可以參考 https://www.w3school.com.cn/html5/att_canvas_width.asp

在一個可視化項目中,我們發現在一些電腦上面總是會出現效果錯亂的情況。

經過調試,我們發現,原來是“canvas.width = canvas.width”惹的禍。普通屏幕下面下不會有問題,但是如果屏幕是高清屏,就會出現問題。這是因為,高清屏下,我們為了處理繪制圖形模糊的問題,通常會做如下處理:

function setupCanvas(canvas) {        let width = canvas.width,          height = canvas.height,          dpr = window.devicePixelRatio || 1.0;        if (dpr != 1.0 ) {          canvas.style.width = width + "px";          canvas.style.height = height + "px";          canvas.height = height * dpr;          canvas.width = width * dpr;          ctx.scale(dpr, dpr);        }      }

我們知道,高清屏下window.devicePixelRatio都大于1。所以在繪圖之前畫筆會被縮放:

ctx.scale(dpr, dpr);

我們知道cavnas是基于狀態的繪圖組件。 其中縮放比例值也在狀態管理之中。 當我們重新設置canvas的寬(高也一樣)的時候,不僅會清空canvas的畫布內容,同時還會把繪圖狀態重置到最原始的狀態,原始狀態下畫筆的縮放比例是1,縮放比例值會被重置為1,因而導致繪制效果錯亂。
 

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久久涩 | 香蕉成人在线视频 | 97中文字幕第一一一页 | 99激情| 亚洲国产小视频 | 一级黄色在线观看 | 亚洲精品成人18久久久久 | 性高潮一级片 | 亚洲欧美不卡视频 | 欧美色视| 黄色高清av| 日本黄色a视频 | 九九热免费在线观看 | 久久精品日韩一区 | 人成免费网站 | 国产手机av在线 | 天堂成人一区二区三区 | 久久国产免费视频 | 欧美三级欧美成人高清www | av在线免费观看中文字幕 | av电影在线免费观看 | 超碰97国产在线 | 亚洲国产综合在线观看 | 毛片视频在线免费观看 | 欧美视频一区二区三区 | 九九热在线视频观看这里只有精品 | 久久综合艹 | 午夜国产福利 | 中文字幕网址 | 天天草夜夜骑 | 久久激情免费视频 | 国产精品美女久久久久久不卡 | 亚洲午夜在线视频 | 中文字幕在线观看国产 | 嗯哈~不行好大h双性 | 九九福利视频 | 性欧美在线视频 | 一区二区久久 | 91成人免费看片 | 国产精品免费看 | 亚洲成人激情在线 |