当前位置: 首页 > article >正文

【流程图】在 .NET (WPF 或 WinForms) 中实现流程图中的连线算法

在 .NET (WPF 或 WinForms) 中实现流程图中的连线算法,通常涉及 图形绘制路径计算。常见的连线方式包括 直线折线贝塞尔曲线。以下是几种方法的介绍和示例代码。


1. 直线连接(最简单)

适用场景

  • 两个节点之间没有障碍物时,最简单的方式。

计算方式

  • 直接用起点 (x1, y1) 和终点 (x2, y2) 画一条直线。

WPF 示例代码

<Canvas x:Name="canvas" Background="White"><Line X1="100" Y1="100" X2="300" Y2="200"Stroke="Black" StrokeThickness="2"/>
</Canvas>

2. 折线连接(适用于流程图)

适用场景

  • 流程图、状态机 这类需要避开障碍的情况。

计算方式

  • 如果两个点在水平方向或垂直方向对齐,直接连线。
  • 否则,使用水平-垂直垂直-水平折线路径。

算法步骤

  1. 确定起点 (x1, y1) 和终点 (x2, y2)
  2. 选择折线拐点:
    • 中间点1 = (x1, y1 + Δy)
    • 中间点2 = (x2, y1 + Δy)

WPF 示例代码

<Canvas x:Name="canvas" Background="White"><Polyline Stroke="Black" StrokeThickness="2"Points="100,100 100,200 300,200"/>
</Canvas>

C# 代码动态生成折线

using System.Windows;
using System.Windows.Shapes;
using System.Windows.Controls;
using System.Windows.Media;public void DrawPolyline(Canvas canvas, Point start, Point end)
{Polyline polyline = new Polyline{Stroke = Brushes.Black,StrokeThickness = 2};// 计算拐点Point mid1 = new Point(start.X, (start.Y + end.Y) / 2);Point mid2 = new Point(end.X, (start.Y + end.Y) / 2);polyline.Points.Add(start);polyline.Points.Add(mid1);polyline.Points.Add(mid2);polyline.Points.Add(end);canvas.Children.Add(polyline);
}

3. 贝塞尔曲线连接(更平滑)

适用场景

  • 逻辑图、网络关系图、UML 图,需要平滑曲线的情况。

计算方式

  • 使用 三次贝塞尔曲线 (Cubic Bezier Curve)
    • 起点 (x1, y1)
    • 终点 (x2, y2)
    • 两个控制点 (cx1, cy1)(cx2, cy2)

算法步骤

  1. 计算控制点:
    • cx1 = x1 + Δx / 2
    • cy1 = y1
    • cx2 = x2 - Δx / 2
    • cy2 = y2
  2. 使用 Path + BezierSegment 进行绘制。

WPF 示例代码

<Path Stroke="Black" StrokeThickness="2"><Path.Data><PathGeometry><PathFigure StartPoint="100,100"><BezierSegment Point1="150,100" Point2="250,200" Point3="300,200"/></PathFigure></PathGeometry></Path.Data>
</Path>

C# 代码动态生成

using System.Windows;
using System.Windows.Shapes;
using System.Windows.Controls;
using System.Windows.Media;public void DrawBezier(Canvas canvas, Point start, Point end)
{Path path = new Path{Stroke = Brushes.Black,StrokeThickness = 2};PathGeometry geometry = new PathGeometry();PathFigure figure = new PathFigure { StartPoint = start };BezierSegment bezier = new BezierSegment{Point1 = new Point(start.X + (end.X - start.X) / 2, start.Y),Point2 = new Point(end.X - (end.X - start.X) / 2, end.Y),Point3 = end};figure.Segments.Add(bezier);geometry.Figures.Add(figure);path.Data = geometry;canvas.Children.Add(path);
}

4. 避障碍物的连线(A*路径算法)

适用场景

  • 复杂流程图、管道布线、自动路径计算
  • 遇到障碍物时,需要智能避开

算法思路

  1. 建模:将整个画布视为网格(如 10×10 的小方块)。
  2. 路径计算
    • 使用 A 搜索算法* 找到起点到终点的最短路径
    • 允许横向、纵向移动,但不能穿过障碍物
  3. 连线方式
    • 根据 A* 计算出的路径,在网格点之间绘制折线。

C# 实现思路

