Node-Canvas图像抗锯齿似乎不起作用

iMo*_*ses 3 javascript canvas antialiasing cairo node.js

我正在尝试使用node.js和node-canvas包生成动画文件,逐帧提取.动画的一部分包括缩放和移动图像.我的问题是,似乎没有发生反锯齿,尽管根据node-canvas和cario(画布背后的图形库),默认情况下应该进行抗锯齿处理.此外,根据node-canvas,可以使用此系统控制抗锯齿ctx.antialias = 'gray';,但它似乎也没有做任何事情.如果有任何更多细节,我可以提供,可能会有所帮助,请告诉我.有没有办法,直接使用node-canvas甚至cairo为图像转换添加抗锯齿?

PS我正在使用ctx.drawImage方法绘制图像,我已经尝试过使用但patternQuality = 'best';没有成功.

小智 6

升频模式,开罗默认使用双线性插值,这应该是合理的.但是,当降尺度时,cairo目前(截至1.12.14)没有正确的抗锯齿模式.没有办法得到这个,没有实际将功能添加到cairo本身,但请参阅下面的潜在解决方法.

cairo中的"antialias"设置控制光栅化形状和文本的抗锯齿,而不是模式.控制模式抗锯齿的设置称为"cairo_pattern_set_filter",并具有以下值:

CAIRO_FILTER_FAST,             // usually the same as NEAREST
CAIRO_FILTER_GOOD,             // usually the same as BILINEAR
CAIRO_FILTER_BEST,             // usually the same as BILINEAR
CAIRO_FILTER_NEAREST,          // for upscaling, this is pixel-replication
CAIRO_FILTER_BILINEAR,         // for upscaling, this is linear interpolation
CAIRO_FILTER_GAUSSIAN          // not implemented, should not be used
Run Code Online (Sandbox Code Playgroud)

但如前所述,它们都不适合降尺度.

某些人使用的解决方法是以2为单位缩小图像.也就是说,将图像缩小到两个尺寸的一半,直到它大致达到所需的大小.然后,这个缩小的图像可以与修改后的变换一起使用,该变换缩小小于2.