My FAQ,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > Visual C++ > 图形图像与多媒体
图形显示特技算法
作者:未知 时间:2005-07-20 14:14 出处:VC知识库 责编:MyFAQ
              摘要:图形显示特技算法

图形显示特技算法


作者 浙江大学 王向伟


下载源代码


    水平百叶窗:将图象分成若干等份,每次扫描各等份的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
    }    
    其它实现细节请参见源代码。
关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 myfaq.com.cn All rights reserved. www.myfaq.com.cn 版权所有