PaperJS 用颜色填充光栅而不遍历像素
PaperJS fill a raster with a color without iiterating over the pixels
在 PaperJS 中,是否可以在不遍历每个像素的情况下用颜色填充光栅?
假设您有一个具有一定透明度的 PNG,没有透明度的像素将具有不同的颜色。
据我所知,您可以遍历每个像素 http://paperjs.org/tutorials/images/using-pixel-colors/ 并手动执行(为每个图像像素创建一个备用像素),但理想情况下,有一种解决方案不需要逐个像素地执行此操作。
最好将光栅用作剪切蒙版以显示其下方的颜色,但我认为这仅适用于路径。
感谢任何帮助
另一种方法是巧妙地使用混合模式。
原则是使用光栅作为位于其上的形状的 alpha 源。
我现在没有太多时间来详细说明,但这里有一个 sketch 应该可以让您步入正轨。
const url = '';
const raster = new paper.Raster(url);
raster.blendMode = 'destination-in';
raster.onLoad = () => {
const rectangle = new Path.Rectangle({
rectangle: raster.bounds,
fillColor: 'orange'
});
new Group([rectangle, raster]);
project.activeLayer.fitBounds(view.bounds.scale(0.8));
};
下一个挑战是确定此效果的范围,以便混合不会影响场景的其他形状。关于这个主题,我在 Paper.js 仓库中发布了一些高级示例,你应该可以找到它们。
在 PaperJS 中,是否可以在不遍历每个像素的情况下用颜色填充光栅?
假设您有一个具有一定透明度的 PNG,没有透明度的像素将具有不同的颜色。
据我所知,您可以遍历每个像素 http://paperjs.org/tutorials/images/using-pixel-colors/ 并手动执行(为每个图像像素创建一个备用像素),但理想情况下,有一种解决方案不需要逐个像素地执行此操作。
最好将光栅用作剪切蒙版以显示其下方的颜色,但我认为这仅适用于路径。
感谢任何帮助
另一种方法是巧妙地使用混合模式。
原则是使用光栅作为位于其上的形状的 alpha 源。
我现在没有太多时间来详细说明,但这里有一个 sketch 应该可以让您步入正轨。
const url = '';
const raster = new paper.Raster(url);
raster.blendMode = 'destination-in';
raster.onLoad = () => {
const rectangle = new Path.Rectangle({
rectangle: raster.bounds,
fillColor: 'orange'
});
new Group([rectangle, raster]);
project.activeLayer.fitBounds(view.bounds.scale(0.8));
};
下一个挑战是确定此效果的范围,以便混合不会影响场景的其他形状。关于这个主题,我在 Paper.js 仓库中发布了一些高级示例,你应该可以找到它们。