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)

相关推荐
爱码小白几秒前
Python 异常处理 完整学习笔记
开发语言·python
c++之路15 分钟前
C++20概述
java·开发语言·c++20
芝士就是力量啊 ೄ೨29 分钟前
Python如何编写一个简单的类
开发语言·python
逻辑驱动的ken40 分钟前
Java高频面试考点18
java·开发语言·数据库·算法·面试·职场和发展·哈希算法
MoonBit月兔41 分钟前
「Why MoonBit 」第一期——Singularity Note AI 学习助手
开发语言·人工智能·moonbit
木木_王1 小时前
嵌入式Linux学习 | 数据结构 (Day05) 栈与队列详解(原理 + C 语言实现 + 实战实验 + 易错点剖析)
linux·c语言·开发语言·数据结构·笔记·学习
冷雨夜中漫步1 小时前
Claude Code源码分析——Claude Code Agent Loop 详细设计文档
java·开发语言·人工智能·ai
超龄编码人1 小时前
Qt Widgets Designer QTabWidget无法添加布局
开发语言·qt
直奔標竿1 小时前
Java开发者AI转型第二十六课!Spring AI 个人知识库实战(五)——联网搜索增强实战
java·开发语言·人工智能·spring boot·后端·spring
Python大数据分析@1 小时前
CLI一键采集,使用Python搭建TikTok电商爬虫Agent
开发语言·爬虫·python