求图象尺寸缩小时的优化算法

死亡幻影 2003-05-24 08:09:15
哪位知道请指教,帮忙!
...全文
23 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
azuretttc 2003-05-24
  • 打赏
  • 举报
回复
this program is from somebody else:

这个不仅能放大还能缩小用指针写的速度很快。是一种很简单的插值算法。



=========================================================================
BOOL COXDIB::ChangeDIB(int cx, int cy)
{

int width=GetWidth();
int height=GetHeight();

if((cx==width)&&(cy==height))
return FALSE;

TRACE("width=%d,height=%d\n",width,height);

COXDIB bmp;
bmp.CreateEmptyDIB(24,cx,cy);
for(int k=0;k<cx;k++)
for(int n=0;n<cy;n++)
bmp.SetPixel(k,n,RGB(255,255,255));

int tempcy,tempcx,startcx,startcy;
double sx,sy,smin; //x和y方向的比例系数
sx=double(cx)/(double)width;
sy=double(cy)/(double)height;

smin=(sx>sy)?sy:sx;
tempcy=(int)(smin*height);
tempcx=(int)(smin*width);

startcx=(cx-tempcx)/2;
startcy=(cy-tempcy)/2;
// endcx=(cx+tempcx)/2;
// endcy=(cy+tempcy)/2;

int i,j;

for(i=0;i<tempcx;i++)
{
for(j=0;j<tempcy;j++)
{
double x,y;
x=(double)i/smin;
y=(double)j/smin;

if(x<=0)x=0;
if(x>=width-1)x=width-1;
if(y<=0)y=0;
if(y>=height-1)y=height-1;
if( ((int)x==0)||((int)x==width-1)||((int)y==0)||((int)y==height-1) )
{
COLORREF color1=GetPixel((int)x,(int)y);
bmp.SetPixel(i+startcx,j+startcy,color1);
}
else
{
double r1,r2,r3,r4;
double g1,g2,g3,g4;
double b1,b2,b3,b4;
COLORREF c1,c2,c3,c4;
c1=GetPixel((int)x,(int)y);
c2=GetPixel((int)x+1,(int)y);
c3=GetPixel((int)x,(int)y+1);
c4=GetPixel((int)x+1,(int)y+1);
double dis1=x-(int)x;
double dis2=1-x+(int)x;
double dis3=y-(int)y;
double dis4=1-y+(int)y;
r1=GetRValue(c1);
g1=GetGValue(c1);
b1=GetBValue(c1);
r2=GetRValue(c2);
g2=GetGValue(c2);
b2=GetBValue(c2);
r3=GetRValue(c3);
g3=GetGValue(c3);
b3=GetBValue(c3);
r4=GetRValue(c4);
g4=GetGValue(c4);
b4=GetBValue(c4);

int r=int(dis4*(r1*dis2+r2*dis1)+dis3*(r3*dis2+r4*dis1));
if(r>255)r=255;
int g=int(dis4*(g1*dis2+g2*dis1)+dis3*(g3*dis2+g4*dis1));
if(g>255)g=255;
int b=int(dis4*(b1*dis2+b2*dis1)+dis3*(b3*dis2+b4*dis1));
if(b>255)b=255;

bmp.SetPixel(i+startcx,j+startcy,RGB((BYTE)r,(BYTE)g,(BYTE)b));

// COLORREF color=GetPixel(int(x+0.5),int(y+0.5));
// bmp1.SetPixel(i,j,color);
}
}
}

Empty();
CreateEmptyDIB(24,cx,cy);
// m_pDIB=bmp.GetDIBPtr();
// m_pDIB=bmp.CopyData(GetDIBPtr());
for(int m=0;m<cx;m++)
{
for(int l=0;l<cy;l++)
{
// SetPixel(100,l,RGB(255,255,255));
COLORREF color=bmp.GetPixel(m,l);
SetPixel(m,l,color);
}
// TRACE("PROBLEM %d\n",m);
}
return TRUE;
}

19,469

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC 图形处理/算法
社区管理员
  • 图形处理/算法社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