图像处理实验一 特效处理_第1页
图像处理实验一 特效处理_第2页
图像处理实验一 特效处理_第3页
图像处理实验一 特效处理_第4页
图像处理实验一 特效处理_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、计算机与通讯工程学院天津理工大学计算机与通信工程学院实验报告2013 至 2014 学年 第 二 学期实验一 图像的特效显示课程名称数字图像处理学号学生姓名年级专业计算机教学班号1实验地点主7-220实验时间 2014年4月 28日 第 5节 至 第 6 节主讲教师 杨淑莹辅导教师实验( 一 )实验名称图像的特效显示软件环境WindowsVC+6.0硬件环境PC 实验目的1 实现图像由小到大,逐渐显示。2 将图像中的红气球物体左右、上下、对称复制。2 自行设计图像的几何变换显示。实验内容(应包括实验题目、实验要求、实验任务等)1 实现图像由小到大,逐渐显示。要求:显示一幅位图,由小到大,逐渐显

2、示。任务: (1)在左视图中打开一幅bmp位图,包括256色或真彩色位图(2)制作一个【图像由小到大逐渐显示】菜单,将消息映射到右视图中,在右视图中显示位图,完成图像由小到大,逐渐显示显示功能。2 将图像中的红气球物体左右、上下、对称复制。要求:在左视图中打开一幅256色的灰度bmp位图。将图像中的红气球物体左右、上下、对称复制。任务: (1)在左视图中打开一幅bmp位图,包括256色或真彩色位图(2)制作一个【红气球复制】菜单,将消息映射到右视图中,在右视图中,完成将图像中的红气球物体左右、上下、对称复制功能。3 自行设计图像的几何变换。(选作)要求:自行设计图像的几何变换。任务: (1)在

