vc/mfc获取rgb图像数据后动态显示及保存图片的方法-阿里云开发者社区

开发者社区> double2li> 正文

vc/mfc获取rgb图像数据后动态显示及保存图片的方法

简介: vc/mfc获取rgb图像数据后动态显示及保存图片的方法 该情况可用于视频通信中获取的位图数据回放显示或显示摄像头捕获的本地图像 第一种方法 #include 加载 vfw32.lib  链接库 [cpp] view plaincopy   //----------...
+关注继续查看

vc/mfc获取rgb图像数据后动态显示及保存图片的方法

该情况可用于视频通信中获取的位图数据回放显示或显示摄像头捕获的本地图像

第一种方法

#include<vfw.h>

加载 vfw32.lib  链接库

[cpp] view plaincopy
 
  1. //------------------------------设置位图头结构信息----------------------------------------------------------------------  
  2.   
  3. // Setup bmpinfo structure yourself   
  4.   m_bmpinfo=new BITMAPINFO;    // PBITMAPINFO *m_bmpinfo;  
  5. //  m_bmpinfo->bmiHeader.biSize=sizeof(BITMAPINFOHEADER);  
  6.   m_bmpinfo->bmiHeader.biSize=sizeof(BITMAPINFO);  
  7.   m_bmpinfo->bmiHeader.biWidth=IMG_WIDTH;  
  8.   m_bmpinfo->bmiHeader.biHeight=IMG_HEIGHT;  
  9.   m_bmpinfo->bmiHeader.biPlanes=1;  
  10.   m_bmpinfo->bmiHeader.biBitCount=24;  
  11.   m_bmpinfo->bmiHeader.biCompression=0;  
  12.   m_bmpinfo->bmiHeader.biSizeImage=0;  
  13.   m_bmpinfo->bmiHeader.biXPelsPerMeter=0;  
  14.   m_bmpinfo->bmiHeader.biYPelsPerMeter=0;  
  15.   m_bmpinfo->bmiHeader.biClrUsed=0;  
  16.   m_bmpinfo->bmiHeader.biClrImportant=0;  
  17.   
  18. //-------------在内存中绘制位图头信息-----------------------------------------------------------------------------------  
  19.   
  20. // Initialize DIB for drawing...  
  21.  hdib=::DrawDibOpen();    // HDRAWDIB hdib;  
  22.  if(hdib!=NULL)  
  23.  {  
  24.     
  25.   ::DrawDibBegin(hdib,  
  26.         m_hdc,  
  27.         -1,    // don't stretch  
  28.         -1,    // don't stretch  
  29.         &m_bmpinfo->bmiHeader,  
  30.         IMG_WIDTH,         // width of image  
  31.         IMG_HEIGHT,        // height of image  
  32.         0      
  33.         );  
  34.  }  
  35.   
  36. //---------------绘制位图数据 buf--------------char* buf--------------------------------------------------------------------  
  37.   
  38.  ::DrawDibDraw(hdib,  
  39.       m_hdc,  
  40.       local_wnd_x,  // dest : left pos  
  41.       local_wnd_y,  // dest : top pos  
  42.       -1,      // -1 don't zoom x  
  43.       -1,      // -1 don't zoom y  
  44.       &m_bmpinfo->bmiHeader, // bmp header info  
  45.       buf,      // bmp data  
  46.       0,      // src :left  
  47.       0,      // src :top  
  48.       IMG_WIDTH,     // src : width  
  49.       IMG_HEIGHT,     // src : height  
  50.       DDF_SAME_DRAW    // use prev params....  
  51.       );  
  52. //------------------------------结束绘制---------------------------------------------------------------------  
  53.   
  54.  // Close graphics....  
  55.  if(hdib!=NULL)  
  56.  {  
  57.  ::DrawDibEnd(hdib);  
  58.  ::DrawDibClose(hdib);  
  59.  }  


 

//***********************************************

第二种方法

 

[cpp] view plaincopy
 
  1. BITMAPINFO *m_bmphdr;  
  2.  DWORD dwBmpHdr = sizeof(BITMAPINFO);  
  3.  m_bmphdr = new BITMAPINFO[dwBmpHdr];  
  4.  m_bmphdr->bmiHeader.biBitCount = 24;  
  5.  m_bmphdr->bmiHeader.biClrImportant = 0;  
  6.  m_bmphdr->bmiHeader.biSize = dwBmpHdr;  
  7.  m_bmphdr->bmiHeader.biSizeImage = 0;  
  8.  m_bmphdr->bmiHeader.biWidth = IMG_WIDTH;  
  9.  m_bmphdr->bmiHeader.biHeight = IMG_HEIGHT;  
  10.  m_bmphdr->bmiHeader.biXPelsPerMeter = 0;  
  11.  m_bmphdr->bmiHeader.biYPelsPerMeter = 0;  
  12.  m_bmphdr->bmiHeader.biClrUsed = 0;  
  13.  m_bmphdr->bmiHeader.biPlanes = 1;  
  14.  m_bmphdr->bmiHeader.biCompression = BI_RGB;  
  15.   
  16.  int nResult = ::StretchDIBits(m_hdc,  
  17.   local_wnd_x,  
  18.   local_wnd_y,  
  19.   IMG_WIDTH,//rc.right - rc.left,  
  20.   IMG_HEIGHT,//rc.top,  
  21.   0, 0,  
  22.   IMG_WIDTH, IMG_HEIGHT,  
  23.   buf,  
  24.   m_bmphdr,  
  25.   DIB_RGB_COLORS,  
  26.   SRCCOPY);  

