在非透明图像周围修剪-10px

问题描述 投票:0回答:1

有没有一种方法可以精确修剪 HTML5 Canvas 中不透明图像的边缘?

示例:

输入:

输出:

javascript canvas html5-canvas
1个回答
0
投票

我在下面添加示例代码

const loadImageFromBase64 = async() => {
  const base64Data = ``;
  //this is base64 code of your origin image with black border.
  const img = await loadImage(base64Data);
  drawImageToCanvas(img);
};

const loadImage = (src) => {
  return new Promise((resolve, reject) => {
    const img = new Image();
    img.onload = () => resolve(img);
    img.onerror = reject;
    img.src = src;
  });
};

const canvas = document.getElementById("myCanvas");
const ctx = canvas.getContext("2d");

const drawImageToCanvas = (img) => {
  ctx.drawImage(img, 0, 0, canvas.width, canvas.height);
};

const convertImage = () => {
  const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height);
  const data = imageData.data;

  for (let i = 0; i < data.length; i += 4) {
    if (data[i] === 0 && data[i + 1] === 0 && data[i + 2] === 0) {
      data[i] = data[i + 1] = data[i + 2] = 255;
    }
  }

  ctx.putImageData(imageData, 0, 0);
};

window.onload = loadImageFromBase64;
<canvas id="myCanvas" width="500" height="500" style="border: 1px solid #000"></canvas>
<button onclick="convertImage()">convert</button>

© www.soinside.com 2019 - 2024. All rights reserved.