C# 把halcon中的任意图形HXLD在WPF中绘制出来

首先要知道在halcon中,可以通过get_contour_xld算子获取一个xld对象的所有坐标点:

然后问题就变成了把这些坐标点在WPF中绘制出来。

针对这些点集,WPF中可以使用Geometry对象表示;

Geometry抽象类有一个派生类:StreamGeometry:

如何:使用 StreamGeometry 创建形状 - WPF | Microsoft Learn

根据官网Demo,发现可以通过 StreamGeometryContext.PolyLineTo(IList<Point>, Boolean, Boolean) 方法描述整个点集。

按照这个逻辑,可以封装以下方法:

cs 复制代码
 internal static Geometry GetXldGeometry(HXLD xld)
 {
     if (xld == null || xld.Key == IntPtr.Zero)
     {
         return Geometry.Empty;
     }
     //将 HALCON 的 HXLDCont 轮廓(XLD 轮廓)转换为 WPF 的 StreamGeometry 对象
     if (xld is HXLDCont cont)
     {
         cont.GetContourXld(out HTuple row, out HTuple col);
         var points = GetXldPoints(row.DArr, col.DArr);
         StreamGeometry geometry = new StreamGeometry();
         var c = geometry.Open();
         c.BeginFigure(points[0], false, false);
         c.PolyLineTo(points, true, false);
         c.Close();
         return geometry;
     }
     else if (xld is HXLDPoly poly)
     {
         poly.GetPolygonXld(out HTuple row, out HTuple col, out _, out _);
         var points = GetXldPoints(row.DArr, col.DArr);
         StreamGeometry geometry = new StreamGeometry();
         var c = geometry.Open();
         c.BeginFigure(points[0], false, false);
         c.PolyLineTo(points, true, false);
         c.Close();
         return geometry;
     }
     else
     {
         var objClass = xld.GetObjClass();
         if (objClass == "xld_cont")
         {
             var cont1 = new HXLDCont(xld);
             cont1.GetContourXld(out HTuple row, out HTuple col);//row和col都有上千个点
             var points = GetXldPoints(row.DArr, col.DArr);
             StreamGeometry geometry = new StreamGeometry();
             var c = geometry.Open();
             c.BeginFigure(points[0], false, false);
             c.PolyLineTo(points, true, false);
             cont1.Dispose();
             c.Close();
             return geometry;
         }
         else if (objClass == "xld_poly")
         {
             var poly1 = new HXLDPoly(xld);
             poly1.GetPolygonXld(out HTuple row, out HTuple col, out _, out _);
             var points = GetXldPoints(row.DArr, col.DArr);
             StreamGeometry geometry = new StreamGeometry();
             var c = geometry.Open();
             c.BeginFigure(points[0], false, false);
             c.PolyLineTo(points, true, false);
             poly1.Dispose();
             c.Close();
             return geometry;
         }
         else
         {
             return Geometry.Empty;
         }
     }
 }

 internal static IList<Point> GetXldPoints(double[] row, double[] column)
 {
     if (row == null || column == null || row.Length != column.Length)
     {
         return null;
     }
     //var rowSpan = new Span<double>(row);
     //var colSpan = new Span<double>(column);
     List<Point> points = new List<Point>(row.Length);
     for (int i = 0; i < row.Length; i++)
     {
         // Halcon: (row, column) 像素中心
         // .NET System.Drawing: (x, y) 像素左上角
         points.Add(new Point(column[i] + 0.5, row[i] + 0.5));
     }
     return points;
 }

得到Geometry对象之后,可以通过GeometryDrawing 对象再包装一层:

cs 复制代码
 GeometryDrawing drawing = new GeometryDrawing
 {
     Geometry = geometry
 };

然后通过DrawingContext类中提供的DrawDrawing方法绘制GeometryDrawing对象:

(GeometryDrawing继承自Drawing)

相关推荐
黄宝康14 分钟前
sublimetext 运行python程序
开发语言·python
m0_7482500325 分钟前
C++ 官方文档与标准
开发语言·c++
zh_xuan39 分钟前
kotlin 类继承的语法2
开发语言·kotlin
DYS_房东的猫1 小时前
《 C++ 零基础入门教程》第6章:模板与 STL 算法 —— 写一次,用万次
开发语言·c++·算法
诗意地回家1 小时前
淘宝小游戏反编译
开发语言·前端·javascript
wangkay881 小时前
【Java 转运营】Day04:抖音新号起号前准备全指南
java·开发语言·新媒体运营
点云SLAM1 小时前
C++ 静态初始化顺序问题(SIOF)和SLAM / ROS 工程实战问题
开发语言·c++·slam·静态初始化顺序问题·工程实战技术·c++static 关键字
D3bugRealm1 小时前
MATLAB解决物理问题:从基础运动学到进阶力学的实战指南
开发语言·其他·matlab
小李独爱秋1 小时前
计算机网络经典问题透视:TLS协议工作过程全景解析
运维·服务器·开发语言·网络协议·计算机网络·php
pen-ai2 小时前
打通 Python 与 C++ 的参数传递机制
开发语言·c++·python