网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > C#应用
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.在dotnet下用c#编写下载器.
.用.NET开发MSN聊天机器人.
.C#一个象棋游戏程序.
.C#几种常用的排序算法.
.利用c#制作简单的留言板(2) .
.C#算法设计与分析-寻找素数.
.使用C#开发用户控制.
.用Visual C#获得计算机名称和IP.
.在指定应用程序域中执行代码.
.C#程序模拟鼠标操作 [Simulate M.
.C#中利用Markup Service实现HTML.
..NET中多线程的同步资源访问.
.C#操作MySQL中文乱码的解决方案.
.C#利用正则表达式实现字符串搜索.
.C#中Delegate浅析与思考.
.Sql server存储过程和C#分页类简.
.C#减少图片文件大小和尺寸.
.分享动态生成文字图片解决方案.
.C#向ACCESS数据库插入图片 .
.用 C# 开发 SQL Server 2005 的自.

C#实现类似qq的屏幕截图程序

发表日期:2006-12-25


因为近来想写个类似于远程桌面监控的程序,该程序中要用到屏幕捕捉.为实现该程序的一部分功能,做了个小DEMO.程序很简单,用到的技术也不多,只能实现类似qq的截图功能(方法虽然很笨)
程序流程如下:

1.截取整个屏幕并保存
2.新开一个全屏窗口,将保存的屏幕作为背景
3.鼠标拖动改变截取范围,右键取消
4.双击截取,保存在粘贴板,全屏窗口关闭

好了,下面的是代码部分

首先新建一个项目ScreenCutter(VS2005),将窗体名改为MainForm,再新建一个窗体ScreenBody.
添加一个按钮btnCutter到ScreenCutter并添加按钮事件:
        private void btnCutter_Click(object sender, EventArgs e)
        {
            Image img = new Bitmap(Screen.AllScreens[0].Bounds.Width, Screen.AllScreens[0].Bounds.Height);
            Graphics g = Graphics.FromImage(img);
            g.CopyFromScreen(new Point(0, 0), new Point(0, 0), Screen.AllScreens[0].Bounds.Size);
            ScreenBody body = new ScreenBody();
            body.BackgroundImage = img;
            body.Show();
        }Screen.AllScreens[0]是获取当前所有设备窗口的第一个,我这里只有一个显示器,当然我就是第一个.
利用Graphics的CopyFromScreen函数获取当前屏幕.

好了,现在按下按钮全屏窗口就会出来了.

下面讲全屏窗口ScreenBody,首先设置窗体的FormBorderStyle为None,然后声明以下变量
private Graphics MainPainter;  //主画笔
private Pen pen;               //就是笔咯
private bool isDowned;         //判断鼠标是否按下
private bool RectReady;         //矩形是否绘制完成
private Image baseImage;       //基本图形(原来的画面)
private Rectangle Rect;        //就是要保存的矩形
private Point downPoint;        //鼠标按下的点
int tmpx;                    
int tmpy;
之后就是窗体的鼠标函数了,里面很多代码都没有作出整理,看了一下,整理后的代码应该会更少更精简的

 

private void ScreenBody_DoubleClick(object sender, EventArgs e)
{
    if (((MouseEventArgs)e).Button == MouseButtons.Left &&Rect.Contains(((MouseEventArgs)e).X, ((MouseEventArgs)e).Y))
    {
        //保存的时候有很多种方法的......我这里只用了这种
        Image memory = new Bitmap(Rect.Width, Rect.Height);
        Graphics g = Graphics.FromImage(memory);
        g.CopyFromScreen(Rect.X + 1, Rect.Y + 1, 0, 0, Rect.Size);
        Clipboard.SetImage(memory);
        this.Close();
    }
}

private void ScreenBody_MouseDown(object sender, MouseEventArgs e)
{
    if (e.Button == MouseButtons.Left)
    {
        isDowned = true;
       
        if (RectReady == false)
        {
            Rect.X = e.X;
            Rect.Y = e.Y;
            downPoint = new Point(e.X, e.Y);
        }
        if (RectReady == true)
        {
            tmpx = e.X;
            tmpy = e.Y;
        }
    }
    if (e.Button == MouseButtons.Right)
    {
        if (RectReady != true)
        {
            this.Close();
            return;
        }
        MainPainter.DrawImage(baseImage, 0, 0);
        RectReady = false;
    }

}

private void ScreenBody_MouseUp(object sender, MouseEventArgs e)
{
    if (e.Button == MouseButtons.Left)
    {
        isDowned = false;
        RectReady = true;
    }
}

private void ScreenBody_MouseMove(object sender, MouseEventArgs e)
{

    if (RectReady == false)
    {
        if (isDowned == true)
        {
            Image New = DrawScreen((Image)baseImage.Clone(), e.X, e.Y);
            MainPainter.DrawImage(New, 0, 0);
            New.Dispose();
        }
    }
    if (RectReady == true)
    {
        if (Rect.Contains(e.X, e.Y))
        {
            //this.Cursor = Cursors.Hand;
            if (isDowned == true)
            {
                //和上一次的位置比较获取偏移量
                Rect.X = Rect.X + e.X - tmpx;
                Rect.Y = Rect.Y + e.Y - tmpy;
                //记录现在的位置
                tmpx = e.X;
                tmpy = e.Y;
                MoveRect((Image)baseImage.Clone(), Rect);
            }
        }
    }
   
}

private void ScreenBody_Load(object sender, EventArgs e)
{
    this.WindowState = FormWindowState.Maximized;
    MainPainter = this.CreateGraphics();
    pen = new Pen(Brushes.Blue);
    isDowned = false;
    baseImage = this.BackgroundImage;
    Rect = new Rectangle();
    RectReady = false;
}


辅助函数
本来应该写更多的辅助函数的,将窗体响应函数里面的代码放到里面来,不过本人很懒,就这样将就了.呵呵


private void DrawRect(Graphics Painter, int Mouse_x, int Mouse_y)
{
    int width = 0;
    int heigth = 0;
    if (Mouse_y < Rect.Y)
    {
        Rect.Y = Mouse_y;
        heigth = downPoint.Y - Mouse_y;
    }
    else
    {
        heigth = Mouse_y - downPoint.Y;
    }
    if (Mouse_x < Rect.X)
    {
        Rect.X = Mouse_x;
        width = downPoint.X - Mouse_x;
    }
    else
    {
        width = Mouse_x - downPoint.X;
    }
    Rect.Size = new Size(width, heigth);
    Painter.DrawRectangle(pen, Rect);
}

private Image DrawScreen(Image back, int Mouse_x, int Mouse_y)
{
    Graphics Painter = Graphics.FromImage(back);
    DrawRect(Painter, Mouse_x, Mouse_y);
    return back;
}
private void MoveRect(Image image, Rectangle Rect)
{
    Graphics Painter = Graphics.FromImage(image);
    Painter.DrawRectangle(pen, Rect.X, Rect.Y, Rect.Width, Rect.Height);
    DrawRects(Painter);
    MainPainter.DrawImage(image, 0, 0);
    image.Dispose();
}

到这里,代码就算是写完了,运行
http://www.cnblogs.com/kevin-wu/archive/2006/12/24/601989.html

上一篇:C#重用UDP端口号 人气:5227
下一篇:C#中使用存储过程中的返回值 人气:6690
浏览全部C#的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