社区
图形处理/算法
帖子详情
求图象尺寸缩小时的优化算法
死亡幻影
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;
}
如何优化VB程序
如何去优化你的VB程序帮助 1、如何去优化你的VB程序Visual Basic 作为一种高级编程语言,它也有着不可避免的缺点---开发出的应用程序运行速度慢。如果我们能够程序做一些优化,那么情况将会大大改善。要优化程序...
【三年面试五年模拟】算法工程师的独孤九剑秘籍(前十二式汇总篇)V1版
四万字算法工程师高价值面试知识点,全网最全,你值得拥有
VC图像编程
图象
拼接是在全景视频系统、地理信息系统等应用中经常遇到的一个问题,本文基于网格匹配的方法对边界部分有重叠的
图象
提出了一种行之有效的对准算法,并通过平滑因子对
图象
实现了无缝拼接。并应用文档视窗模型实现...
VC多媒体编程
图象
拼接是在全景视频系统、地理信息系统等应用中经常遇到的一个问题,本文基于网格匹配的方法对边界部分有重叠的
图象
提出了一种行之有效的对准算法,并通过平滑因子对
图象
实现了无缝拼接。并应用文档视窗模型实现...
MATLAB算法实战应用案例精讲-【图像处理】机器视觉(基础篇)(六)
机器视觉是通过光学装置和传感器,自动地接收...(2)觉:即视觉处理软件及算法。在一个典型的机器视觉系统中,光源及光源控制器、镜头、相机等硬件部分负责成像,视觉控制系统负责对结果进行处理分析、输出分析结果。
图形处理/算法
19,469
社区成员
50,697
社区内容
发帖
与我相关
我的任务
图形处理/算法
VC/MFC 图形处理/算法
复制链接
扫一扫
分享
社区描述
VC/MFC 图形处理/算法
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章