Skip to main content

Canvas 截图 — 使用 JavaScript 将 HTML5 Canvas 导出为图像

要对你的画布进行截图并使用 Konva 将其导出为图像,请使用 toDataURL() 方法;对于 Stage,它需要一个回调函数(对于其他节点则不需要回调)。 你可以传入诸如 image/jpeg 之类的 mime type,以及范围在 0 到 1 之间的质量值。 你还可以捕获特定节点的截图,包括图层、组和形状。

注意:toDataURL() 方法要求绘制到画布上的任何图像都托管在与执行代码相同域的 web 服务器上。如果未满足此条件,将抛出 SECURITY_ERR 异常。

说明: 拖动矩形,然后点击保存按钮以获取复合数据 URL,并在新窗口中打开生成的图像。

import Konva from 'konva';

const stage = new Konva.Stage({
  container: 'container',
  width: 400,
  height: 400
});

const layer = new Konva.Layer();
stage.add(layer);

// 创建可拖动的矩形
const rect = new Konva.Rect({
  x: 100,
  y: 100,
  width: 100,
  height: 100,
  fill: 'red',
  stroke: 'black',
  strokeWidth: 4,
  draggable: true
});

layer.add(rect);

// 添加按钮
const button = document.createElement('button');
button.textContent = '保存为图像';
document.body.appendChild(button);

button.addEventListener('click', () => {
  // 获取默认设置的数据 URL
  const dataURL = stage.toDataURL();
  
  // 在新窗口中打开
  const win = window.open();
  win.document.write(`<img src="${dataURL}" alt="舞台"/>`);
  
  // 你还可以使用不同的设置进行保存
  const jpegURL = stage.toDataURL({
    mimeType: 'image/jpeg',
    quality: 0.8
  });
  console.log('JPEG URL:', jpegURL);
});