图形显示特技算法

王朝vc·作者佚名  2006-01-17
窄屏简体版  字體: |||超大  

图形显示特技算法

作者 浙江大学 王向伟

下载源代码

水平百叶窗:将图象分成若干等份,每次扫描各等份的1象素宽后Sleep一段时间,再扫描下一象素,直到每份的象素都扫描完。

雨滴效果:读入位图的最后一行象素,从屏幕的最上端开始移动到象素的实际位置;接着读入倒数第一行象素,依次类推。

具体步骤如下:

1.在工程中加入变量:

CDC memdc;

CBitmap m_bitmap;

2.在资源中加入位图资源,ID为IDB_BITMAP1;

3.在构造函数中加入初始化代码:

m_bitmap.LoadBitmap(IDB_BITMAP1);

4.在OnDraw(CDC* pDC)中加入如下代码:

void CMyView::OnDraw(CDC* pDC)

{

CMyDoc* pDoc = GetDocument();

ASSERT_VALID(pDoc);

int width; // 位图的宽度

int height; //位图的高度

if(!memdc.GetSafeHdc())

{

memdc.CreateCompatibleDC(pDC);

memdc.SelectObject(&m_bitmap);

}

//获取位图大小信息

BITMAP bm;

m_bitmap.GetBitmap(&bm);

width=bm.bmWidth;

height=bm.bmHeight;

if(next==2)//水平向左扫描

{

for(int i=0;i<width;i++)

{

pDC->BitBlt(i,0,1,height,&memdc,i,0,SRCCOPY);

Sleep(1);

}

}

else if(next==1)//水平向右扫描

{

for(int i=width-1;i>=0;i--)

{

pDC->BitBlt(i,0,1,height,&memdc,i,0,SRCCOPY);

Sleep(1);

}

}

else if(next==3)//水平百叶窗

{

//每条20象素宽

int num=width/20;

for(int i=0;i<20;i++)

{

//分别扫描每条

for(int j=0;j<num;j++)

{

pDC->BitBlt(j*20+i,0,1,height,&memdc,j*20+i,0,SRCCOPY);

}

Sleep(10);

}

}

else if(next==4)//垂直百叶窗

{

int num=height/20;

for(int i=0;i<20;i++)

{

//分别扫描每条

for(int j=0;j<num;j++)

{

pDC->BitBlt(0,j*20+i,width,1,&memdc,0,j*20+i,SRCCOPY);

}

Sleep(10);

}

}

else if(next==5)//雨滴效果

{

for(int i=height-1;i>=0;i--)

{

for(int j=0;j<i;j++)

{

pDC->BitBlt(0,j,width,1,&memdc,0,i,SRCCOPY);

Sleep(10);

}

}

}

// TODO: add draw code for native data here

}

其它实现细节请参见源代码。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航