C#使用Graphics在窗体上绘图

先上代码:

 public partial class Form1 : Form
    {
        Pen redPen = new Pen(Color.Red, 3);
        Size RectangleSize = new Size(50,50);
        Size EllipseSize = new Size(80, 60);
        public Form1()
        {
            InitializeComponent();
        }


        private void Form1_Load(object sender, EventArgs e)
        {
           
        }
        protected override void OnPaint(PaintEventArgs e)
        {
            base.OnPaint(e);
            if (e.ClipRectangle.Top<112 && e.ClipRectangle.Left<82)
            {
                Rectangle rectangel = new Rectangle(new Point(0, 0), RectangleSize);
                Rectangle Ellipse = new Rectangle(new Point(0, 50), EllipseSize);
                var dc = e.Graphics;


                dc.DrawRectangle(redPen, rectangel);
                dc.DrawEllipse(redPen, Ellipse);
            }
           
        }
    }

重写OnPaint的原因是,当窗体被其它窗体覆盖或都窗体有调整大小时,windows会自动调用OnPaint方法。在这个方法中绘图,可以使图画保持可见性。另外绘图类Graphics是会对GDI+编程,它的对象有可以是打印机,也可以是屏幕等。只要调用Graphics后,与其它设备的上下文交互,就不需要理会。

另外,windows的绘图数据是存在内存上的。而当窗体被覆盖时,会清除掉内存的数据。因此,当窗体被还原时,会重新载入数据,并重新绘图。为了提高程序运行的性能。可以增加ClipRectangle的判断。如果绘图区被覆盖了。那么就重新绘图。如果没有,则什么都不用做。这样程序运行的性能就提高了。

PaintEventArgs是绘图对象的一个传入参数。从这个参数中常用到两个对象。一个是绘图对象。这比使用this.CreateGraphics()要好一些。因为它可是指向一个引用,而不需要重建对象。这样就提高了程序的性能。另一个是ClipRectangle对象。它是一个距形,描绘一个剪切板,即被遮盖的区域。当它的顶点位于图形的区域内时,再调用绘图的方法。

如上面的代码,当窗体被加载时,就实现了绘图。即窗体被加载时,它的顶点应该就是绘图的范围之内。因此一加载就实现了绘图。

  • 0
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下是一个简单的绘图应用程序的示例代码: 首先,创建一个新的 C# 窗体应用程序。在窗体上添加一个 Panel 控件,用于绘制图形。 在窗体的代码文件中,添加以下代码: ```csharp using System; using System.Drawing; using System.Windows.Forms; namespace DrawingApp { public partial class MainForm : Form { private bool isDrawing = false; private Point startPoint; private Point endPoint; private Graphics graphics; public MainForm() { InitializeComponent(); graphics = panel.CreateGraphics(); } private void panel_MouseDown(object sender, MouseEventArgs e) { isDrawing = true; startPoint = e.Location; } private void panel_MouseMove(object sender, MouseEventArgs e) { if (isDrawing) { endPoint = e.Location; graphics.DrawLine(Pens.Black, startPoint, endPoint); startPoint = endPoint; } } private void panel_MouseUp(object sender, MouseEventArgs e) { isDrawing = false; } private void clearButton_Click(object sender, EventArgs e) { graphics.Clear(Color.White); } } } ``` 这个示例应用程序通过鼠标事件在 Panel 控件上绘制直线。isDrawing 变量用于跟踪是否正在绘制。startPoint 和 endPoint 变量用于存储直线的起点和终点。graphics 对象用于在 Panel 控件上绘制。 在窗体上添加一个清除按钮,单击该按钮时,清除 Panel 控件上的所有图形。将以下代码添加到清除按钮的 Click 事件处理程序中: ```csharp private void clearButton_Click(object sender, EventArgs e) { graphics.Clear(Color.White); } ``` 最后,在窗体的代码文件中,将 panel 控件的 MouseDown、MouseMove 和 MouseUp 事件分别绑定到 panel_MouseDown、panel_MouseMove 和 panel_MouseUp 事件处理程序。 在窗体设计器中,将 Panel 控件的 Dock 属性设置为 Fill,以便它占据整个窗体。 现在,运行应用程序,你可以在 Panel 控件上绘制直线,单击清除按钮可以清除所有绘图

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值