public List<Point> AStarFindPath(Point start, Point end, List<Rect> obstacles)
{// 使用 A* 寻路算法,返回经过的路径点// 省略 A* 具体实现,可使用 AStarSharp 库return new List<Point> { start, new Point(200, 150), end };
}public void DrawPath(Canvas canvas, Point start, Point end, List<Rect> obstacles)
{List<Point> path = AStarFindPath(start, end, obstacles);Polyline polyline = new Polyline{Stroke = Brushes.Black,StrokeThickness = 2};foreach (var point in path)polyline.Points.Add(point);canvas.Children.Add(polyline);
}

总结

方法适用场景优点缺点
直线连接简单流程图计算简单,性能高不能避开障碍物
折线连接业务流程图、状态图适应复杂布局,易控制可能需要手动计算拐点
贝塞尔曲线关系图、UML平滑美观,减少交叉控制点计算较复杂
A 避障路径*复杂流程、自动布线自动选择最优路径计算复杂,性能开销大

如果你的流程图 节点不会重叠,可以用 折线贝塞尔曲线
如果有 障碍物,建议使用 A 算法* 计算路径。

你打算在哪种场景下使用?

相关文章:

【流程图】在 .NET (WPF 或 WinForms) 中实现流程图中的连线算法

在 .NET (WPF 或 WinForms) 中实现流程图中的连线算法&#xff0c;通常涉及 图形绘制 和 路径计算。常见的连线方式包括 直线、折线 和 贝塞尔曲线。以下是几种方法的介绍和示例代码。 1. 直线连接&#xff08;最简单&#xff09; 适用场景&#xff1a; 两个节点之间没有障碍…...

Linux查找占用的端口,并杀死进程的简单方法

在Linux系统管理中&#xff0c;识别并管理占用特定端口的进程是一项常见且重要的任务。以下是优化过的步骤指南&#xff0c;帮助您高效地完成这一操作&#xff0c;同时提供了一个简洁的命令参考表。 Linux下识别并终止占用端口的进程 1. 探寻端口占用者 使用 lsof命令 lsof…...

【python语言应用】最新全流程Python编程、机器学习与深度学习实践技术应用(帮助你快速了解和入门 Python)

近年来&#xff0c;人工智能领域的飞速发展极大地改变了各个行业的面貌。当前最新的技术动态&#xff0c;如大型语言模型和深度学习技术的发展&#xff0c;展示了深度学习和机器学习技术的强大潜力&#xff0c;成为推动创新和提升竞争力的关键。特别是PyTorch&#xff0c;凭借其…...

Datawhale Ollama教程笔记3

小白的看课思路&#xff1a; Ollama REST API 是什么&#xff1f; 想象一下&#xff0c;你有一个智能的“盒子”&#xff08;Ollama&#xff09;&#xff0c;里面装了很多聪明的“小助手”&#xff08;语言模型&#xff09;。如果你想让这些“小助手”帮你完成一些任务&#…...

基于JavaWeb开发的Java+Spring+vue+element实现旅游信息管理平台系统

基于JavaWeb开发的JavaSpringvueelement实现旅游信息管理平台系统 &#x1f345; 作者主页 网顺技术团队 &#x1f345; 欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; &#x1f345; 文末获取源码联系方式 &#x1f4dd; &#x1f345; 查看下方微信号获取联系方式 承接各…...

基础网络详解4--HTTP CookieSession 思考 2

一、Cookie与Set-Cookie 1. Cookie 定义: Cookie 是客户端&#xff08;通常是浏览器&#xff09;存储的一小段数据&#xff0c;由服务器通过 Set-Cookie 响应头设置&#xff0c;并在后续请求中通过 Cookie 请求头发送回服务器。作用: 用于在客户端保存状态信息&#xff0c;例…...

2.14日学习总结

题目一&#xff1a;接雨水问题 1.题目描述&#xff1a;给定一个数组 height 表示一个地形的高度图&#xff0c;数组中的每个元素代表每个宽度为 1 的柱子的高度。计算按此排列的柱子&#xff0c;下雨之后能接多少雨水。 2.示例&#xff1a;输入 height [0,1,0,2,1,0,1,3,2,1…...

【技术产品】DS三剑客:DeepSeek、DataSophon、DolphineSchduler浅析

