原文:winform屏幕截图

屏幕截图是一个比较常用的功能,在项目中出现的比例也比较高,至少我做过的每个项目都有屏幕截图这个功能,从全屏截图到区域截图都有出现过。当然区域截图已然包含了全屏截图。

全屏截图方式有好几种,调用API截图、调用操作系统的截图然后到剪切板去取(当然这种方式几乎没人会去用)、用Graphics去画屏幕等等。

下面上Graphics画屏幕的代码,毕竟这种方式代码量最少。

            //截取屏幕
Bitmap myImage = new Bitmap(Screen.PrimaryScreen.Bounds.Width, Screen.PrimaryScreen.Bounds.Height);
Graphics g = Graphics.FromImage(myImage);
g.CopyFromScreen(new Point(0, 0), new Point(0, 0), new Size(Screen.PrimaryScreen.Bounds.Width, Screen.PrimaryScreen.Bounds.Height));
g.Dispose();

上面的代码即可截取当前屏幕的图像。注:由于WPF是使用DirectX进行渲染的,此方式截图在部分系统会截图不到wpf的窗体。(win7,windows server2008,windows vista均能截取到wpf窗体,windows XP无法截取到WPF窗体,原因可能是windows xp出现时还没有WPF呢)

实现区域截图,主要有四个步骤,一截取全屏,弹出遮罩层,画选择区,截取选择区域

一、截取全屏可用上面代码实现,这里就不写了。

二、弹出遮罩层

遮罩层的目的是用来画截图区域,一般采用半透明方式。代码如下:

            this.BackColor = Color.Gray;
this.Opacity = 0.5;
this.FormBorderStyle = FormBorderStyle.None;
this.WindowState = FormWindowState.Maximized;

  设置窗体背景颜色,通明度,边框样式及使其最大化。即可弹出全屏遮罩层。

三、画选择区

  这个就是截屏中最重要的部分了

  我们需要在窗体中加入pictureBox控件,且Dock属性设置为Fill,这样才能在屏幕上画选择区

跟随鼠标在 pictureBox的图片上画矩形
private int intStartX = ;
private int intStartY = ;
private bool isMouseDraw = false; private void pictureBox_Src_MouseDown(object sender, MouseEventArgs e)
{
isMouseDraw = true; intStartX = e.X;
intStartY = e.Y;
} private void pictureBox_Src_MouseMove(object sender, MouseEventArgs e)
{
if (isMouseDraw)
{
try
{
Graphics g = this.pictureBox_Src.CreateGraphics();
//清空上次画下的痕迹
g.Clear(this.pictureBox_Src.BackColor);
Brush brush = new SolidBrush(Color.Red);
Pen pen = new Pen(brush, );
pen.DashStyle = DashStyle.Solid;
g.DrawRectangle(pen, new Rectangle(intStartX > e.X ? e.X : intStartX, intStartY > e.Y ? e.Y : intStartY, Math.Abs(e.X - intStartX), Math.Abs(e.Y - intStartY)));
g.Dispose();
}
catch (Exception ex)
{
ex.ToString();
}
}
} private void pictureBox_Src_MouseUp(object sender, MouseEventArgs e)
{
isMouseDraw = false; intStartX = ;
intStartY = ;
}

当然这只是在图片上画了一个红色的矩形,没法二次调整矩形大小,移动矩形,且画图时会不停的清除画下的痕迹,导致屏幕闪烁,且平时使用的屏幕截图在选择区的区域亮度都会高些,这些都没实现,不过既然能画区域了那这些就都不是问题了,只需稍作修改即可,以下给出部分修改代码:

填充选择区

SolidBrush soldwhite = new SolidBrush(Color.White);
Rectangle rec = new Rectangle(StartX, StartY, ScreenWidth, ScreenHeight); g.FillRectangle(soldwhite, rec);//用来填充矩形区域

屏幕闪烁

清除时屏幕闪烁是由于清除的整个图片,然后在重新绘制的,这样若加上填充区设置为白色,我们能看到填充区域闪烁的很厉害,解决方式为采用填充的方式清除选择区域外的部分,这样整个图片总共分5此填充和一次划线。

            Graphics g = this.pictureBox1.CreateGraphics();
//清空上次画下的痕迹
// g.Clear(this.pictureBox1.BackColor);
g.FillRectangle(soldgray, 0, 0, pictureBox1.Width, StartY);//清除上
g.FillRectangle(soldgray, 0, StartY + ScreenHeight, pictureBox1.Width, pictureBox1.Height - (StartY + ScreenHeight));//清除下
g.FillRectangle(soldgray, 0, StartY, StartX, ScreenHeight + 1);//清除左
g.FillRectangle(soldgray, StartX + ScreenWidth, StartY, pictureBox1.Width - (StartX + ScreenWidth), ScreenHeight + 1);//清除右

二次调整大小及选择区移动

当我们对区域进行选择后,想二次调整大小通常会看到鼠标样式变化,表示可以对其进行修改或移动

        /// <summary>
/// 设置鼠标样式
/// </summary>
/// <param name="p"></param>
private void SetCursorStyle(Point p)
{
if (p.X > StartX && p.X < StartX + ScreenWidth && p.Y > StartY && p.Y < StartY + ScreenHeight)
{this.Cursor = Cursors.SizeAll;
}
else if (p.X >= StartX - && p.X <= StartX && p.Y >= StartY - && p.Y <= StartY)
{this.Cursor = Cursors.SizeNWSE;
}
else if (p.X >= StartX + ScreenWidth && p.X <= StartX + ScreenWidth + && p.Y <= StartY + ScreenHeight + && p.Y >= StartY + ScreenHeight)
{this.Cursor = Cursors.SizeNWSE;
}
else if ((p.X >= StartX + ScreenWidth && p.X <= StartX + ScreenWidth + && p.Y >= StartY - && p.Y <= StartY))
{this.Cursor = Cursors.SizeNESW;
}
else if (p.X >= StartX - && p.X <= StartX && p.Y <= StartY + ScreenHeight + && p.Y >= StartY + ScreenHeight)
{this.Cursor = Cursors.SizeNESW;
}
else
{this.Cursor = Cursors.Default;
}
}

这是设置鼠标在选择区域内的样式和四个角的样式,若是在4个角,只需将起始坐标设置好之后和原来一样画区域就行,若是在区域中,移动选择区则需根据当前坐标和开始坐标计算出差值,在移动时更改开始坐标,固定宽高画区域即可,若移动到屏幕边缘需加上判断。

四、截取选择区域

画好区域后,需要选择是否截取,通常会给出按钮选择我们只需在MouseUP和MouseDown事件中加上按钮的隐藏和显示即可,显示时根据选择区计算显示的坐标位置。

截取选择区代码

Bitmap map = myImage.Clone(new Rectangle(StartX, StartY, ScreenWidth, ScreenHeight), System.Drawing.Imaging.PixelFormat.Format32bppArgb);

这样即可实现简单的区域截图了。

winform屏幕截图的更多相关文章

  1. Winform屏幕截图保存C#代码

    代码如下: using System.Runtime.InteropServices; using System.Drawing.Imaging; [System.Runtime.InteropSer ...

  2. 16Aspx.com源码2014年7月详细

            Web电子商务网(三层)V2.0源码 2014-07-31   [VS2010] 源码介绍: Web电子商务网(三层)V2.0源码 源码描述: 一.源码特点     采用三层架构开发, ...

  3. WinForm GDI+ 资料收集

    UI(User Interface)编程在整个项目开发过程中是个颇为重要的环节,任何好的解决方案若没有良好的用户界面呈现给最终用户,那么就算包含了最先进的技术也不能算是好程序.UI编程体现在两个方面, ...

  4. winform实现矩形框截图

    使用方法如下: private void button1_Click(object sender, EventArgs e) { s.GerScreenFormRectangle(); } priva ...

  5. C# WinForm开发系列 - GDI+【转】

    http://blog.csdn.net/blue_sky6/article/details/53811435?locationNum=6&fps=1 C# WinForm开发系列 - GDI ...

  6. 解决WinForm屏幕缩放适配只需修改两个Form的两个属性

    最近要做一个windows下截屏识别文字的程序,调试发现截取的图像显示不完整. 输出了Screen.PrimaryScreen.Bounds.Width获取的值,结果与实际分辨率不同,所以确定了与我的 ...

  7. 使用Python保存屏幕截图(不使用PIL)

    起因 在极客学院讲授<使用Python编写远程控制程序>的课程中,涉及到查看被控制电脑屏幕截图的功能. 如果使用PIL,这个需求只需要三行代码: from PIL import Image ...

  8. 使用 .NET WinForm 开发所见即所得的 IDE 开发环境,实现不写代码直接生成应用程序

    直接切入正题,这是我09年到11年左右业余时间编写的项目,最初的想法很简单,做一个能拖拖拽拽就直接生成应用程序的工具,不用写代码,把能想到的业务操作全部封装起来,通过配置的方式把这些业务操作组织起来运 ...

  9. 逆天通用水印支持Winform,WPF,Web,WP,Win10。支持位置选择(9个位置 ==》[X])

    常用技能:http://www.cnblogs.com/dunitian/p/4822808.html#skill 逆天博客:http://dnt.dkil.net 逆天通用水印扩展篇~新增剪贴板系列 ...

随机推荐

  1. 【网络流量最大流量】poj3281Dining

    /* EK算法版本号,哦,慢.....见下文dinic版本号 ----------------------------------------- 最大的问题是网络流量问题 -------------- ...

  2. 追索权 Eclipse + NDK error: stray &#39;\24&#39; in program

    [size=16px][b][color=#FF0000]追索权 Eclipse + NDK  error: stray '\24' in program[/color][b][/b][/b][/si ...

  3. FireFox VS Chrome 之 调试篇

    一个完美的调试工具,FireBug! 精确跟踪每一步.仅仅要按下图所看到的,选择"脚本",然后在下方选择脚本所在的文件就可以对该文本的运行进行断点跟踪. 而且仅当一个线程运行结束后 ...

  4. Nginx + IIS

    Nginx + IIS 配置,实现负载均衡   当你的Web应用程序访问量大的时候,一台服务器可能会因为压力过大而无法处理所有的请求.此时,可以增加服务器,采用负载均衡来分担所有的请求.关于Nginx ...

  5. c#-RTF文本编辑器

    1".RTF"什么? 多信息文本格式 (RTF) 是一种方便于不同的设备.系统查看的文本和图形文档格式. RTF 使用美国国内标准协会 (ANSI). PC-8. Macintos ...

  6. 使用Canvas和Paint自己绘制折线图

    主要用于Canvas一个特别简单的小demo. 能够手动点击看每一个月份的数据.很easy.就是用paint在canvas上画出来的. 主要内容就是计算左边价格的位置,以下日期的位置,三根虚线的位置, ...

  7. nodejs 复制、移动文件

    对路径没有做验证 复制文件 var fs = require('fs'); var path = require('path'); var fileName = "coverflow-3.0 ...

  8. 【Testin实验室】MoiMark安卓中国终端体验性能排行榜(11月报)

    [Testin实验室]MoiMark安卓中国终端体验性能排行榜(11月报) 2014/11/20 · Testin · 实验室报告 11月报要点: 新增机型Note4强势夺得第一.三星Note4以多个 ...

  9. HOWTO: 为GitHub for Windows指定代理服务器(转)

    If the command line way of configuring your proxy server doesn't work, you can probably just edit .g ...

  10. Oracle 11g oracle客户端(32位)PL/SQL develepment的安装配置

    Oracle 11g+oracle客户端(32位)+PL/SQL develepment的安装配置 之前一直想学Oracle,可是就是安装配置Oracle一直未成功,让人很苦恼,特别是什么监听器什么的 ...