保存成bmp图片文件

[cpp] view plaincopy
 
    1. // 创建位图文件  
    2.     BOOL SaveBitmap(BYTE *pBuffer, long lBufferLen)  
    3.     {  
    4.         HANDLE hf = CreateFile(m_szFileName, GENERIC_WRITE,   
    5.             FILE_SHARE_READ, NULL, CREATE_ALWAYS, NULL, NULL);  
    6.         if (hf == INVALID_HANDLE_VALUE) return 0;  
    7.         // 写文件头  
    8.         BITMAPFILEHEADER fileheader;  
    9.         ZeroMemory(&fileheader, sizeof(BITMAPFILEHEADER));  
    10.         fileheader.bfType = 'MB';  
    11.         fileheader.bfSize = sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER)+lBufferLen;  
    12.         fileheader.bfOffBits = sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER);  
    13.         DWORD dwWritter = 0;  
    14.         WriteFile(hf, &fileheader, sizeof(BITMAPFILEHEADER), &dwWritter, NULL);  
    15.         // 写文图格式  
    16.         BITMAPINFOHEADER infoHeader;  
    17.         ZeroMemory(&infoHeader, sizeof(BITMAPINFOHEADER));  
    18.         infoHeader.biSize = sizeof(BITMAPINFOHEADER);  
    19.         infoHeader.biSizeImage = lBufferLen;  
    20.         infoHeader.biWidth = lWidth;  
    21.         infoHeader.biHeight = lHeight;  
    22.         infoHeader.biBitCount = 24;  
    23.         WriteFile(hf, &infoHeader, sizeof(BITMAPINFOHEADER), &dwWritter, NULL);  
    24.         // 写位图数据  
    25.         WriteFile(hf, pBuffer, lBufferLen, &dwWritter, NULL);  
    26.         CloseHandle(hf);  
    27.         MessageBox(NULL, _T("Save bmp file succeed!"), _T("warn"), MB_OK|MB_ICONINFORMATION);  
    28.         return 0;  
    29.     }  

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
基于 H5 Canvas "指纹识别" 技术 【浏览器指纹 VS Canvas指纹】
基于 H5 Canvas "指纹识别" 技术 【浏览器指纹 VS Canvas指纹】
22 0
VS Code识别编辑规范,ESlint规则,VS Code保存去掉自动加分号、逗号、双引号
书写规范是非常重要的,除了统一,还要简洁。 1、VS Code识别编辑规范 在项目根目录新建.editorconfig文件,加入设置:
19 0
是什么让 Gear 与众不同? 在 Gear 上部署有什么好处?
Gear 是一个智能合约平台,任何人都可以在去中心化网络以及 Polkadot 生态系统中开发和部署 dApp,就像在 Layer-1 区块链网络中一样,但效果更胜一筹!
14 0
【Typescript入门手册】类型进阶
【Typescript入门手册】类型进阶
12 0
备战5月软考--软件设计师
1.上午场需要做的就是不停的刷题,每个科目的题都要会个大概(大概有11个大考点) 2.下午场需要做的也是不停的做题,下午场的题型比较固定,做来做出都是那几类,自己做完总结适合自己的做题技巧第一题:数据流图方面的设计(实体Ei的名称、数据存储Di的名称,数据流图等)第二题:数据库设计(E-R图、完整性约束等)第三题:用例描述(识别参与者、用例名称、类名等)第四题:算法题第五题:设计模式的Java代码第六题:设计模式的C++代码
10 0
领域建模:分清问题域和问题解决域(下)
领域建模:分清问题域和问题解决域(下)
4 0
终身学习与传统文化[增强版]
最近H同学问了我2个问题。一是我越参加社群活动,就越没有自信了(大家都挺牛的,连友强都是,不仅能写,排版能力也提升了);二是张同学是我老板,他擅长做会议引导,他竟然让我策划组织一次会议,我也怕丢脸。 那么问题来了,有哪些解法呢?
5 0
【算法学习】1863. 找出所有子集的异或总和再求和(java / c / c++ / python / go / rust)
一个数组的 异或总和 定义为数组中所有元素按位 XOR 的结果;如果数组为 空 ,则异或总和为 0 。 例如,数组 [2,5,6] 的 异或总和 为 2 XOR 5 XOR 6 = 1 。 给你一个数组 nums ,请你求出 nums 中每个 子集 的 异或总和 ,计算并返回这些值相加之 和 。 注意:在本题中,元素 相同 的不同子集应 多次 计数。 数组 a 是数组 b 的一个 子集 的前提条件是:从 b 删除几个(也可能不删除)元素能够得到 a 。
4 0
python测试框架-pytest
python测试框架-pytest 一、pytest 介绍、运行、参数化和数据驱动、Fixture pytest安装与介绍 官网 : pip install -U pytest 查看版本号:pytest --version 为何选择pytest 兼容unittest 定制化插件开发 pycharm 配置github VSC--Git--Remotes... pycharm pytest 配置 settings--搜索pytest--Python integrated Tools--testing--选择pytest:根据黄色叹号fix安装pytest安装到环境
23 0
user-modify VS contenteditable 【实现掘金沸点话题标签】
user-modify VS contenteditable 【实现掘金沸点话题标签】
16 0
+关注
double2li
一个在IT行业摸爬滚打的老司机
2870
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载