【发布时间】:2018-09-04 13:31:26
【问题描述】:
我有一个画布,可以使用 fabric.js 绘制一些形状。然后我填充这些形状,并使用 context.drawImage() 在另一个画布上绘制它们,然后使用 canvas.toDataURL() 导出到 png。
我已经为我绘制的画布和我导出为 png 的画布关闭了 enableRetinaScaling 和 imageSmoothingEnabled。
我生成的 png 在形状边缘有不同颜色的像素,并且似乎是抗锯齿或模糊的。有没有办法禁用它并使每个像素的边框颜色相同?我知道这会导致边缘不太光滑,这很好。
const canvas = document.getElementById('canvas');
let ctx = canvas.getContext('2d');
ctx.imageSmoothingEnabled = false;
const drawingCanvas = new fabric.Canvas(canvas, {
width: 150,
height: 150,
backgroundColor: 'transparent',
selection: false,
enableRetinaScaling: false,
imageSmoothingEnabled: false,
});
let polygon = new fabric.Polygon([
{ x: 50, y: 100 },
{ x: 70, y: 10 },
{ x: 90, y: 100 },
], {
stroke: 'green',
fill: 'green',
selectable: false,
perPixelTargetFind: true,
hoverCursor: 'cursor'
});
drawingCanvas.add(polygon);
drawingCanvas.renderAll();
link = document.getElementById('download');
link.setAttribute("href", canvas.toDataURL());
link.setAttribute("download", "example.png");
<body>
<a id="download"><button>Download</button></a>
<canvas id="canvas" style="border: solid red 1px" />
</body>
<script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/2.3.5/fabric.js"></script>
【问题讨论】:
-
您在 toDataURL 中使用
encoderOptions吗? developer.mozilla.org/en-US/docs/Web/API/HTMLCanvasElement/… -
如果你能用一个简单的形状创建一个最小的代码 sn-p 来显示你的问题,那就太好了
-
@HelderSepu - 对于默认的 png,编码器选项似乎什么都不做。它只是说它会影响替代格式。
-
这是一个密码笔。如果您同时下载了小png和大png,当您放大形状时,您可以看到像素色差。我希望所有像素都是相同的绿色阴影,或者是透明的。 codepen.io/carter485/pen/ajroNO?editors=1011
-
@VictorStoddard - 试过这个,仍然可以看到形状边缘周围的像素颜色差异。试试codepen,看看你能不能让所有的像素都变成相同的阴影。
标签: javascript canvas fabricjs