C# | GDI+图像测距辅助线的实现思路

embedded/2025/3/1 7:59:07/

C# | GDI+图像测距辅助线的实现思路

文章目录

    • C# | GDI+图像测距辅助线的实现思路
      • 一、辅助线需求概述
      • 二、坐标系与角度计算
        • 2.1 笛卡尔坐标系
        • 2.2 线长和角度计算方法
        • 2.3 文本角度矫正计算方法
        • 2.4 坐标变换实现步骤
      • 三、与if判断方式对比
      • 四、总结

一、辅助线需求概述

在图像测量工具中,动态辅助线的数值标签需要满足两个核心要求:其一,标签方向需与辅助线走向保持一致;其二,无论辅助线处于何种角度,文本必须保持正面朝上显示。
在这里插入图片描述

二、坐标系与角度计算

2.1 笛卡尔坐标系

在屏幕坐标系中,Y轴方向与数学坐标系相反(向下为正方向)。两点间连线形成的角度范围在-π到π之间,对应屏幕空间的360度方向。

2.2 线长和角度计算方法

计算两点之间的距离:

double length = Math.Sqrt(Math.Pow(endPoint.X - startPoint.X, 2) + Math.Pow(endPoint.Y - startPoint.Y, 2));

计算线的反正切值,Math.Atan2 返回的值在 (-π, π] 之间,用于表示线的方向:

double atan = Math.Atan2(endPoint.Y - startPoint.Y, endPoint.X - startPoint.X);
2.3 文本角度矫正计算方法

调整反正切值,以确保显示的长度文本始终保持向上的方向。如果反正切值的绝对值大于 π/2,说明线的倾斜方向可能导致文本倒着显示。
此时通过 -(Math.PI - atan) 来调整反正切值,使其对应的文本方向向上。

atan = Math.Abs(atan) > Math.PI / 2 ? -(Math.PI - atan) : atan;
2.4 坐标变换实现步骤
  1. 平移坐标系至线段中点
  2. 应用旋转变换
  3. 垂直偏移避免覆盖线段

关键代码段:

// 计算中点位置
PointF midPoint = new PointF((startPoint.X + endPoint.X) / 2, (startPoint.Y + endPoint.Y) / 2);// 调整原点至两点中心
g.TranslateTransform(midPoint.X, midPoint.Y);
g.RotateTransform((float)(atan * 180 / Math.PI));

三、与if判断方式对比

使用if连环判断不但啰嗦还存在除零风险。

if (deltaX >= 0 && deltaY >= 0) // 第一象限
{angle = Math.Atan(deltaY / deltaX);
}
else if (deltaX <= 0 && deltaY >= 0) // 第二象限
{angle = Math.PI - Math.Atan(deltaY / -deltaX);
}
// 三、四...

四、总结

通过坐标变换矩阵验证法可检测实现效果:

  1. 当辅助线处于水平方向(0度)时,旋转角度为0
  2. 当辅助线垂直向上(-90度)时,实际应用90度旋转
  3. 当辅助线倾斜135度时,自动校正为-45度显示

综上,在0-360度全范围内均能保持文本正向显示,感谢阅读。


http://www.ppmy.cn/embedded/169008.html

相关文章

网页五子棋——项目测试

目录 测试用例设计 功能测试 注册功能测试 正常注册 异常注册 登录功能测试 正常登录 异常登录 匹配功能测试 对战功能测试 自动化测试 引入依赖 Utils 注册测试 登录测试 匹配测试 RunTest 界面测试 性能测试 总结 测试用例设计 在本篇文章中&#xff0c;…

Tr0ll: 1靶场渗透测试

Tr0ll: 1靶场 来自 <Tr0ll: 1 ~ VulnHub> 1,将两台虚拟机网络连接都改为NAT模式 2&#xff0c;攻击机上做namp局域网扫描发现靶机 nmap -sn 192.168.23.0/24 那么攻击机IP为192.168.23.181&#xff0c;靶场IP192.168.23.185 3&#xff0c;对靶机进行端口服务探测 nmap -…

Idea 和 Pycharm 快捷键

一、快捷键 二、Pycharm 中怎么切换分支 参考如下 如果在界面右下角 没有看到当前所在的分支&#xff0c;如 “Git:master” 3. 有了 4.

Python 创建一个能够筛选文件的PDF合并工具

合并多个 PDF 文件。这款 PDF 合并工具允许用户浏览文件夹、选择 PDF 文件&#xff0c;并将其合并为一个新的 PDF 文件。我们将详细分析代码结构和如何一步步实现每个功能。 C:\pythoncode\new\PDFFileInFolderMergeToNewPDFFile.py 全部代码 import os import wx import PyP…

如何通过DeepBI提升亚马逊广告效果:全方位优化广告投放的智能工具

在竞争激烈的亚马逊市场上&#xff0c;精准的广告投放已成为商家成功的关键。传统的广告优化方法常常依赖手动调整和经验判断&#xff0c;这不仅耗时耗力&#xff0c;还容易忽视潜在的优化机会。随着人工智能技术的发展&#xff0c;DeepBI应运而生&#xff0c;成为提升亚马逊广…

001 Kafka入门及安装

Kafka入门及安装 文章目录 Kafka入门及安装1.介绍Kafka的基本概念和核心组件 2.安装1.docker快速安装zookeeper安装kafka安装 添加topic删除topickafka-ui安装 2.Docker安装&#xff08;SASL/PLAIN认证配置-用户名密码&#xff09; 来源参考的deepseek&#xff0c;如有侵权联系…

Python - Python操作Redis

安装Redis可参考 Redis-入门简介-CSDN博客 在Python中接入Redis数据库通常使用redis-py这个库 一、安装Redis 首先&#xff0c;需要安装redis-py库。通过pip来安装 pip install redis 二、连接Redis Redis连接操作import redisdef redis_connect():try:redisClient redi…

基于大数据的音乐网站数据分析与可视化推荐系统

【大数据】基于大数据的音乐网站数据分析与可视化推荐系统&#xff08;完整系统源码开发笔记详细部署教程&#xff09;✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 本选题旨在设计并实现一款基于大数据技术的音乐网站数据分析与可视化推荐系统&#x…