使用 canvas 畫圖時圖像文字模糊的解決辦法


最近在使用 canvas 畫圖的時候,遇到了圖像文字模糊的問題,解決思路就是根據分辨率創建不同尺寸的畫布。以下是創建高分辨率畫布的代碼:

/**
 * 創建高分辨率畫布
 * @param w     畫布寬
 * @param h     畫布高
 * @param ratio 屏幕分辨率
 */
function createHiDPICanvas(w, h, ratio?) {

  const PIXEL_RATIO = (function () {
    const c = <HTMLCanvasElement>document.createElement("canvas"),
      ctx = c.getContext("2d"),
      dpr = window.devicePixelRatio || 1,
      bsr = ctx['webkitBackingStorePixelRatio'] ||
        ctx['mozBackingStorePixelRatio'] ||
        ctx['msBackingStorePixelRatio'] ||
        ctx['oBackingStorePixelRatio'] ||
        ctx['backingStorePixelRatio'] || 1;

    return dpr / bsr;
  })();

  if (!ratio) { ratio = PIXEL_RATIO; }
  const can = document.createElement("canvas");
  can.width = w * ratio;
  can.height = h * ratio;
  can.style.width = w + "px";
  can.style.height = h + "px";
  can.getContext("2d").setTransform(ratio, 0, 0, ratio, 0, 0);
  return can;
}

// 不創建高分辨率畫布
const canvas = document.createElement("canvas");
canvas.width = 100;
canvas.height = 100;

// 創建使用默認分辨率的畫布
const myCanvas = this.createHiDPICanvas(100, 100);

// 創建分辨率為 3 的畫布
const myCustomCanvas = this.createHiDPICanvas(100, 100, 3);

最后,貼一個高分辨率畫布的開源庫
https://github.com/jondavidjohn/hidpi-canvas-polyfill


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM