图形显示特技算法

2016-06-19

水平百叶窗:将图象分成若干等份,每次扫描各等份的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;iBitBlt(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;jBitBlt(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;jBitBlt(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;jBitBlt(0,j,width,1,&memdc,0,i,SRCCOPY);
			   Sleep(10);
		   }
		   
		}
	}
	// TODO: add draw code for native data here
}    

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