WPF通过代码DrawingContext绘制不同的图形(圆形,矩形,菱形,十字交错形)

这边通过接口来实现,使用的时候继承这个接口即可使用

 public interface IShapeDraw
 {
     void DrawPolygon(DrawingContext dc, Brush brush, Pen? p, List<Point> points)
     {
         if (!points.Any())
             return;

         // 创建一个路径,并添加三角形的点
         var geometry = new StreamGeometry();
         using (var geometryContext = geometry.Open())
         {
             geometryContext.BeginFigure(points[0], true, true);
             for (var i = 1; i < points.Count; i++)
             {
                 geometryContext.LineTo(points[i], true, false);
             }
         }
         // 绘制三角形并填充颜色
         dc.DrawGeometry(brush, p, geometry);
     }

     /// <summary>
     /// 三角形
     /// </summary>
     void DrawTriangle(DrawingContext dc, Brush brush, Pen? p, Point point1, Point point2, Point point3)
     {
         DrawPolygon(dc, brush, p, new List<Point>() { point1, point2, point3 });
     }

     /// <summary>
     /// 棱形
     /// </summary>
     void DrawDiamond(DrawingContext dc, Brush brush, Pen? p, Point point1, Point point2, Point point3, Point point4)
     {
         DrawPolygon(dc, brush, p, new List<Point>() { point1, point2, point3, point4 });
     }

     /// <summary>
     /// 十字型图
     /// </summary>
     void DrawCross(DrawingContext dc, Brush brush, Pen? p, List<Point> horizontal2Point, List<Point> vertical2Point)
     {
         if (horizontal2Point.Count != 2)
             return;
         if (vertical2Point.Count != 2)
             return;

         // 定义十字型的线段
         var horizontalStart = horizontal2Point[0];
         var horizontalEnd = horizontal2Point[1];

         var verticalStart = vertical2Point[0];
         var verticalEnd = vertical2Point[1];

         // 创建路径,并添加线段
         var geometry = new StreamGeometry();
         using (var geometryContext = geometry.Open())
         {
             geometryContext.BeginFigure(horizontalStart, false, false);
             geometryContext.LineTo(horizontalEnd, true, false);

             geometryContext.BeginFigure(verticalStart, false, false);
             geometryContext.LineTo(verticalEnd, true, false);
         }

         dc.DrawGeometry(brush, p, geometry);
     }

     /// <summary>
     /// 绘制圆弧
     /// </summary>
     /// <param name="dc"></param>
     /// <param name="center">中心点</param>
     /// <param name="startAngle">其实角度</param>
     /// <param name="endAngle">截止角度</param>
     /// <param name="radius">半径</param>

     void DrawArc(DrawingContext dc, Pen pen, Point center, double startAngle, double endAngle, double radius)
     {
         // 使用ArcSegment绘制圆弧
         var arcGeometry = new PathGeometry();
         var arcFigure = new PathFigure
         {
             StartPoint = new Point(center.X + radius * Math.Cos(startAngle * Math.PI / 180), center.Y + radius * Math.Sin(startAngle * Math.PI / 180)),
             IsClosed = false,
             IsFilled = true
         };
         arcFigure.Segments.Add(new ArcSegment(new Point(center.X + radius * Math.Cos(endAngle * Math.PI / 180), center.Y + radius * Math.Sin(endAngle * Math.PI / 180)), new Size(radius, radius), 0, Math.Abs(endAngle - startAngle) > 180, SweepDirection.Clockwise, true));
         arcGeometry.Figures.Add(arcFigure);

         // 绘制圆弧
         dc.DrawGeometry(Brushes.Transparent, pen, arcGeometry);
     }


  • 15
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

搬砖的诗人Z

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值