引言 在大数据与云原生技术快速发展的时代&#xff0c;开源技术成为推动行业进步的重要力量。本文将深入探讨三个备受瞩目的开源产品组件&#xff1a;DeepSeek、DataSophon 和 DolphinScheduler&#xff0c;分别从产品定义、功能、技术架构、应用场景、优劣势及社区活跃度等方面…...

Go 语言里中的堆与栈

在 Go 语言里&#xff0c;堆和栈是内存管理的两个重要概念&#xff0c;它们在多个方面存在明显差异&#xff1a; 1. 内存分配与回收方式 栈 分配&#xff1a;Go 语言中&#xff0c;栈内存主要用于存储函数的局部变量和调用信息。当一个函数被调用时&#xff0c;Go 会自动为其…...

云计算实训室解决方案(2025年最新版)

一、中高职及本科院校在云计算专业建设中面临的挑战 随着大数据、信息安全、人工智能等新兴信息技术产业的快速发展&#xff0c;相关领域人才需求激增&#xff0c;许多本科及职业院校纷纷开设云计算及相关专业方向。 然而&#xff0c;大多数院校在专业建设过程中面临以下困难&…...

我的新书《青少年Python趣学编程(微课视频版)》出版了!

&#x1f389; 激动人心的时刻来临啦&#xff01; &#x1f389; 小伙伴们久等了&#xff0c;我的第一本新书 《青少年Python趣学编程&#xff08;微课视频版&#xff09;》 正式出版啦&#xff01; &#x1f4da;✨ 在这个AI时代&#xff0c;市面上的Python书籍常常过于枯燥&…...

网络安全要学python 、爬虫吗

网络安全其实并不复杂&#xff0c;只是比普通开发岗位要学习的内容多一点。无论是有过编程基础还是零基础的都可以学习的。网络安全目前可就业的岗位从技术上可分为两部分&#xff1a;web安全和二进制逆向安全。web安全是网络安全的入门方向&#xff0c;内容简单&#xff0c;就…...

DBSCAN 基于密度的空间带噪聚类法

DBSCAN 基于密度的空间带噪聚类法 DBSCAN&#xff08;Density - Based Spatial Clustering of Applications with Noise&#xff09;即基于密度的空间聚类算法&#xff0c;它是一种典型的密度聚类算法&#xff0c;以下从核心概念、算法步骤、优缺点及应用场景等方面进行解释。…...

Spring Security,servlet filter,和白名单之间的关系

首先&#xff0c;Servlet Filter是Java Web应用中的基础组件&#xff0c;用于拦截请求和响应&#xff0c;进行预处理和后处理。它们在处理HTTP请求时处于最外层&#xff0c;可以执行日志记录、身份验证、授权等操作。白名单机制通常指允许特定IP、用户或请求通过的安全策略&…...

深入理解Java反射机制 —— 构建灵活、动态的后端应用

一、引言 在Java后端开发中&#xff0c;反射机制是一项极具威力的技术。它允许程序在运行时动态加载类、调用方法以及访问属性&#xff0c;从而使得代码具有更高的灵活性和扩展性。本文将从反射的基本原理、核心API、实际应用场景到使用时的注意事项&#xff0c;详细探讨如何在…...

Python基于Django的漏洞扫描系统【附源码、文档说明】

博主介绍&#xff1a;✌Java老徐、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&…...

或非门组成的SR锁存器真值表相关问题

PS&#xff1a;主要是给大家抛砖引玉&#xff0c;不喜勿喷。 问题描述&#xff1a;或非门组成的SR锁存器&#xff0c;为什么当SD和RD等于0时候的真值表一个是Q0&#xff0c;Q0.一个结果是Q1&#xff0c;Q1&#xff1f;...

深度学习框架探秘|TensorFlow vs PyTorch:AI 框架的巅峰对决

在深度学习框架中&#xff0c;TensorFlow 和 PyTorch 无疑是两大明星框架。前面两篇文章我们分别介绍了 TensorFlow&#xff08;点击查看&#xff09; 和 PyTorch&#xff08;点击查看&#xff09;。它们引领着 AI 开发的潮流&#xff0c;吸引着无数开发者投身其中。但这两大框…...

如何测试和验证CVE-2024-1430:Netgear R7000 路由器信息泄露漏洞分析

