Dot Net下实现屏幕图像差异获取v1.0

简介:

 开发平台:VS 2008,Windows xp sp2

      效果截图:

 


图1 软件界面图
 

图2 差异结果图

      图片说明:第一幅图展示的是我所实现的这个软件的最终效果图,通过菜单栏的按键可以选择两幅有差异的图片(要求是相同大小,24位或以上颜色,目的是模仿系统屏幕截图),然后对图片进行比较后,就会截取出差异部分,并将该图片保存到E盘根目录,也就是上面的差异结果图。

 

      最近项目中要实现屏幕传输和控制功能,其中主要的就是屏幕传输功能。“不就是屏幕传输嘛,简单呀~~建立个线程,隔一定时间截取一下屏幕的图片,然后发送给对方不就成了。”这是我最初的想法,我也按照这个办法做了,当看到屏幕从一台电脑成功传到了另一台电脑时(局域网内),我有点高兴,心里暗想“原来远程控制也不过如此”。当然,事情的发展并不如预期中那样完美,事实上,我所实现的远程控制几乎没有任何价值,因为延迟太大,一副屏幕的截图从截取到发送到再显示出来,整个过程至少要耗费2秒多的时间。这是什么概念呢?我们可以比较一下,标准的卡通片是24fps,也就是每秒24帧,这样才会流畅;如果你玩过极品飞车,会发现极品飞车一般的帧数会保持在40以上(之所以说一般,是因为帧数和具体的显卡有关)。而现在我所实现的这个帧数是0.5,极品飞车的帧数是我的80倍,当你玩极品飞车的时候,画面每2秒才刷新一次,你就会知道我的实现有多烂了。不过这些帧数都是对流畅性要求极高的环境来说的,对于远程控制这种每秒画面变化不大的情况,就没必要这么高要求了,只要能保持在6帧每秒就几乎可以达到流畅的感受了。

     屏幕传输主要分为“截图->压缩->传输->解压->显示”这几个步骤,传输、压缩、解压及显示几乎很难有明显的性能提升,因此主要能改进的就是“截图”这个过程。单纯的全屏截图,我尝试过最快每秒也就7、8帧,无法实现更高的速度。(我截屏利用的GDI+方式,而并非是用DirectX来做,DirectX更能发挥显卡的性能,但是我没有尝试过。)7、8帧的速度是不是可以了呢?这是不够的,因为这只是单纯的截图,并没有加上网络传输、压缩解压等,因此必须要有更快的速度。而且,此种方式,每秒需要传输的数据量是相当惊人的。拿我的电脑1280*800的分辨率来说,按24位颜色质量存储的话,一张图需要2.9M,按每秒7帧来算需要20.3M。每秒需要传输20.3M,这对于现有的网络带宽来说是承受不了的。

      翻阅了很多网上达人的文章,发现通常用于屏幕传输的方法主要是传输前后两幅图片的不同之处。而查找不同之处的算法又主要有两类:隔行查找和分块比较。翻阅了很多,主要是以Delphi下的实现为主,尤其以DG老大为代表的实现方式。由于本人从未用过Delphi,对C++也有多年未用了,因此在研究DG老大的代码(DGScreenSpy_0.2c)上着实花了不少时间,现在也只能算是懂了个基本。在我自己的实现方式,并非只是简单的对DG老大代码的翻译,根据我自己的理解,我的算法思路如下:

      首先对两张图片的数据按照从上到下从左到右的方式进行扫描,考虑到在实际的环境下,一个图标或一个窗口肯定会横向和纵向跨好几个像素,因此用了两个参数来分别表示步进值。扫描的过程中用一个矩形区域来表示当前变化的范围,这个范围在整个扫描过程中会随时进行调整以适应变化的区域。

      下面举个例子来说明区域的设置:从第0行开始扫描,没有发现该行内的像素不同,加上步进的数值后(假如是3),扫描接着从第4(3+1)行开始,在该行的扫描中发现第2个像素到第10个像素(基数为0)都不同,于是设置矩形的Top边为4,Left为2,Right为11,Bottom为5。接着扫描第8行,发现这一行中第0个像素到第8个像素不一样,则调整矩形的区域(Top:4,Left:0,Right:11,Bottom:9),依次类推直到扫描到一行全都相同或扫描完最后一行时,这个矩形的区域则正式确定。这样该区域的图形就是最小的变化范围。

      这是大概的思路,具体的大家可以参考我的代码。按照这种方式,可以获取变化的最小区域,如果变化不多,则图片数据量明显变少,如果变化很多或干脆整个屏幕都不一样,那图片数据量仍然会很大,因此还需要进一步对图片数据进行压缩或采取降低图片颜色质量的方式,QQ的远程屏幕传输就降低了图片的质量,估计其图片质量为16位每像素。

      为了专门研究图片差异的获取,所以并没有实现其他诸如压缩、传输的功能。其中对像素的比较用的是BitmapData.Scan0来获取像素指针的方式进行比较,因为这样比较速度最快。我在测试时发现,我的这种实现方式(以我设置的步进值为基准)一次比较需要0.15秒左右(包括了存储差异部分到本地文件的时间,大约耗时0.04秒),速度上仍然有待提升。改变步进值可以适当的调节速度,但也会影响到变化区域的准确性。

     本着合作共赢的想法,提供我的代码供大家参考,希望大家在看了我的思路和代码后,能提出宝贵的意见,我会根据您的意见思路对代码进行不断改进,每一次重大改进我都会把代码发布出来。希望能早日完成一款Dot Net下的远程控制佳作。以下是核心代码:

 

FindDifferences

 项目打包下载:http://files.cnblogs.com/stg609/Pic.rar

 参考:http://iamgyg.blog.163.com/








本文转自stg609博客园博客,原文链接:http://www.cnblogs.com/stg609/archive/2009/11/28/1612778.html,如需转载请自行联系原作者

目录
相关文章
.NET Core:使用ImageSharp跨平台处理图像
一.简述 ImageSharp是一个新的跨平台2D图形API,旨在处理图像而不使用System.Drawing。 二.安装 目前ImageSharp还是处于alpha版本,所以我们需要在nuget中添加它的地址:https://www.
2348 0
|
8月前
|
机器学习/深度学习 数据采集 存储
【3-D深度学习:肺肿瘤分割】创建和训练 V-Net 神经网络,并从 3D 医学图像中对肺肿瘤进行语义分割研究(Matlab代码实现)
【3-D深度学习:肺肿瘤分割】创建和训练 V-Net 神经网络,并从 3D 医学图像中对肺肿瘤进行语义分割研究(Matlab代码实现)
141 0
|
11月前
|
机器学习/深度学习 算法 光互联
致敬何凯明的暗通道去雾算法 | NAS-Net: 基于非对齐监督的图像去雾框架
致敬何凯明的暗通道去雾算法 | NAS-Net: 基于非对齐监督的图像去雾框架
246 0
|
文字识别 数据处理 C++
使用.NET开发一个屏幕OCR工具
本文将介绍使用.NET开发的一款桌面截图 OCR 工具,软件已开源,地址:[https://github.com/sangyuxiaowu/Snipping_OCR](https://github.com/sangyuxiaowu/Snipping_OCR)
179 0
使用.NET开发一个屏幕OCR工具
|
安全 搜索推荐 数据安全/隐私保护
用.NET设计一个假装黑客的屏幕保护程序
本文主要介绍屏幕保护程序的一些相关知识,以及其在安全方面的用途,同时介绍了如何使用 .NET 开发一款屏幕保护程序,并对核心功能做了介绍,案例代码开源:https://github.com/sangyuxiaowu/HackerScreenSaver
141 0
用.NET设计一个假装黑客的屏幕保护程序
【STM32 .NET MF开发板学习-29】摄像头蓝牙图像远程获取
目前M3的开发板,虽然前段时间可以支持WPF了,但是SRAM毕竟还是有限,所以从串口摄像头直接获取的jpg图像,并不能在LCD屏上显示出来(在模拟器上没有这个问题,可以直接呈现),所以我借助蓝牙接口,把另一个串口获取的图像数据发送到一台带蓝牙的PC上,PC上的程序否则实现数据接收,并把图像呈现出来。
706 0
|
PHP Windows
一起谈.NET技术,使用DeeepZoom Composer进行富图像应用的开发(翻译--2)
  Deep Zoom程序设计      到目前为止,你已经见识了Deep Zoom Composer工具,也见到了Deep Zoom 多图像的浏览器应用程序。不过你可能还需要知道怎样设计这样的程序。   因此,在这一节中,你将能够在Silverlight中开发Deep Zoom程序,可以用Deep Zoom Composer工具来创建图像瓷片,而且你也能够将它们集成到你自己的Silverlight应用程序中,下面的过程将显示MultiScaleImage控件来展示这个过程。
1024 0
|
Web App开发 PHP
一起谈.NET技术,使用DeeepZoom Composer进行富图像应用的开发(翻译--1)
  富图像应用(第一部分)   在这章,你会学到下列内容: 使用Deep Zoom Composer 工具建立高质量、高度友好的图像。 组合为平滑、可缩放的全景图像。 建立以编程形式方式控制的深度缩放的Silverlight应用程序。
1105 0
|
存储 测试技术