3、左视图中打开一幅bmp位图,包括256色或真彩色位图(2)制作一个【自行设计图像的几何变换】菜单,将消息映射到右视图中,在右视图中自行设计图像的特效显示,完成图像的几何变换功能。实验过程与实验结果(可包括实验实施的步骤、算法描述、流程、结论等)附录(可包括源程序清单或其它说明)1、 实现图像由小到大,逐渐显示。在Menu界面中添加菜单选项 生成响应函数在函数中添加代码:/刷新屏幕CDC *pDC=GetDC();CRect rect(0,0,1000,1000);CBrush brush(RGB(255,255,255); pDC->FillRect(&rect,&bru

4、sh);/复制图像数据clearmem(); CDSplitDoc* pDoc = GetDocument();ASSERT_VALID(pDoc);if(!pDoc ->statedoc&&state2=1) BYTE* pBitmapData = CDibNew1->GetData(); LPBITMAPINFO pBitmapInfo = CDibNew1->GetInfo(); int bitmapHeight = CDibNew1->GetHeight(); int bitmapWidth = CDibNew1->GetWidth();i

5、nt scaledWidth = (int)(bitmapWidth*0.2);int scaledHeight = (int)(bitmapHeight);if (CDibNew1->GetRGB() / Has a color tableCPalette * hPalette=CreateBitmapPalette(CDibNew1); CPalette * hOldPalette = pDC->SelectPalette(hPalette, true); pDC->RealizePalette();for(int j=1;j<8;j+):StretchDIBits

6、(pDC->GetSafeHdc(),bitmapWidth/2, bitmapHeight/2, (int)(bitmapWidth*0.1*j), (int)(bitmapWidth*0.1*j),0, 0, bitmapWidth, bitmapHeight,pBitmapData, pBitmapInfo,DIB_RGB_COLORS, SRCCOPY);Sleep(100); pDC->SelectPalette(hOldPalette, true); :DeleteObject(hPalette);elsefor(int j=1;j<8;j+):StretchDI

7、Bits(pDC->GetSafeHdc(),bitmapWidth/2, bitmapHeight/2, (int)(bitmapWidth*0.1*j), (int)(bitmapWidth*0.1*j),0, 0, bitmapWidth, bitmapHeight,pBitmapData, pBitmapInfo,DIB_RGB_COLORS, SRCCOPY);Sleep(100);Invalidate(); void CDynSplitView2:Onfuzhi() / TODO: Add your command handler code hereint i,j;/刷新屏幕

8、CDC *pDC=GetDC();CRect rect(0,0,1000,1000);CBrush brush(RGB(255,255,255);pDC->FillRect(&rect,&brush);/复制图像数据clearmem(); CDSplitDoc* pDoc = GetDocument();ASSERT_VALID(pDoc);if(!pDoc ->statedoc&&state2=1 )BYTE* pBitmapData = CDibNew1->GetData();LPBITMAPINFO pBitmapInfo = CDibN

9、ew1->GetInfo();int bitmapHeight= CDibNew1->GetHeight();int bitmapWidth = CDibNew1->GetWidth();LPBYTE temp;temp=new BYTECDibNew1->GetHeight()*CDibNew1->GetWidth()*3;memset (temp,0,CDibNew1->GetHeight()*CDibNew1->GetWidth()*3);for( j = 0; j < bitmapHeight; j+)for( i = 0; i <

10、 bitmapWidth; i +) tempj*bitmapWidth*3+i*3=pBitmapDataj*bitmapWidth*3+i*3; tempj*bitmapWidth*3+i*3+1=pBitmapDataj*bitmapWidth*3+i*3+1; tempj*bitmapWidth*3+i*3+2=pBitmapDataj*bitmapWidth*3+i*3+2;:StretchDIBits(pDC->GetSafeHdc(),0,bitmapHeight/2, bitmapWidth/2, bitmapHeight/2,0,bitmapHeight/2, bitm

11、apWidth/2, bitmapHeight/2,temp, pBitmapInfo,DIB_RGB_COLORS, SRCCOPY); :StretchDIBits(pDC->GetSafeHdc(), bitmapWidth/2, 0, bitmapWidth/2, bitmapHeight/2,0,bitmapHeight/2, bitmapWidth/2, bitmapHeight/2,temp, pBitmapInfo,DIB_RGB_COLORS, SRCCOPY);:StretchDIBits(pDC->GetSafeHdc(),0,0, bitmapWidth/2

12、, bitmapHeight/2,0,bitmapHeight/2, bitmapWidth/2, bitmapHeight/2,temp, pBitmapInfo,DIB_RGB_COLORS, SRCCOPY);:StretchDIBits(pDC->GetSafeHdc(),bitmapWidth/2, bitmapHeight/2, bitmapWidth/2, bitmapHeight/2,0,bitmapHeight/2, bitmapWidth/2, bitmapHeight/2,temp, pBitmapInfo,DIB_RGB_COLORS, SRCCOPY);memc

13、py ( pBitmapData,temp,CDibNew1->GetHeight()*CDibNew1->GetWidth()*3);delete temp;2、 将图像中的红气球物体左右、上下、对称复制。在Menu界面中添加菜单选项生成响应函数:代码中添加:int i,j;/刷新屏幕CDC *pDC=GetDC();CRect rect(0,0,1000,1000);CBrush brush(RGB(255,255,255);pDC->FillRect(&rect,&brush);/复制图像数据clearmem(); CDSplitDoc* pDoc =

14、GetDocument();ASSERT_VALID(pDoc);if(!pDoc ->statedoc&&state2=1 )BYTE* pBitmapData = CDibNew1->GetData();LPBITMAPINFO pBitmapInfo = CDibNew1->GetInfo();int bitmapHeight= CDibNew1->GetHeight();int bitmapWidth = CDibNew1->GetWidth();LPBYTE temp;temp=new BYTECDibNew1->GetHeight

15、()*CDibNew1->GetWidth()*3;memset (temp,0,CDibNew1->GetHeight()*CDibNew1->GetWidth()*3);for( j = 0; j < bitmapHeight; j+)for( i = 0; i < bitmapWidth; i +) tempj*bitmapWidth*3+i*3=pBitmapDataj*bitmapWidth*3+i*3; tempj*bitmapWidth*3+i*3+1=pBitmapDataj*bitmapWidth*3+i*3+1; tempj*bitmapWid

16、th*3+i*3+2=pBitmapDataj*bitmapWidth*3+i*3+2;:StretchDIBits(pDC->GetSafeHdc(),0,bitmapHeight/2, bitmapWidth/2, bitmapHeight/2,0,bitmapHeight/2, bitmapWidth/2, bitmapHeight/2,temp, pBitmapInfo,DIB_RGB_COLORS, SRCCOPY); :StretchDIBits(pDC->GetSafeHdc(), bitmapWidth/2, 0, bitmapWidth/2, bitmapHeight/2,0,bitmapHeight/2, bitmapWidth/2, bitmapHeight/2,temp, pBitmapInfo,DIB_RGB_COLORS, SRCCOPY);:StretchDIBits(pDC->GetSafeHdc(),0,0, bitmapWidth/2, bitmapHeight/2,0,bitmapHeight/2, bitmapWidth/2, bitmapHeight/2,temp, pBitmapInfo,DIB_RGB_COLORS, SRCCOPY);:StretchDIBits(pDC->GetSafeHdc

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论