C#区域截图——调用API截图

前言:截图对于一个C++开发者来讲无非是小菜一碟,也有朋友使用C#的 Graphics.CopyFromScreen 方法屏幕操做,做为一名成天想着用 C++ 开发游戏的初级 C#.NET 的程序员的我,只是本身研究区域截图,失败 n 屡次,最后在半梦半醒中弄出来的简单的Demo,简单的分享一下而已。如此的班门弄斧,着实不堪,另外个人 C++ 水平也是处于入门水准,若是该博客有什么问题,请各位朋友留言指正,谢谢关照!程序员


附件及其余:windows

C#的 Graphics.CopyFromScreen 方法   https://msdn.microsoft.com/zh-cn/library/fw1kt6f9.aspx框架

附件:http://files.cnblogs.com/files/herbertchina/GetFormDemo.zip函数


本文Demo:(VS2010环境)学习

本文使用的图片素材:google

image


本文主题:spa

从窗体的图片中截取须要的部分,本例是验证码区域。code


正文:orm

先贴出主要代码blog

        /// <summary>
        /// 指定窗口区域截图
         /// </summary>
        /// <param name="handle">窗口句柄. (在windows应用程序中, 从Handle属性得到)</param>
        /// <param name="rect">窗口中的一个区域</param>
        /// <returns></returns>
        public  Bitmap CaptureWindow(IntPtr hWnd,RECT rect)
        {
            // 获取设备上下文环境句柄
              IntPtr hscrdc = GetWindowDC(hWnd);

            // 建立一个与指定设备兼容的内存设备上下文环境(DC)
              IntPtr hmemdc = CreateCompatibleDC(hscrdc);
            IntPtr myMemdc = CreateCompatibleDC(hscrdc);

            // 返回指定窗体的矩形尺寸
              RECT rect1;
            GetWindowRect(hWnd, out rect1);

            // 返回指定设备环境句柄对应的位图区域句柄
              IntPtr hbitmap = CreateCompatibleBitmap(hscrdc, rect1.Right - rect1.Left, rect1.Bottom - rect1.Top);
            IntPtr myBitmap = CreateCompatibleBitmap(hscrdc, rect.Right - rect.Left, rect.Bottom - rect.Top);

            //把位图选进内存DC 
            // IntPtr OldBitmap = (IntPtr)SelectObject(hmemdc, hbitmap);
            SelectObject(hmemdc, hbitmap);
            SelectObject(myMemdc, myBitmap);

            /////////////////////////////////////////////////////////////////////////////
            //
            // 下面开始所谓的做画过程,此过程能够用的方法不少,看你怎么调用 API 了
              //
            /////////////////////////////////////////////////////////////////////////////

            // 直接打印窗体到画布
              PrintWindow(hWnd, hmemdc, 0);

            // IntPtr hw = GetDesktopWindow();
            // IntPtr hmemdcClone = GetWindowDC(myBitmap);

            BitBlt(myMemdc, 0, 0, rect.Right - rect.Left, rect.Bottom - rect.Top, hmemdc, rect.Left, rect.Top, CopyPixelOperation.SourceCopy | CopyPixelOperation.CaptureBlt);
            //SelectObject(myMemdc, myBitmap);

            Bitmap bmp = Bitmap.FromHbitmap(myBitmap);
            DeleteDC(hscrdc);
            DeleteDC(hmemdc);
            DeleteDC(myMemdc);
            return bmp;
        }

讲解吧:

原理步骤:
一、经过窗体 handle 建立设备上下文环境
二、根据上下文环境句柄创建对应的与设备兼容的内存设备上下文环境(理解成一块画板,内存上的)
三、经过窗体句柄获得长宽,经过CreateCompatibleBitmap获得窗体对应的设备环境句柄对应的位图区域(理解成天然界的一个美丽的景色)
四、经过 SelectObject 指向性,把 3 中的位图区域句柄对应到 2 中的内存设备上下文中(理解成,我须要画这大天然的美丽景色,我须要有相应的画布,这里就是在画板上固定画布)
五、绘图,包括各类 API 绘图或获取图形
六、此处很重要,由于咱们不是要过去框架的总体图形,咱们要的是局部的,因而,咱们能够经过 1 、2 、3 、4 的步骤,再建设一块画布(第三步有一点区别,就是长宽)
七、经过 BitBlt 方法把以前画好的画的一个区域复制到咱们新建的画板上, BitBlt 的功能是“对指定的源设备环境区域中的像素进行位块(bit_block)转换,以传送到目标设备环境”
八、而后就简单了,Bitmap bmp = Bitmap.FromHbitmap(myBitmap);把咱们复制出来的第二块画板上的画生成位图图像
九、再进行什么操做就随你了
十、最后,最后,最最重要的是……不要忘了使用 DeleteDC 函数清除第 1 、 2 中建的上下文环境,由于这是 API,没有Java的自动清理机制


再者:

再者,哥们我是初学者,文章仅供参考,有什么问题能够百度、google,而后就是,我上面说的必定有问题,请看明白的朋友指正留言,帮助下小友学习一二!谢谢!

相关文章
相关标签/搜索