2008年(909)
分类:
2008-05-06 21:32:19
下载源代码
CDC memdc; CBitmap m_bitmap;
m_bitmap.LoadBitmap(IDB_BITMAP1);
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其它实现细节请参见源代码。 下载本文示例代码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 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 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;jBitBlt(0,j,width,1,&memdc,0,i,SRCCOPY); Sleep(10); } } } // TODO: add draw code for native data here }