利用WPF绘制轮廓并保存为图片

news/2024/9/19 9:00:11 标签: wpf, c#, 轮廓提取, 保存图片, 几何算法

1.前言        

        WPF作为显示工具也挺好用,用C#开发应用软件会比较省力,当然也有其缺点,如在对效率要求较高的情况下有性能问题,本文记录用WPF绘制轮廓并保存为图片相关内容。

         显示效果也还不错,满足调试使用了,

2.代码

private static void DrawCurve(DrawingContext drawingContext, Pen pen, ICurve iCurve)
      {
         if(iCurve is HLine2d)
         {
            var point0 = iCurve.GetEndPoint(0);
            var point1 = iCurve.GetEndPoint(1);
            drawingContext.DrawLine(pen, new Point(point0.X, point0.Y), new Point(point1.X, point1.Y));
         }
         else if(iCurve is HArc2d)
         {
            var point0 = iCurve.GetEndPoint(0);
            var point1 = iCurve.GetEndPoint(1);
            var pt0 = new Point(point0.X, point0.Y);
            var pt1 = new Point(point1.X, point1.Y);

            var hArc = iCurve as HArc2d;
            Point center = new Point(hArc.Center.X, hArc.Center.Y);
            bool bLarge = hArc.Large;
            bool bClockWise = !hArc.ClockWise;  //窗体坐标系为左手
            double radius = hArc.Radius;

            PathFigure figure = new PathFigure() { StartPoint = pt0, IsFilled = false };
            PathGeometry path = new PathGeometry();
            path.Figures.Add(figure);
            SweepDirection dirSweep = bClockWise ? SweepDirection.Clockwise : SweepDirection.Counterclockwise;
            ArcSegment line = new ArcSegment(pt1, new Size(radius, radius), 0.0, bLarge, dirSweep, true);
            figure.Segments.Add(line);

            drawingContext.DrawGeometry(null, pen, path);
         }
      }
public static System.Drawing.Bitmap ConvertPatternToBitmap2(List<ICurve> lstICurve, List<List<ICurve>> lstIHatchProfile,
         System.Windows.Size imageSize, double? dLengthLabel = null, double? dWidthLabel = null)
      {
         var curvesTemp = new List<ICurve>();
         curvesTemp.AddRange(lstICurve);
         lstIHatchProfile?.ForEach(s => { curvesTemp.AddRange(s); });

         //  获取满布居中转换矩阵
         var matTrans = CurveUtils.GetScaleMatrix(curvesTemp, new Size(imageSize.Width, imageSize.Height - 12));

         //  转换到满布居中
         HMatrix3 mat = new HMatrix3();
         mat.M00 = matTrans.Value.M11;
         mat.M01 = matTrans.Value.M12;
         mat.M10 = matTrans.Value.M21;
         mat.M11 = matTrans.Value.M22;
         mat.M02 = matTrans.Value.OffsetX;
         mat.M12 = matTrans.Value.OffsetY;

         lstICurve = CurveUtils.CreateTransform(lstICurve, mat);
         for (int cntItem = 0; cntItem < lstIHatchProfile.Count; cntItem++)
         {
            lstIHatchProfile[cntItem] = CurveUtils.CreateTransform(lstIHatchProfile[cntItem], mat);
         }

         //  创建虚拟画布
         DrawingVisual drawingVisual = new DrawingVisual();
         DrawingContext drawingContext = drawingVisual.RenderOpen();
         Rect rect = new Rect(new Point(0, 0), imageSize);
         drawingContext.DrawRectangle(Brushes.White, (Pen)null, rect);
         Pen pen = new Pen(Brushes.Black, 2);
         foreach (var icurve in lstICurve)
         {
            DrawCurve(drawingContext, pen, icurve);
         }

         int cntPro = -1;
         foreach (var profile in lstIHatchProfile)
         {
            DrawProfile(drawingContext, Brushes.LightBlue, pen, profile);

            var boundBox = CurveUtils.GetBoundBox(profile);
            var dir = boundBox.MaxPoint - boundBox.MinPoint;
            double fontSize = Math.Max(15.0, Math.Min(dir.X, dir.Y) * 0.2);
            DrawText(drawingContext, (++cntPro).ToString(), boundBox.Center, fontSize);
         }

         DrawLabel(drawingContext, dLengthLabel, dWidthLabel, imageSize);

         drawingContext.Close();

         //截虚拟画布并生成为本地图片文件
         RenderTargetBitmap bmp = new RenderTargetBitmap((int)imageSize.Width, (int)imageSize.Height, 96, 96, PixelFormats.Pbgra32);
         bmp.Render(drawingVisual);
         BitmapEncoder encoder = new JpegBitmapEncoder();
         encoder.Frames.Add(BitmapFrame.Create(bmp));
         using (MemoryStream stream = new MemoryStream())
         {
            encoder.Save(stream);
            return new System.Drawing.Bitmap(stream);
         }

      }

 3.效果

 


