首页 技术 正文
技术 2022年11月15日
0 收藏 854 点赞 3,260 浏览 1872 个字

Wu反走样算法###

原理:在我看来,Wu反走样算法是在Bresenham算法基础上改进了一番,它给最靠近理想直线/曲线的两个点以不同的亮度值,以达到模糊锯齿的效果。因为人眼看到的是线附近亮度的平均值。

MFC 中给CXXXView类添加函数
void CMy3_4View::wuLine(CPoint p0, CPoint p1)
{
//自定义二维坐标系
CDC *pDC = GetDC();
CRect rect;
GetClientRect(&rect);
pDC->SetMapMode(MM_ANISOTROPIC);
pDC->SetWindowExt(rect.Width(), rect.Height());
pDC->SetViewportExt(rect.Width(), -rect.Height());
pDC->SetViewportOrg(rect.Width()/2, rect.Height()/2);
rect.OffsetRect(-rect.Width()/2, -rect.Height()/2);
//-----------------------------------------------------------CPoint p, temp;
int dx=p1.x-p0.x;
int dy=p1.y-p0.y;
double k=(dy*1.00)/(dx*1.00);//计算斜率if(dx==0)//垂线
{
if(dy<0)//起点在上方,调换
{
temp=p0;
p0=p1;
p1=temp;
}
for(p=p0; p.y<p1.y; p.y++)//主移动方向->y,不包括p1
{
pDC->SetPixelV(p.x, p.y, RGB(0,0,0));
}
}else
{
double e=0.00;//增量if(k>=0 && k<=1)
{
if(dx<0)//p1在左侧,调换
{
temp=p0;
p0=p1;
p1=temp;
}//p0在左下for(p=p0; p.x<p1.x; p.x++)//主移动方向->x,不包括p1
{
pDC->SetPixelV(p.x, p.y, RGB(e*255, e*255, e*255));
pDC->SetPixelV(p.x, p.y+1, RGB((1-e)*255, (1-e)*255, (1-e)*255));//不同亮度值
e+=k;if(e>=1.0)
{
p.y++;
e-=1;
}
}
/*p0.x+=10;
p1.x+=10;
pDC->MoveTo(p0);
pDC->LineTo(p1);*/
}
else if(k>1)
{
if(dy<0)//p1在左侧,调换
{
temp=p0;
p0=p1;
p1=temp;
}//p0在下方for(p=p0; p.y<p1.y; p.y++)//主移动方向->y,不包括p1
{
pDC->SetPixelV(p.x, p.y, RGB(e*255, e*255, e*255));
pDC->SetPixelV(p.x+1, p.y, RGB((1-e)*255, (1-e)*255, (1-e)*255));
e+=1.00/(k*1.00);if(e>=1.0)
{
p.x++;
e-=1;
}
}
}else if(k>=-1 && k<0)
{
e=0.00;
if(dx<0)//p1在左上,调换
{
temp=p0;
p0=p1;
p1=temp;
}//p0在左上for(p=p0; p.x<p1.x; p.x++)//主移动方向->x,不包括p1
{
pDC->SetPixelV(p.x, p.y, RGB(-1*e*255, -1*e*255, -1*e*255));
pDC->SetPixelV(p.x, p.y-1, RGB((1+e)*255, (1+e)*255, (1+e)*255));//这里e是负数!!!
e+=k;if(e<=-1.0)
{
p.y--;
e+=1.0;
}
}
}else if(k<-1)
{
if(dy>0)//p1在上方,调换
{
temp=p0;
p0=p1;
p1=temp;
}//p0在上
for(p=p0; p.y>p1.y; p.y--)//主移动方向->y,不包括p1
{
pDC->SetPixelV(p.x, p.y, RGB(e*255, e*255, e*255));
pDC->SetPixelV(p.x+1, p.y, RGB((1-e)*255, (1-e)*255, (1-e)*255));
e+=-1.0/(k*1.0);if(e>=1.0)
{
p.x++;
e-=1;
}
}
}}
pDC->DeleteDC();
}
VC++ 6.0编译通过!如有错误,或编译不通过,请留言。
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,955
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,479
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,291
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,108
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,740
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,774