c语言编程 消除直线锯齿,C语言 抗锯齿像素渲染

我正在尝试实现抗锯齿像素渲染.我的基本想法是渲染4个像素而不是1个像素,并根据其与“虚拟”像素的距离为每个“真实”像素赋予权重:

void put_aa_pixel(double x, double y)

{

int x0 = int(x);

int x1 = x0 + 1;

int y0 = int(y);

int y1 = y0 + 1;

double weight_x1 = x - x0;

double weight_x0 = 1 - weight_x1;

double weight_y1 = y - y0;

double weight_y0 = 1 - weight_x1;

put_pixel(x0, y0, int((weight_x0 * weight_y0) * 255));

put_pixel(x1, y0, int((weight_x1 * weight_y0) * 255));

put_pixel(x0, y1, int((weight_x0 * weight_y1) * 255));

put_pixel(x1, y1, int((weight_x1 * weight_y1) * 255));

}

乘以x和y权重给出了每个真实像素内的虚拟像素的重叠区域.我天真地认为这会给我一个完美的抗锯齿效果,但我测试程序中的移动像素只显示一个令人难以置信的闪烁.它看起来比没有任何抗锯齿的简单像素更糟糕.

但是,当我从乘法切换到加法时,它看起来好多了:

put_pixel(x0, y0, int((weight_x0 + weight_y0) * 127.5));

put_pixel(x1, y0, int((weight_x1 + weight_y0) * 127.5));

put_pixel(x0, y1, int((weight_x0 + weight_y1) * 127.5));

put_pixel(x1, y1, int((weight_x1 + weight_y1) * 127.5));

添加权重似乎没有任何几何意义.那为什么这会更好呢?第一个版本出了什么问题?还有更好的方法吗?

按照要求 :)

直观地说:你的x和y权重表示从虚拟到真实像素的轴的距离.所以,实际距离是sqrt(w_x ^ 2 w_y ^ 2).解释为什么总和更好 – 它更接近这种形式而不是乘法.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值