http://www.niftyadmin.cn/n/5665298.html

相关文章

C语言--结构体(学习笔记)

内容借鉴于b站杜远超官方频道&#xff08;C语言结构体详解【干货】&#xff09; 首先C语言中定义变量格式为“数据类型 变量名”&#xff0c;如int a; float b;等等。 那么结构体则是将多个变量&#xff08;数据类型 变量名&#xff09;结合在一起的一种新的数据类型&…

pycharm 安装对应python版本的pip

pycharm: 调出终端命令行 AltF12 返回用户级别的Python安装基础目录。 python3 -m site --user-base 添加新的Python版本到update-alternatives sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.8 1 将python3的默认路径/usr/bin/python…

佰朔资本:股票中什么叫龙头?怎么找龙头股?

龙头&#xff0c;也便是龙头股&#xff0c;指的是某一工作中有必定影响力和号召力的股票&#xff0c;龙头股的涨跌一般对其他同工作板块股票的涨跌有必定演示和引导效果&#xff0c;是一种风向标一般的存在。龙头股的技能面表现和成交量都会比一同间的大盘和地块要强。 龙头股…

写一个自动化记录鼠标/键盘的动作,然后可以重复执行的python程序

import sys import threading import time from PyQt5.QtWidgets import * from auto_fun import * import pyautogui import pynput from PyQt5.QtCore import pyqtSignal from MouseModule import * from pynput import keyboardlocal_list [] # 保存操作坐标、动作、文本 …

南昌大学-计算机科学与技术专业-预推免-专业课(408)复试面试准备

一、数据结构与算法 1. 什么是时间复杂度和空间复杂度&#xff1f; 时间复杂度用于描述算法的执行时间与输入规模之间的关系&#xff0c;即当输入规模增加时&#xff0c;算法的运行时间如何变化。它主要衡量算法的效率和性能。 空间复杂度用于描述算法在运行过程中所需内存空…

golang学习笔记28——golang中实现多态与面向对象

推荐学习文档 golang应用级os框架&#xff0c;欢迎stargolang应用级os框架使用案例&#xff0c;欢迎star案例&#xff1a;基于golang开发的一款超有个性的旅游计划app经历golang实战大纲golang优秀开发常用开源库汇总想学习更多golang知识&#xff0c;这里有免费的golang学习笔…

家居小程序有什么用?

家居小程序在现代家居生活中扮演着越来越重要的角色&#xff0c;其功能和用途广泛且实用。以下是家居小程序的主要用途&#xff1a; 一、商品展示与购物 商品展示&#xff1a;家居小程序可以展示各种家居产品&#xff0c;包括家具、家电、装饰品等&#xff0c;用户可以通过分类…

计算机网络基础 - 应用层(3)

计算机网络基础 应用层P2P 应用P2P 体系结构的扩展性BitTorrent 协议torrenl 洪流BitTorrent 运行的过程 P2P文件共享应用非结构化 P2PDHT 结构化 P2P&#xff08;了解&#xff09; 视频流和内容分发网视频流化服务HTTP 流和 DASH内容分发网 CDN面临挑战CDN 概述CDN 操作过程集…