CVE-2024-1430 是一个影响 Netgear R7000 路由器的安全漏洞&#xff0c;漏洞来源于该路由器 Web 管理界面的信息泄露问题。攻击者通过访问 /currentsetting.htm 文件&#xff0c;可能泄露敏感信息&#xff0c;如 Wi-Fi 密码等。 在测试和验证 CVE-2024-1430 时&#xff0c;您需…...

MongoDB 基本操作

一、数据库操作 1. 切换或创建数据库 使用use命令切换到指定数据库&#xff0c;若该数据库不存在&#xff0c;在首次插入数据时会自动创建。 use myDatabase 2. 查看所有数据库 使用show dbs命令查看 MongoDB 实例中的所有数据库。 show dbs 3. 删除当前数据库 使用db.…...

【前端框架】Vue3 面试题深度解析

本文详细讲解了VUE3相关的面试题&#xff0c;从基础到进阶到高级&#xff0c;分别都有涉及&#xff0c;希望对你有所帮助&#xff01; 基础题目 1. 简述 Vue3 与 Vue2 相比有哪些主要变化&#xff1f; 答案&#xff1a; 响应式系统&#xff1a;Vue2 使用 Object.definePrope…...

springboot中使用log4j2

安装依赖pom.xml <!--排除logback的依赖--> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId><exclusions><exclusion><groupId>org.springframework.boot</…...

GRN前沿:DGCGRN:基于有向图卷积网络的基因调控网络推理

1.论文原名&#xff1a;Inference of gene regulatory networks based on directed graph convolutional networks 2.发表日期&#xff1a;2024 DGCGRN框架 中心节点和节点的构建 局部增强策略 1. 问题背景 在基因调控网络中&#xff0c;许多节点的连接度较低&#xff08;即…...

DeepSeek崛起:中国AI产业的颠覆者与重构者

当DeepSeek以"中国版ChatGPT"的标签横空出世时&#xff0c;这个诞生于杭州的AI新贵仅用三个月时间就完成了从行业黑马到颠覆者的蜕变。其开源大模型DeepSeek-R1在HuggingFace开源大模型排行榜的登顶&#xff0c;不仅意味着技术指标的超越&#xff0c;更预示着中国AI产…...

E. Exposition

题目链接&#xff1a;Problem - E - Codeforces 题目大意&#xff1a; 给你一个长度为n的序列&#xff0c;和一个整数k.现让找出所有连续的最长子区间&#xff0c; 其子区间的条件是&#xff1a;在区间里最大值减去最小值之差要小于 k . 输入&#xff1a; 输入数据的第一行包…...

KVM虚拟化快速入门,最佳的开源可商用虚拟化平台

引言 在信息技术飞速发展的时代&#xff0c;服务器资源的高效利用成为企业关注的焦点。KVM 虚拟化作为一种先进的虚拟化技术&#xff0c;在众多虚拟化方案中脱颖而出&#xff0c;为企业实现服务器资源的优化配置提供了有效途径。 以往&#xff0c;物理服务器的资源利用效率较…...

unity删除了安卓打包平台,unityhub 还显示已经安装,怎么解决

解决问题地址 可能由于版本问题文章中这个我没搜到&#xff0c;应该搜Android Build Supprot...

软件工程-软件设计

包括 从管理的观点看包括&#xff1a; 详细设计 概要设计 从技术的观点看包括&#xff1a; 数据设计&#xff08;详细设计&#xff09; 系统结构设计&#xff08;概要设计&#xff09; 过程设计&#xff08;详细设计&#xff09; 任务 分析模型——》设计模型——》设…...

【Viper】配置格式与支持的数据源与go案例

Viper 是一个用于 Go 应用程序的配置管理库&#xff0c;支持多种配置格式和数据源。 安装依赖 go get github.com/spf13/viper go get github.com/spf13/viper/remote go get go.etcd.io/etcd/client/v3"github.com/spf13/viper/remote"要写在etcd客户端import里 1…...

C++ Primer 参数传递

欢迎阅读我的 【CPrimer】专栏 专栏简介&#xff1a;本专栏主要面向C初学者&#xff0c;解释C的一些基本概念和基础语言特性&#xff0c;涉及C标准库的用法&#xff0c;面向对象特性&#xff0c;泛型特性高级用法。通过使用标准库中定义的抽象设施&#xff0c;使你更加适应高级…...