主頁 > 知識庫 > 高清屏下canvas重置尺寸引發(fā)的問題的解決

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

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

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

第一種方法是cearRect函數(shù):

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

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

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

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

每當畫布的高度或?qū)挾缺恢卦O(shè)時,畫布內(nèi)容就會被清空。相關(guān)內(nèi)容可以參考 https://www.w3school.com.cn/html5/att_canvas_width.asp

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

經(jīng)過調(diào)試,我們發(fā)現(xiàn),原來是“canvas.width = canvas.width”惹的禍。普通屏幕下面下不會有問題,但是如果屏幕是高清屏,就會出現(xiàn)問題。這是因為,高清屏下,我們?yōu)榱颂幚砝L制圖形模糊的問題,通常會做如下處理:

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

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

標簽:盤錦 金昌 阿壩 中山 赤峰 聊城 萍鄉(xiāng) 綏化

巨人網(wǎng)絡(luò)通訊聲明:本文標題《高清屏下canvas重置尺寸引發(fā)的問題的解決》,本文關(guān)鍵詞  高清,屏下,canvas,重置,尺寸,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《高清屏下canvas重置尺寸引發(fā)的問題的解決》相關(guān)的同類信息!
  • 本頁收集關(guān)于高清屏下canvas重置尺寸引發(fā)的問題的解決的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章