欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > 名人名企 > 利用WPF绘制轮廓并保存为图片

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

2024/10/25 3:22:08 来源:https://blog.csdn.net/baidu_38621657/article/details/142340681  浏览:    关键词:利用WPF绘制轮廓并保存为图片

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.效果

 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com