源代码:http://download.csdn.net/detail/nuptboyzhb/3961677

Ø  添加全屏截图菜单项,菜单项的属性如下;

Ø  为该菜单项建立类向导。

编辑消息处理函数如下

voidCCVMFCView::OnPrintscreen()

{

CRect rect;

//HBITMAP hMap;

rect.left = 0;

rect.top = 0;

rect.right =GetSystemMetrics(SM_CXSCREEN);

rect.bottom =GetSystemMetrics(SM_CYSCREEN);

//-------------------------------------------

HDC hScrDC, hMemDC;

// 屏幕和内存设备描述表

HBITMAP hBitmap,hOldBitmap;

// 位图句柄

int       nX, nY, nX2, nY2;

// 选定区域坐标

int       nWidth, nHeight;

// 位图宽度和高度

int       xScrn, yScrn;

// 屏幕分辨率

// 确保选定区域不为空矩形

//为屏幕创建设备描述表

hScrDC = CreateDC("DISPLAY",NULL, NULL, NULL);

//为屏幕设备描述表创建兼容的内存设备描述表

hMemDC = CreateCompatibleDC(hScrDC);

// 获得选定区域坐标

nX = rect.left;

nY = rect.top;

nX2 =rect.right;

nY2 =rect.bottom;

// 获得屏幕分辨率

xScrn = GetDeviceCaps(hScrDC, HORZRES);

yScrn = GetDeviceCaps(hScrDC, VERTRES);

//确保选定区域是可见的

if (nX < 0) nX = 0;

if (nY < 0) nY = 0;

if (nX2 > xScrn) nX2 = xScrn;

if (nY2 > yScrn) nY2 = yScrn;

nWidth = nX2 - nX;

nHeight = nY2 - nY;

// 创建一个与屏幕设备描述表兼容的位图

hBitmap=CreateCompatibleBitmap(hScrDC,nWidth,nHeight);

// 把新位图选到内存设备描述表中

hOldBitmap=(HBITMAP)SelectObject(hMemDC,hBitmap);

// 把屏幕设备描述表拷贝到内存设备描述表中

BitBlt(hMemDC,0,0,nWidth,nHeight,hScrDC, nX, nY, SRCCOPY);

//得到屏幕位图的句柄

hBitmap=(HBITMAP)SelectObject(hMemDC,hOldBitmap);

//清除

DeleteDC(hScrDC);

DeleteDC(hMemDC);

CFileDialogdlg(false,"*.bmp","Test.bmp",OFN_HIDEREADONLY |OFN_OVERWRITEPROMPT,"保存文本(*.bmp)|*.bmp|所有文件(*.*)|*.*||");

CString strPath("");

if(dlg.DoModal() == IDOK)

{

strPath=dlg.GetPathName();

//----------------以下为保存图像句柄为hBitmap,路径为lpFileName的图像

LPSTR lpFileName=(LPTSTR)(LPCTSTR)strPath;

HDC  hDC;   //设备描述表

int iBits;  //当前显示分辨率下每个像素所占字节数

WORD    wBitCount;  //位图中每个像素所占字节数

//定义调色板大小, 位图中像素字节大小 ,  位图文件大小 , 写入文件字节数

DWORD          dwPaletteSize=0,dwBmBitsSize,dwDIBSize, dwWritten;

BITMAP          Bitmap;     //位图属性结构

BITMAPFILEHEADER   bmfHdr; //位图文件头结构

BITMAPINFOHEADER   bi;     //位图信息头结构

LPBITMAPINFOHEADER lpbi;          //指向位图信息头结构

HANDLE       fh, hDib, hPal;

HPALETTE     hOldPal=NULL;

//定义文件,分配内存句柄,调色板句柄

//计算位图文件每个像素所占字节数

hDC =CreateDC("DISPLAY",NULL,NULL,NULL);

iBits = GetDeviceCaps(hDC,BITSPIXEL) *

GetDeviceCaps(hDC,PLANES);

DeleteDC(hDC);

if (iBits <= 1)  wBitCount = 1;

else if (iBits <= 4)  wBitCount = 4;

else if (iBits <= 8)  wBitCount = 8;

else if (iBits <= 24)wBitCount = 24;

else

wBitCount = 32;

//计算调色板大小

if (wBitCount <= 8)

dwPaletteSize=(1<<wBitCount)*sizeof(RGBQUAD);

//设置位图信息头结构

GetObject(hBitmap,sizeof(BITMAP), (LPSTR)&Bitmap);

bi.biSize=sizeof(BITMAPINFOHEADER);

bi.biWidth= Bitmap.bmWidth;

bi.biHeight= Bitmap.bmHeight;

bi.biPlanes= 1;

bi.biBitCount= wBitCount;

bi.biCompression= BI_RGB;

bi.biSizeImage= 0;

bi.biXPelsPerMeter= 0;

bi.biYPelsPerMeter= 0;

bi.biClrUsed= 0;

bi.biClrImportant= 0;

dwBmBitsSize =((Bitmap.bmWidth*wBitCount+31)/32)*4*Bitmap.bmHeight;

//为位图内容分配内存

/*xxxxxxxx计算位图大小分解一下(解释一下上面的语句)xxxxxxxxxxxxxxxxxxxx

//每个扫描行所占的字节数应该为4的整数倍,具体算法为:

int biWidth =(Bitmap.bmWidth*wBitCount) / 32;

if((Bitmap.bmWidth*wBitCount)% 32)

biWidth++; //不是整数倍的加1

biWidth *= 4;//到这里,计算得到的为每个扫描行的字节数。

dwBmBitsSize = biWidth *Bitmap.bmHeight;//得到大小

xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx*/

hDib  =GlobalAlloc(GHND,dwBmBitsSize+dwPaletteSize+sizeof(BITMAPINFOHEADER));

lpbi =(LPBITMAPINFOHEADER)GlobalLock(hDib);

*lpbi = bi;

// 处理调色板

hPal =GetStockObject(DEFAULT_PALETTE);

if (hPal)

{

hDC = ::GetDC(NULL);

hOldPal=SelectPalette(hDC,(HPALETTE)hPal,FALSE);

RealizePalette(hDC);

}

// 获取该调色板下新的像素值

GetDIBits(hDC,hBitmap,0,(UINT)Bitmap.bmHeight,(LPSTR)lpbi+sizeof(BITMAPINFOHEADER)+dwPaletteSize,(BITMAPINFO *)lpbi,DIB_RGB_COLORS);

//恢复调色板

if (hOldPal)

{

SelectPalette(hDC,hOldPal, TRUE);

RealizePalette(hDC);

::ReleaseDC(NULL,hDC);

}

//创建位图文件

fh=CreateFile(lpFileName,GENERIC_WRITE,0, NULL, CREATE_ALWAYS,FILE_ATTRIBUTE_NORMAL | FILE_FLAG_SEQUENTIAL_SCAN,NULL);

// 设置位图文件头

bmfHdr.bfType = 0x4D42;  // "BM"

dwDIBSize=sizeof(BITMAPFILEHEADER)+sizeof(BITMAPINFOHEADER)+dwPaletteSize+dwBmBitsSize;

bmfHdr.bfSize = dwDIBSize;

bmfHdr.bfReserved1 = 0;

bmfHdr.bfReserved2 = 0;

bmfHdr.bfOffBits=(DWORD)sizeof(BITMAPFILEHEADER)+(DWORD)sizeof(BITMAPINFOHEADER)+dwPaletteSize;

// 写入位图文件头

WriteFile(fh,(LPSTR)&bmfHdr, sizeof(BITMAPFILEHEADER), &dwWritten, NULL);

// 写入位图文件其余内容

WriteFile(fh, (LPSTR)lpbi,sizeof(BITMAPINFOHEADER)+dwPaletteSize+dwBmBitsSize , &dwWritten, NULL);

//清除

GlobalUnlock(hDib);

GlobalFree(hDib);

CloseHandle(fh);

MessageBox("已完成保存!");

}

}

Ø  “全屏截图”菜单项的资源ID是ID_PRINTSCREEN

Ø  打开资源:Accelerator

Ø  目前的快捷键为:

Ø  添加新的快捷键,在最后一行的虚线处,点击鼠标右键添加:属性如下

Ø  添加之后的资源界面为:

from:http://blog.csdn.net/nupt123456789/article/details/7100134

1.1.0-学习Opencv与MFC混合编程之---全屏截图,保存为BMP图像(并增加快捷键)的更多相关文章

  1. 1.0.x-学习Opencv与MFC混合编程之---视频运动检测

    源代码地址: http://download.csdn.net/detail/nuptboyzhb/3961668 版本1.0.x新增内容 视频运动检测 Ø 新建菜单项,Learning OpenCV ...

  2. 1.0.3-学习Opencv与MFC混合编程之---打开本地摄像头

    源代码:http://download.csdn.net/detail/nuptboyzhb/3961643 版本1.0.3新增内容 打开摄像头 Ø 新建菜单项,Learning OpenCV——&g ...

  3. 1.0.2-学习Opencv与MFC混合编程之---为播放AVI视频添加滑动条

    源代码地址:http://download.csdn.net/detail/nuptboyzhb/3961642 版本1.0.2新增内容 Ø  全局变量和函数的添加: 在CVMFCview.cpp文件 ...

  4. 1.0.1-学习Opencv与MFC混合编程之---播放AVI视频

    资源源代码:http://download.csdn.net/detail/nuptboyzhb/3961639 版本1.0.1新增内容 Ø  新建菜单项,Learning OpenCV——> ...

  5. 1.1-学习Opencv与MFC混合编程之---利用画图函数,生成视频,并写入视频文件

    源代码地址:http://download.csdn.net/detail/nuptboyzhb/3961674 写视频文件 Ø 新建菜单项,Learning OpenCV——> OpenCVr ...

  6. 1.1.7-学习Opencv与MFC混合编程之---为画图工具添加工具栏

    源代码:http://download.csdn.net/detail/nuptboyzhb/3961701 哎,其实里面有很多图片的,本来看起开很明了的,资源连接里有详细的文档,比下面的看的舒服的多 ...

  7. 1.1.5-学习Opencv与MFC混合编程之---画图工具 输入文字和填充图像 修改光标

    源代码:http://download.csdn.net/detail/nuptboyzhb/3961696 输入文字 l 对话框 1.    插入,资源,选择对话框资源 2.    编辑对话框如下: ...

  8. 1.1.6-学习Opencv与MFC混合编程之---播放WAV音乐和 alpha融合功能

    源代码:http://download.csdn.net/detail/nuptboyzhb/3961698 Alpha融合菜单项 1.      增加alpha融合菜单项,修改相应的属性,建立类向导 ...

  9. 1.1.4-学习Opencv与MFC混合编程之---画图工具 画椭圆

    源代码地址:http://download.csdn.net/detail/nuptboyzhb/3961690 1.    增加‘椭圆’菜单项,设置属性,添加类向导: 2.    编辑消息处理函数, ...

随机推荐

  1. 《Java并发编程实战》第二章 线程安全性 读书笔记

    一.什么是线程安全性 编写线程安全的代码 核心在于要对状态訪问操作进行管理. 共享,可变的状态的訪问 - 前者表示多个线程訪问, 后者声明周期内发生改变. 线程安全性 核心概念是正确性.某个类的行为与 ...

  2. Codeforces Round #262 (Div. 2) 460C. Present(二分)

    题目链接:http://codeforces.com/problemset/problem/460/C C. Present time limit per test 2 seconds memory ...

  3. Erich Gamma

    Erich Gamma是IBM的杰出工程师.他是Jazz项目的领头人之一,曾担任Eclipse的Java开发环境JDT项目的领导,目前是Eclipse的项目管理委员会成员.Erich也是经典书籍< ...

  4. rbd块映射

    rbd块映射: root@u18:~# rbd create kvm/test002.img --size root@u18:~# rbd info kvm/test002.img rbd image ...

  5. iOSAPP启动时实现加载广告

    现在很多APP在启动的时候都在加载广告,现在也很流行,主要是盈利啊.笔者也做了很多关于广告的事情.现在记录下自己在APP启动的时候,怎么加载广告的. 下面总结下广告加载的三种方式 1.现在很多APP的 ...

  6. UVALive 6467 Strahler Order 拓扑排序

    这题是今天下午BNU SUMMER TRAINING的C题 是队友给的解题思路,用拓扑排序然后就可以了 最后是3A 其中两次RE竟然是因为: scanf("%d",mm); ORZ ...

  7. 四级流水线的8bit加法器

    以流水线实现8bit 加法器. //date : 2013/8/23 //designer :pengxiaoen //function : module pipeline ( clock ,rese ...

  8. 引用 U-boot给kernel传参数和kernel读取参数—struct tag

    引用 清风徐徐 的 U-boot给kernel传参数和kernel读取参数—struct tag U-boot会给Linux Kernel传递很多参数,如:串口,RAM,videofb等.而Linux ...

  9. TCP和UDP的"保护消息边界" (经典)

    在socket网络程序中,TCP和UDP分别是面向连接和非面向连接的.因此TCP的socket编程,收发两端(客户端和服务器端)都要有一一成对的socket,因此,发送端为了将多个发往接收端的包,更有 ...

  10. 完整的yuicompressor单个压缩和批量压缩以及gzip再次压缩,拦截器的配置等

    下载地址:http://yuilibrary.com/download/yuicompressor/ 个人认为现在yuicompressor是最安全,最值得信赖的压缩工具,至少到现在没出现过问题 1. ...