




已阅读5页,还剩1页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
课程实验1 一、实验目的 熟悉*.bmp位图文件的文件格式,掌握位图数据读取并在屏幕上显示的方法。二、实验环境 12人一台pc机,Visual C+6.0编程环境。三、实验内容 读取指定的256色灰度图像的数据,显示该文件的文件头和信息头数据的值,并在屏幕上显示该图象。四、实验步骤1 进入Visual C+6.0编程环境,点击“File”“New”,选择project标签页,按照图1所示选择新建工程的类型和名字,点击ok确定。图12 出现图2所示对话框,按照图2进行应用程序类型选择,并点击Finish确定。在随后出现的对话框中点击ok确定,系统就按照我们的要求自动生成了一个名为“ShowBmp”的工程。3 在stdafx.h头文件中添加如下的代码:#include / MFC core and standard components#include / MFC extensions#include / MFC Automation classes#include / MFC support for Internet Explorer 4 Common Controls#include /* For _MAX_PATH definition */#include / 输入输出函数库#include / 内存分配函数库#include / 数学相关函数库图24 打开ShowBmp.cpp文件,在主函数main之前添加如下代码:BITMAPFILEHEADER bmfHeader; /位图文件头BITMAPINFOHEADER bmiHeader; /位图信息头RGBQUAD *bmiColor; /调色板指针unsigned char MyImage10241024; /为二维图像的颜色数据分配一个二维数组5 将主函数写为如下形式:void main(int argc, char* argv)if(argc2) printf(输入命令格式: ShowBmp.exe *.bmpn); return; FILE *fp;int Palette_Num;int Height, Width, Width_4;int i, j;DWORD Color_Value;fp=fopen(argv1, rb); /打开*.bmp文件,获取文件指针 fread(&bmfHeader, sizeof(bmfHeader), 1, fp); /从文件中读位图文件头数据到bmfHeader变量fread(&bmiHeader, sizeof(bmiHeader), 1, fp); /从文件中读位图信息头数据到bmiHeader变量/ 判断是否是DIB对象,检查头两个字节是否是BMif (bmfHeader.bfType != 0x4D42)printf(这不是一个位图文件n);return;/判断位图的颜色是否是256色if(bmiHeader.biBitCount!=8)printf(本程序只能显示256色灰度图n);return;Height = bmiHeader.biHeight; /从信息头中读出图像高度Width = bmiHeader.biWidth; /从信息头中读出图像宽度 Width_4 = (Width+3)/4*4; /取一个大于等于Width,并且最接近Width的4的整数倍的数值printf(%s图像文件的文件头数据如下n, argv1);printf( bfType=BMn bfSize=%dn bfReserved1=%dn bfReserved2=%dn bfoffBits=%dn, bmfHeader.bfSize, bmfHeader.bfReserved1, bmfHeader.bfReserved2, bmfHeader.bfOffBits);printf(%s图像文件的信息头数据如下n, argv1);printf( biSize=%dn biWidth=%dn biHeight=%dn biPlanes=%dn biBitCount=%dn biCompress=%dn biSizeImage=%dn biXPeIsPerMeter=%dn biYPeIsPerMeter=%dn biCIrUsed=%dn biClrImprotant=%dn, bmiHeader.biSize, bmiHeader.biWidth, bmiHeader.biHeight, bmiHeader.biPlanes, bmiHeader.biBitCount, bmiHeader.biCompression, bmiHeader.biSizeImage, bmiHeader.biXPelsPerMeter, bmiHeader.biYPelsPerMeter, bmiHeader.biClrUsed, bmiHeader.biClrImportant);/获取调色板的成员数目,也就是位图所用到的颜色个数if(bmiHeader.biClrUsed=0) Palette_Num = 1bmiHeader.biBitCount;elsePalette_Num = bmiHeader.biClrUsed;bmiColor = (RGBQUAD *)malloc(Palette_Num * sizeof(RGBQUAD); /为调色板指针指向的地址分配一块内存空间fread(bmiColor, sizeof(RGBQUAD), Palette_Num, fp); /从文件中读位图的调色板数据到bmiColor指针指向的缓冲区 fseek(fp, bmfHeader.bfOffBits, 0); /令文件指针指向位图有效数据的起始位置/将位图有效数据输入导入MyImage二维数组中for(i=0; iHeight; i+)fread(MyImageHeight-1-i, sizeof(unsigned char), Width_4, fp);fclose(fp); /关闭位图文件for(i=0; iHeight; i+)for(j=0; jWidth_4; j+)MyImageij = bmiColorMyImageij.rgbRed; /根据颜色索引号从调色板中查找真正的颜色值,赋给MyImage数组的元素 free(bmiColor); HDC hMyDc=GetDC(NULL); /获取显示屏的指针/将MyImage二维数组所存储的图像数据显示在屏幕上for(i=0; iHeight; i+)for(j=0; jWidth_4; j+) Color_Value = MyImageij;Color_Value = Color_Value*65536 + Color_Value*256 +Color_Value; SetPixel(hMyDc, j, i, Color_Value);return;6 依次点击菜单“Build”下面的“Compile” 和“Rebuild All”菜单项,在Debug文件夹中生成可执行程序ShowBmp.exe。将该文件复制到E:盘根目录下,并将实验图片也全部复制到根目录下。在dos命令提示符界面中,进入到E:盘根目
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 环境友好型设计与实践作业指导书
- 数字化设计与制造作业指导书
- 甘肃2025年中共甘肃省委党校(甘肃行政学院)事业岗位招聘27人笔试历年参考题库附带答案详解
- 三农领域创新与创业实践作业指导书
- 三农村地区新型农业经营主体培育策略
- 鹰潭2025年江西鹰潭市事业单位招聘301人笔试历年参考题库附带答案详解
- 铜仁2025年贵州铜仁市碧江区事业单位招聘24人笔试历年参考题库附带答案详解
- 贵州2025年贵州省妇联直属事业单位招聘3人笔试历年参考题库附带答案详解
- 2024年二级建造师考试《建设工程法规及相关知识6.1B卷》真题及答案
- 2025年云安全服务项目建议书
- 2024年河南职业技术学院单招职业适应性测试题库各版本
- 龙门吊基础施工方案 (定稿)
- 乡村规划理论与方法智慧树知到期末考试答案章节答案2024年长安大学
- 永遇乐·京口北固亭怀古
- 《廉洁文化知识问答100题》答题活动(含答案)
- 手术室患者身份识别制度
- 第一单元练习卷(单元测试)2023-2024学年统编版语文六年级下册
- 巴黎香榭丽舍大街课件
- 教师命题能力提升培训
- 成人肥胖食养指南2024年版-国家卫健委-202403
- 电复律的护理查房
评论
0/150
提交评论