图片模糊、锐化、雕刻
2008-02-23 05:35:55来源:互联网 阅读 ()
{
//0:模糊1:锐化3:雕刻
int flt[9];
switch (xg)
{
case 0:
{
flt[0]=5;flt[1]=5;flt[2]=5;
flt[3]=5;flt[4]=60;flt[5]=5;
flt[6]=5;flt[7]=5;flt[8]=5;
};
break;
case 1:
{
flt[0]=0;flt[1]=-5;flt[2]=0;
flt[3]=-5;flt[4]=30;flt[5]=-5;
flt[6]=0;flt[7]=-5;flt[8]=0;
};
break;
default:
{
flt[0]=-15;flt[1]=-15;flt[2]=0;
flt[3]=-15;flt[4]=15;flt[5]=15;
flt[6]=0;flt[7]=15;flt[8]=0;
};
}
int XX[3];
BYTE *ptr,*ptru,*ptrd,*ptr1;
NewPic->Assign(Source);
for (int y = 1; y < NewPic->Height-1; y )
{
ptr=(BYTE *)NewPic->ScanLine[y];
ptr1=(BYTE *)Source->ScanLine[y];
ptru=(BYTE *)Source->ScanLine[y-1];
ptrd=(BYTE *)Source->ScanLine[y 1];
for(int x=3;x<(Source->Width-1)*3;x =3)
{
XX[0]=0;XX[1]=0;XX[2]=0;
for(int i=-1;i<=1;i )
for(int j=0;j<3;j )
XX[j] =ptr1[x 3*i j]*flt[4 i];
for(int i=-1;i<=1;i )
for(int j=0;j<3;j )
XX[j] =ptru[x 3*i j]*flt[1 i];
for(int i=-1;i<=1;i )
for(int j=0;j<3;j )
XX[j] =ptrd[x 3*i j]*flt[7 i];
for (int i=0;i<3;i )
{
XX[i]=XX[i]/Div;
XX[i]=MAX(XX[i],0);
XX[i]=MIN(XX[i],255);
ptr[x i]=XX[i];
}
}
}
}
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇: BitBlt()双缓冲解决图象闪烁
下一篇: 图片反色的一段程式
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash