深入c# GDI+简单绘图的具体操作步骤(二)

时间:2022-01-31 12:43:49 

在上一篇里已经向大家介绍了如何使用GDI+绘制简单的图像,这一片继续向大家介绍其它一些绘图知识.
1.首先我们来看下上一片中我们使用过的Pen.
Pen的属性主要有: Color(颜色),DashCap(短划线终点形状),DashStyle(虚线样式),EndCap(线尾形状), StartCap(线头形状),Width(粗细)等.
我们可以用Pen 来画虚线,带箭头的直线等


Pen  p = new  Pen(Color.Blue, 5);//设置笔的粗细为,颜色为蓝色
Graphics  g = this.CreateGraphics();
//画虚线
p.DashStyle = DashStyle.Dot;//定义虚线的样式为点
g.DrawLine(p, 10, 10, 200, 10);
//自定义虚线
p.DashPattern = new  float[] { 2, 1 };//设置短划线和空白部分的数组
g.DrawLine(p, 10, 20, 200, 20);
//画箭头,只对不封闭曲线有用
p.DashStyle = DashStyle.Solid;//恢复实线
p.EndCap = LineCap.ArrowAnchor;//定义线尾的样式为箭头
g.DrawLine(p, 10, 30, 200, 30);
g.Dispose();
p.Dispose();


以上代码运行结果:
深入c# GDI+简单绘图的具体操作步骤(二)

2.接下来我们来看下Brush的使用
作用:我们可以用画刷填充各种图形形状,如矩形、椭圆、扇形、多边形和封闭路径等,主要有几种不同类型的画刷:
•SolidBrush:画刷最简单的形式,用纯色进行绘制
•HatchBrush:类似于 SolidBrush,但是可以利用该类从大量预设的图案中选择绘制时要使用的图案,而不是纯色
•TextureBrush:使用纹理(如图像)进行绘制
•LinearGradientBrush:使用沿渐变混合的两种颜色进行绘制
•PathGradientBrush :基于编程者定义的唯一路径,使用复杂的混合色渐变进行绘制
我们这里只是简单介绍使用其中的几种:


Graphics g = this.CreateGraphics();
Rectangle rect = new Rectangle(10, 10, 50, 50);//定义矩形,参数为起点横纵坐标以及其长和宽
//单色填充
SolidBrush b1 = new SolidBrush(Color.Blue);//定义单色画刷         
g.FillRectangle(b1, rect);//填充这个矩形
//字符串
g.DrawString("字符串", new Font("宋体", 10), b1, new PointF(90, 10));
//用图片填充
TextureBrush b2 = new TextureBrush(Image.FromFile(@"e:\picture\1.jpg"));
rect.Location = new Point(10, 70);//更改这个矩形的起点坐标
rect.Width = 200;//更改这个矩形的宽来
rect.Height = 200;//更改这个矩形的高
g.FillRectangle(b2, rect);
//用渐变色填充
rect.Location = new Point(10, 290);
LinearGradientBrush b3 = new  LinearGradientBrush(rect, Color.Yellow , Color.Black , LinearGradientMode.Horizontal);
g.FillRectangle(b3, rect);


运行效果图:
深入c# GDI+简单绘图的具体操作步骤(二)

3.坐标轴变换
在winform中的坐标轴和我们平时接触的平面直角坐标轴不同,winform中的坐标轴方向完全相反:窗体的左上角为原点(0,0),水平向左则X增大,垂直下向则Y增大
深入c# GDI+简单绘图的具体操作步骤(二)
接下来,我们来实际操作下,通过旋转坐标轴的方向来画出不同角度的图案,或通过更改坐标原点的位置来平衡坐标轴的位置.


Graphics g = this.CreateGraphics();
//单色填充
//SolidBrush b1 = new SolidBrush(Color.Blue);//定义单色画刷         
Pen p = new Pen(Color.Blue,1);
//转变坐标轴角度
for (int i = 0; i < 90; i++)
{
    g.RotateTransform(i);//每旋转一度就画一条线
    g.DrawLine(p, 0, 0, 100, 0);
    g.ResetTransform();//恢复坐标轴坐标
}
//平移坐标轴
g.TranslateTransform(100, 100);
g.DrawLine(p, 0, 0, 100, 0);
g.ResetTransform();
//先平移到指定坐标,然后进行度旋转
g.TranslateTransform(100,200);
for (int i = 0; i < 8; i++)
{
g.RotateTransform(45);
g.DrawLine(p, 0, 0, 100, 0);
}
g.Dispose();


运行效果图:
深入c# GDI+简单绘图的具体操作步骤(二)

4.最后我们来看下Graphics这个画板上我们还可以画什么
其实我们上面用到的都是在画一些简单的图形,直线,矩形,扇形,圆孤等,我们还可以用它来绘制图片,这可以用它的DrawImage方法.这里我不详细讲解,大家有兴趣可以自己去MSDN了解下.我们后面会讲到的截图就会用到这个方法.

标签:c#,gdi绘图
0
投稿

猜你喜欢

  • 浅谈关于Java的GC垃圾回收器的一些基本概念

    2021-11-14 10:42:52
  • 关于c#中枚举类型支持显示中文的扩展说明

    2023-02-02 22:35:02
  • java整合SSM框架的图文教程

    2023-03-11 01:06:30
  • 通过源码角度看看AccessibilityService

    2023-07-25 09:31:43
  • Unity学习之FSM有限状态机

    2022-09-10 06:18:33
  • 关于Java的ArrayList数组自动扩容机制

    2021-11-26 13:12:46
  • 浅谈Java安全之C3P0链利用与分析

    2022-05-23 20:31:17
  • Java 基础语法中的逻辑控制

    2022-11-22 16:30:59
  • C#开发WinForm根据条件改变DataGridView行颜色

    2022-05-06 05:38:56
  • C/C++常用函数易错点分析

    2021-11-13 23:21:30
  • Spring定时任务中@PostConstruct被多次执行异常的分析与解决

    2022-08-20 07:28:22
  • C# 如何使用ajax请求

    2023-07-21 07:44:40
  • 关于WPF异步MVVM等待窗体的介绍

    2022-08-03 00:54:19
  • C#全局热键设置与窗体热键设置实例

    2022-09-30 05:38:52
  • 详解Mybatis通用Mapper介绍与使用

    2023-11-29 08:49:08
  • JetBrains IntelliJ IDEA 配置优化技巧

    2022-06-19 08:31:38
  • Flutter开发Widgets 之 PageView使用示例

    2023-06-24 13:23:34
  • SpringCloud之熔断器Hystrix的实现

    2021-09-21 01:39:26
  • java.lang.StackOverflowError出现的原因及解决

    2022-03-21 08:12:21
  • 在C#程序中对MessageBox进行定位的方法

    2022-03-04 18:45:26
  • asp之家 软件编程 m.aspxhome.com