当前位置:七道奇文章资讯编程技术VC/C++编程
日期:2011-03-22 13:55:00  来源:本站整理

图片模糊、锐化、雕琢[VC/C++编程]

赞助商链接



  本文“图片模糊、锐化、雕琢[VC/C++编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

void S_Filter(Graphics::TBitmap *Source,Graphics::TBitmap *NewPic,int Div,int xg)//图片效果
{
//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];
          }
   }
  }
}


  以上是“图片模糊、锐化、雕琢[VC/C++编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • 图片模糊、锐化、雕琢
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .