这个截图工具能实现最主要的截图功能,并保存为bmp图片。

编写环境是vs2005,使用Unicode,基于对话框。

没什么难度,直接看代码

项目名称为CutOut

// CutOutDlg.h : 头文件
// #pragma once
#include <atlimage.h> // CCutOutDlg 对话框
class CCutOutDlg : public CDialog
{
// 构造
public:
CCutOutDlg(CWnd* pParent = NULL); // 标准构造函数 // 对话框数据
enum { IDD = IDD_CUTOUT_DIALOG }; protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持 // 实现
protected:
HICON m_hIcon; // 生成的消息映射函数
virtual BOOL OnInitDialog();
afx_msg void OnSysCommand(UINT nID, LPARAM lParam);
afx_msg void OnPaint();
afx_msg HCURSOR OnQueryDragIcon();
DECLARE_MESSAGE_MAP() private:
CDC m_DC;
CBitmap m_bDeskTopBitmap;
int m_x;
int m_y;
afx_msg void OnLButtonDown(UINT nFlags, CPoint point);
POINT m_StartPt;
POINT m_EndPt;
CRectTracker m_rectTracker;
afx_msg void OnRButtonDown(UINT nFlags, CPoint point);
afx_msg BOOL OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message);
CBitmap m_bSaveBitmap;
afx_msg void OnLButtonDblClk(UINT nFlags, CPoint point);
afx_msg void OnLButtonUp(UINT nFlags, CPoint point);
};

// CutOutDlg.cpp : 实现文件
// #include "stdafx.h"
#include "CutOut.h"
#include "CutOutDlg.h" #ifdef _DEBUG
#define new DEBUG_NEW
#endif // 用于应用程序“关于”菜单项的 CAboutDlg 对话框 class CAboutDlg : public CDialog
{
public:
CAboutDlg(); // 对话框数据
enum { IDD = IDD_ABOUTBOX }; protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持 // 实现
protected:
DECLARE_MESSAGE_MAP()
}; CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
} void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
} BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
END_MESSAGE_MAP() // CCutOutDlg 对话框 CCutOutDlg::CCutOutDlg(CWnd* pParent /*=NULL*/)
: CDialog(CCutOutDlg::IDD, pParent)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
//橡皮筋默认位置
//m_rectTracker.m_rect = CRect(200,200,400,400); //初始化橡皮筋的style
m_rectTracker.m_nStyle = CRectTracker::solidLine|CRectTracker::resizeOutside;
} void CCutOutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
} BEGIN_MESSAGE_MAP(CCutOutDlg, CDialog)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
//}}AFX_MSG_MAP
ON_WM_LBUTTONDOWN()
ON_WM_RBUTTONDOWN()
ON_WM_SETCURSOR()
ON_WM_LBUTTONDBLCLK()
ON_WM_LBUTTONUP()
END_MESSAGE_MAP() // CCutOutDlg 消息处理程序 BOOL CCutOutDlg::OnInitDialog()
{
CDialog::OnInitDialog(); // 将“关于...”菜单项加入到系统菜单中。 // IDM_ABOUTBOX 必须在系统命令范围内。
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000); CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != NULL)
{
CString strAboutMenu;
strAboutMenu.LoadString(IDS_ABOUTBOX);
if (!strAboutMenu.IsEmpty())
{
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
}
} // 设置此对话框的图标。当应用程序主窗体不是对话框时,框架将自己主动
// 运行此操作
SetIcon(m_hIcon, TRUE); // 设置大图标
SetIcon(m_hIcon, FALSE); // 设置小图标 // TODO: 在此加入额外的初始化代码 ////////////////////////////////////////////////////////////////////////// //获得整个屏幕的大小
m_x = GetSystemMetrics(SM_CXSCREEN);
m_y = GetSystemMetrics(SM_CYSCREEN); //以当前桌面窗体创建一个DC
CClientDC dc(GetDesktopWindow()); //创建一个兼容桌面窗体的dc并关联bitmap
m_DC.CreateCompatibleDC(&dc);
m_bDeskTopBitmap.CreateCompatibleBitmap(&dc,m_x,m_y);
m_DC.SelectObject(&m_bDeskTopBitmap); //讲窗体dc内容传输到应用程序的dc
m_DC.BitBlt(0,0,m_x,m_y,&dc,0,0,SRCCOPY);
//窗体最大化显示
ShowWindow(SW_SHOWMAXIMIZED); return TRUE; // 除非将焦点设置到控件,否则返回 TRUE
} void CCutOutDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialog::OnSysCommand(nID, lParam);
}
} // 假设向对话框加入最小化button,则须要以下的代码
// 来绘制该图标。对于使用文档/视图模型的 MFC 应用程序,
// 这将由框架自己主动完毕。 void CCutOutDlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // 用于绘制的设备上下文 SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0); // 使图标在工作矩形中居中
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2; // 绘制图标
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CDialog::OnPaint();
} //////////////////////////////////////////////////////////////////////////
//每次重绘都显示应用程序窗体出现之前截到的窗体
CClientDC dc(this);
dc.BitBlt(0,0,m_x,m_y,&m_DC,0,0,SRCCOPY); //显示橡皮筋
m_rectTracker.Draw(&dc); } //当用户拖动最小化窗体时系统调用此函数取得光标显示。
//
HCURSOR CCutOutDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
} void CCutOutDlg::OnLButtonDown(UINT nFlags, CPoint point)
{
// TODO: 在此加入消息处理程序代码和/或调用默认值
m_StartPt = point; m_rectTracker.Track(this,m_StartPt,TRUE);
Invalidate();
CDialog::OnLButtonDown(nFlags, point);
} void CCutOutDlg::OnRButtonDown(UINT nFlags, CPoint point)
{
// TODO: 在此加入消息处理程序代码和/或调用默认值 //右键按下,获取橡皮筋圈住的区域,并传输到窗体左上角,实现预览
CClientDC dc(this);
CRect re(m_rectTracker.m_rect);
dc.BitBlt(0,0,re.Width(),re.Height(),&dc,re.left,re.top,SRCCOPY); CDialog::OnRButtonDown(nFlags, point);
} BOOL CCutOutDlg::OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message)
{
// TODO: 在此加入消息处理程序代码和/或调用默认值 //设置鼠标的图标
if (m_rectTracker.SetCursor(this,nHitTest))
{
return FALSE;
} //不在橡皮筋内部及边界就显示默认的箭头
return CDialog::OnSetCursor(pWnd, nHitTest, message);
} void CCutOutDlg::OnLButtonDblClk(UINT nFlags, CPoint point)
{
// TODO: 在此加入消息处理程序代码和/或调用默认值 //右键双击橡皮筋内部,保存图片
if (m_rectTracker.m_rect.PtInRect(point))
{
//保存橡皮筋圈住的区域到内存dc
CClientDC dc(this);
CRect re(m_rectTracker.m_rect);
m_bSaveBitmap.CreateCompatibleBitmap(&dc,re.Width(),re.Height()); CDC tempDc;
tempDc.CreateCompatibleDC(&dc);
tempDc.SelectObject(&m_bSaveBitmap);
tempDc.BitBlt(0,0,re.Width(),re.Height(),&dc,re.left,re.top,SRCCOPY); //弹出一个对话框,保存为bmp格式
CFileDialog fDlg(FALSE,_T("bmp"),NULL,OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT,_T("*.bmp"),this);
if (fDlg.DoModal()==IDOK)
{
CString bmpfile = fDlg.GetPathName();
//用CImage保存图片
ATL::CImage img;
img.Attach(m_bSaveBitmap);
img.Save(bmpfile);
img.Detach();
//截图后退出程序
PostQuitMessage(0);
}
}
CDialog::OnLButtonDblClk(nFlags, point);
} void CCutOutDlg::OnLButtonUp(UINT nFlags, CPoint point)
{
// TODO: 在此加入消息处理程序代码和/或调用默认值 //左键按下获取坐标,实现拖拽鼠标画框
m_EndPt = point;
m_rectTracker.m_rect = CRect(m_StartPt,m_EndPt); Invalidate(); CDialog::OnLButtonUp(nFlags, point);
}

MFC 之 截图工具的更多相关文章

  1. MFC开发--截图工具

    近期学习了MFC的相关知识,MFC(Microsoft Foundation Classes)是微软公司提供的一个类库,可以这样简单理解,就是对于Win32的封装(MFC对windows API函数的 ...

  2. 人生第一次研读MFC截图工具的笔记心得

    截图工具: 其中用到了动态链接库DLL技术(Dynamic Link Library)技术,键盘钩子技术,光标捕获技术,类橡皮类CRectTracker 头文件:后缀名为.cpp,主要是定义和声明之类 ...

  3. 在Ubuntu|CentOS上安装Shutter截图工具及快捷键设置

    简介 Shutter前身叫GScrot,它是一款相当棒的截图软件. 通过Shutter,你可以截取包括选定区域.全屏幕.窗口.窗口内的控件甚至网页的图像.通过内置的强大插件机制,你可以在截图后,对图像 ...

  4. google浏览器截图工具 Open Screenshot(代码截图)

    有的时候特别想把自己写的代码保存为图片,但是代码的内容很长,用普通的截图工具只能一次一次的拼接起来,太麻烦了.这里使用了Google的截图插件,很好用. 或者使用360极速浏览器-->保存网页也 ...

  5. Ubuntu菜鸟入门(一)—— 截图工具安装

    Ubuntu截图工具Shutter 1.添加安装包软件源 sudo add-apt-repository ppa:shutter/ppa 2.更新源并安装 shutter sudo apt-get u ...

  6. linux deepin-scrot 截图工具

    1.下载 .deb 安装包: 点击这里   (如果提示缺少依赖,去终端安装相应的依赖) 2. 设置快捷键Alt+Ctrl+A 1. 系统设置 -> 键盘设置 -> 自定义快捷键 -> ...

  7. 创建Windows截图工具的快捷方式

    日常生活中我们会用到好多截图,一般截图我们用QQ自带截图较多,但许多人都忽视了电脑自带截图功能.在我的电脑-->附件-->截图工具   按照上述方式找截图工具比较繁琐,今天我们可以通过快捷 ...

  8. ubuntu 14.04 安装截图工具 Shutter及使用

    一.安装截图工具 Shutter 1. 添加安装包软件源 sudo add-apt-repository ppa:shutter/ppa 1 2. 更新源并安装 shutter sudo apt-ge ...

  9. linux截图工具scrot

    SCROT截图工具 安装命令 sudo apt-get install scrot 截图命令使用说明: 1.抓取整个桌面:    scrot   ~/Pictures/pic1.jpg2.抓取窗口:  ...

随机推荐

  1. BZOJ 1823: [JSOI2010]满汉全席( 2-sat )

    2-sat...假如一个评委喜好的2样中..其中一样没做, 那另一样就一定要做, 这样去建图..然后跑tarjan. 时间复杂度O((n+m)*K) ------------------------- ...

  2. spring多数据源的配置

    C3P0和DBCP的区别 C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展.目前使用它的开源项目有Hibernate,Spring等.   d ...

  3. atexit模块解析

    atexit模块很简单,只定义了一个register函数用于注册程序退出时的回调函数,我们可以在回调函数中做一些资源清理的操作. 注意回调函数只有正常退出的时候才会调用,如果程序是被信号杀死或者因为严 ...

  4. C语言程序转换为Python语言

    python语言是支持用c来它写模块的,其实现有的很多模块也是用c写的.这里我做个简单的介绍. 先决条件:1.在linux上编写,需要自己编译出python的动态连接库.也就是要有libpython2 ...

  5. 浅谈Linux ftp服务器相关配置

    首先我们需要在Linux系统下安装FTP服务器  Ubuntu sudo apt-get install.......  centos yun....... 然后,我们要配置vsftpd.conf文件 ...

  6. 【c语言】求最大值

    一.我个人觉得求最大值比较简单的一种方法(当然同时求最大值和最小值时稍微改改也能行) #include <stdio.h> int main(void) { int f, i, max; ...

  7. How do I Find Out Linux CPU Utilization?

    From:http://www.cyberciti.biz/tips/how-do-i-find-out-linux-cpu-utilization.html Whenever a Linux sys ...

  8. poj 1579 Function Run Fun(记忆化搜索+dp)

    题目链接:http://poj.org/problem?id=1579 思路分析:题目给出递归公式,使用动态规划的记忆搜索即可解决. 代码如下: #include <stdio.h> #i ...

  9. FLASH ROM与EEPROM的区别

    EEPROM,虽然也叫“非易失性数据存储器”,但它不能直接参与ALU运算,只是用于掉电不丢失的数据存储. EEPROM和片内RAM 类似,也属于数据存储器,它的特点是数据掉电可保持,而程序存储器一般指 ...

  10. Sprintf()的思考和引出的相关问题

    Sprintf()为什么不安全? 功能 把格式化的数据写入某个 字符串 缓冲区. 头文件 stdio.h 原型 int sprintf( char *buffer, const char *forma ...