| 网站首页 | 文章中心 | 电子书下载 | 矢量图库 | 视频教程 | 素材下载 | 程序代码下载 | JS代码 | 论坛 | 
常用软件类:
|杀毒安全 |联络聊天 |网络软件 |多媒体类 |系统工具 |图形图像 |系统工具 |应用软件 |行业软件
开发设计类:
|动画制作 |图像处理 |3D设计 |操作系统 |站长学院 |网络相关 |WEB设计 |数据库类 |程序开发
C#制作屏幕捕捉程序
  随着微软.Net战略的进一步深入,各种新的技术、概念可谓层出不穷,特别是C#语言的推出,在业界产生了重大影响。C#是一门高效的语言,它既有VB的RAD特性,又不乏C++语言的高效性。最重要的它是基于.Net Framework的,在图形图像、网络编程等方面有着强大的优势,所以它很可能发展成为未来的主要编程语言之一。

  本文通过一个实例来向大家展示一下用C#进行图形图像编程的特性。实例中运用到了GDI+编程的一些基础知识,GDI+是从GDI演化而来的,是.Net环境下的新的图形图像编程机制。它不仅具有GDI编程的一些基本功能,而且对GDI进行了不少扩充,使得它功能更强大。在Visual Studio的以前版本中使用GDI是相当复杂的,而且工作量十分大。现在在GDI+中,微软已经帮我们解决了许多问题,因而使用GDI+进行图形图像编程将变得非常容易。不过要指出的是:用GDI编程虽然较复杂,却可以完成几乎所有的复杂功能,比如在实例中用GDI可以轻易做一个屏幕捕捉程序。那么,现在我们在GDI+是否也能完成同样的功能呢?答案是肯定的。正因为GDI+是从GDI演化而来的,我们只要在GDI+中调用GDI的一些功能就行了。

  C#有一个特性,那就是它允许你运用任何预先已经完成的动态连接库文件(*.dll),其中当然包括了gdi32.dll这个文件。该文件包含了进行GDI编程所需的基本类库、函数、方法等。这样,我们在GDI+编程机制下也同样可以享受GDI为我们留下的宝贵资源。具体导入的方法如下:

[System.Runtime.InteropServices.DllImportAttribute("gdi32.dll")]

  在GDI中做屏幕捕捉程序的话,就要用到上下文设备(device context)了。在程序中,我们用它获得屏幕图形并将它写入内存中的一个位图中,实现的方法就是调用BitBlt()函数。同样在GDI+中实现的原理是一样的,下面给出了GDI+中的外部声明函数(用C#语言描述):

privatestaticexternbool BitBlt(

IntPtr hdcDest, //目的上下文设备的句柄

int nXDest, //目的图形的左上角的x坐标

int nYDest, //目的图形的左上角的y坐标

int nWidth, //目的图形的矩形宽度

int nHeight, //目的图形的矩形高度

IntPtr hdcSrc, //源上下文设备的句柄

int nXSrc, //源图形的左上角的x坐标

int nYSrc, //源图形的左上角的x坐标

System.Int32 dwRop //光栅操作代码

);


  为了能在GDI+中调用GDI,我们还需要取得上下文设备的钩子。在GDI+中有一个方法就提供了这种操作的具体实现:

IntPtr dc1 = aGraphicsObject.GetHdc();


  在取得了源上下文设备以及目的上下文设备的句柄后,我们就可以在上面的BitBlt()函数运用它们(作为参数),实现图像创建功能了。在图像创建后,还必须释放源上下文设备以及目的上下文设备资源。

  这样,基本的原理就已介绍完毕,总的来说实现的原理还是比较简单的。下面就是实现实例的具体步骤:

1. 获得一个对应于屏幕上窗体的图形对象

2. 创建一个大小为窗体客户区大小的位图文件

3. 获得窗体的上下文设备

4. 获得位图文件的上下文设备

5. 把屏幕上的窗体写入位图中

6. 释放窗体的上下文设备

7. 释放位图文件的上下文设备

8. 将图像保存为一个jpeg格式的文件

工程步骤:

1. 新建一个C#的工程,不妨命名为“FormCapture”,图示如下:




2. 布置主窗体:

  在窗体上添加一个图片框(pictureBox)控件以及一个按钮(button)控件即可。将主窗体的Text属性设置为“屏幕捕捉程序”;将图片框的Image属性设置为一个图形文件;将按钮的Text属性设置为“屏幕捕捉”即可。(当然读者可以添加自己需要的控件来布置主窗体)图示如下:


3. 代码编写:

先在代码文件中添加上面介绍的BitBlt函数的外部声明。

再添加按钮的OnClick事件处理函数,该函数就是实现屏幕捕捉的主要部分了。函数如下:

private void button1_Click(object sender, System.EventArgs e)

{

Graphics g1 = this.CreateGraphics();//获得窗体图形对象

Image MyImage = new Bitmap(this.ClientRectangle.Width, this.ClientRectangle.Height, g1);

Graphics g2 = Graphics.FromImage(MyImage);//创建位图图形对象

IntPtr dc1 = g1.GetHdc();//获得窗体的上下文设备

IntPtr dc2 = g2.GetHdc();//获得位图文件的上下文设备

BitBlt(dc2, 0, 0, this.ClientRectangle.Width, this.ClientRectangle.Height, dc1, 0, 0, 13369376);//写入到位图

 

g1.ReleaseHdc(dc1);//释放窗体的上下文设备

g2.ReleaseHdc(dc2);//释放位图文件的上下文设备

MyImage.Save(@"c:\Captured.jpg", ImageFormat.Jpeg);//保存为jpeg文件

MessageBox.Show("保存图片结束!");

}


4.到此为止,程序已经做完了。按Ctrl+F5可以试试效果如下图:




图片已经保存好了,看看屏幕捕捉的结果吧(如下图)!




  不过,这个程序只是捕捉到了程序自身的客户区,所以功能有限。当然,你也可以试着做个捕捉屏幕任何位置的程序!你只要改变源图像的宽度和高度即可,而这个宽度和高度当然可以由用户来选定。这样,一个自制的屏幕捕捉程序就出炉了。

  从上面的实例中,我们不难发现用C#编程实现一些基本功能还是非常容易的,真可谓是高效开发的好工具。所以,笔者希望有更多的人加入C#的行列,开发出更实用、更完善的软件

[1] [2] 下一页


  • 上一篇文章:

  • 下一篇文章: 没有了
  • 相关文章