圆弧插补【C#】

圆弧:

圆弧插补方法可以通过提供圆弧的起点、终点和半径来画弧。下面是一个用C#实现的圆弧插补方法的示例代码:```
public void DrawArc(Point startPoint, Point endPoint, int radius, bool isClockwise)
{// 计算圆心坐标int centerX = (startPoint.X + endPoint.X) / 2;int centerY = (startPoint.Y + endPoint.Y) / 2;double distance = Math.Sqrt(Math.Pow(endPoint.X - startPoint.X, 2) + Math.Pow(endPoint.Y - startPoint.Y, 2));double halfChord = Math.Sqrt(Math.Pow(radius, 2) - Math.Pow(distance / 2, 2));double angle = Math.Atan2(endPoint.Y - startPoint.Y, endPoint.X - startPoint.X);if (isClockwise){angle += Math.PI / 2;}else{angle -= Math.PI / 2;}int circleX = (int)(centerX + halfChord * Math.Cos(angle));int circleY = (int)(centerY + halfChord * Math.Sin(angle));// 计算外接矩形int left = centerX - radius;int top = centerY - radius;int right = centerX + radius;int bottom = centerY + radius;// 绘制圆弧GraphicsPath path = new GraphicsPath();path.AddArc(left, top, radius * 2, radius * 2, (float)Math.Atan2(startPoint.Y - circleY, startPoint.X - circleX) * 180 / (float)Math.PI, (float)Math.Atan2(endPoint.Y - circleY, endPoint.X - circleX) * 180 / (float)Math.PI - (float)Math.Atan2(startPoint.Y - circleY, startPoint.X - circleX) * 180 / (float)Math.PI);Graphics g = this.CreateGraphics();g.DrawPath(new Pen(Color.Black), path);
}
```这个方法接受起点、终点和半径作为参数,并且可以指定是顺时针还是逆时针画弧。它首先计算出圆心坐标,然后根据起点、终点和半径计算出外接矩形。最后使用GraphicsPath类的AddArc方法绘制圆弧。

直线插补:

直线插补是数控机床中常用的一种插补方式,可以实现直线和圆弧的插补。下面是一个用C#实现直线插补的简单示例:```csharp
public class LinearInterpolation
{public static List<PointF> Interpolate(PointF start, PointF end, float step){List<PointF> points = new List<PointF>();float dx = end.X - start.X;float dy = end.Y - start.Y;float distance = (float)Math.Sqrt(dx * dx + dy * dy);int steps = (int)Math.Ceiling(distance / step);float xIncrement = dx / steps;float yIncrement = dy / steps;float x = start.X;float y = start.Y;for (int i = 0; i < steps; i++){points.Add(new PointF(x, y));x += xIncrement;y += yIncrement;}return points;}
}
```这个示例中,我们定义了一个`LinearInterpolation`类,其中包含一个静态方法`Interpolate`,该方法接受起点、终点和步长三个参数,并返回一个包含所有插值点的列表。在方法中,我们首先计算出起点和终点之间的距离,然后根据步长计算出需要插值的点数。接着,我们计算出每个点的坐标增量,然后循环计算每个插值点的坐标,并将其添加到列表中。最后,我们返回包含所有插值点的列表。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/108969.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

01【Git的基本使用与底层命令】

下一篇&#xff1a;02【Git的分支与数据恢复】 目录&#xff1a;【Git系列教程-目录大纲】 文章目录 一、Git概述1.1 Git简介1.2 集中式与分布式1.2.1 集中式版本控制1.2.2 分布式版本控制 1.3 Git的使用流程1.3.1 本地仓库1.3.2 协同开发 1.4 Git的配置1.4.1 Git的配置等级1…

华为汪涛:5.5G时代UBB目标网,跃升数字生产力

[阿联酋&#xff0c;迪拜&#xff0c;2023年10月12日] 在2023全球超宽带高峰论坛上&#xff0c;华为常务董事、ICT基础设施业务管理委员会主任汪涛发表了“5.5G时代UBB目标网&#xff0c;跃升数字生产力”的主题发言&#xff0c;分享了超宽带产业的最新思考与实践&#xff0c;探…

c++ 类的继承(二)

1. 初始化列表 初始化列表在三种情况下必须使用: 继承关系下&#xff0c;父类没有无参构造函数情况 #include <iostream>using namespace std;class Base{ public:string name;int num;Base(){cout<< "基类的无参构造..." <<endl;}Base(string …

谈谈 Redis 分片集群模式

谈谈 Redis 分片集群模式 优点 ● 无中心架构&#xff0c;支持动态扩容 ● Cluster 自动具备哨兵监控和故障转移&#xff08;主从切换&#xff09;能力 ● 客户端连接集群内部地址可自动发现 ● 高性能、高可用&#xff0c;有效解决了 Redis 分布式需求 缺点 ● 运维复杂 ● 只…

MySQL远程连接

一、什么是mysq的远程连接? 1、本地连接 直接在本地使用mysqladmin命令登录 mysql -u root -p 解释如下: mysql:mysql 命令表示要启动 MySQL 客户端。-u root:-u 选项指定要使用的用户名。在这里,我们使用 root 用户名作为示例。-p:-p 选项需要用户输入密码。如果省…

Vue 父子组件传值有哪些方式

① Props 父组件向子组件传递数据是通过 props 传递的&#xff1b; 在父组件中通过 v-bind 绑定子组件的属性&#xff0c;子组件中通过 props 接收父组件传递的数据。 这是一种单向数据流的方式&#xff0c;父组件可以向子组件传递数据&#xff0c;但是子组件不能直接修改传…

比postman更好用的接口管理软件——Apifox

比postman更好用的接口管理软件——Apifox 官网安装和登录Apifox功能使用团队管理&项目管理接口管理接口文档 Apifox 帮助文档 最近使用了一个好用的中文版接口管理软件&#xff0c;Apifox&#xff0c;以下介绍一下它的使用方式及好处。 官网 Apifox的官方地址&#xff1a…

Python制作PDF转Word工具(Tkinter+pdf2docx)

一、效果样式 二、核心点 1. 使用pdf2docx完成PDF转换Word 安装pdf2docx可能会报错&#xff0c;安装完成引入from pdf2docx import Converter运行也可能报错&#xff0c;可以根据报错提示看缺少那些库&#xff0c;先卸载pip uninstall xxx,使用pip install python-docx -i htt…

Stm32_标准库_16_串口蓝牙模块_手机与蓝牙模块通信_手机传入信息能对芯片时间日期进行更改

实现了手机发送信息给蓝牙模块&#xff0c;程序对数据进行分析拆解&#xff0c;并更新自身数据 main.c: #include "stm32f10x.h" // Device header #include "Delay.h" #include "OLED.h" #include "Serial.h" #include "Ti…

Docker仓库harbor私服搭建

Harbor和Registry都是Docker的镜像仓库&#xff0c;但是Harbor作为更多企业的选择&#xff0c;是因为相比较于Regisrty来说&#xff0c;它具有很多的优势。 提供分层传输机制&#xff0c;优化网络传输 Docker镜像是是分层的&#xff0c;而如果每次传输都使用全量文件(所以用FT…

特斯拉pre-test (Go)

特斯拉pre-test &#xff08;Go&#xff09; 1 Q12 Q23 Q3 1 Q1 原文&#xff1a; You are given an implementation of a function Solution that, given a positive integer N, prints to standard output another integer, which was formed by reversing a decimal repres…

前端成神之路-HTML

前端成神之路-HTML 目录 前端成神之路-HTML 认识网页 常见浏览器介绍 查看浏览器占有的市场份额&#xff08;知晓&#xff09; 浏览器内核&#xff08;理解&#xff09; Web标准&#xff08;重点&#xff09; Web 标准的好处 Web 标准构成 HTML 初识 HTML骨架格式 …

基于Lang-Chain(ChatGLM和ChatChat)知识库大语言模型的部署搭建

环境准备 阿里云个人认证后&#xff0c;可免费试用机器学习平台PAI&#xff0c;可提供适合大语言模型环境搭建的高配置服务器。 点击试用阿里云服务器 试用产品选择&#xff1a;选择交互式建模PAI-DSW 适合哪些场景 文章/知识库/帮助文档等的检索基于现有知识库实现问答… …

Java 字符串工具类

package com.lihaozhe.util.string;import java.util.UUID; import java.util.concurrent.ThreadLocalRandom;/*** 字符串工具类** author 李昊哲* version 1.0*/ public class StringUtils {/*** 去除字符串左边的的空格** param string 原始字符串* return 去除左边空格后的字…

2024得物校招面试真题汇总及其解答(一)

1.你对java什么方向比较了解,数据结构?jvm? 我对Java的各个方面都有一定了解,但我对数据结构和JVM比较熟悉。 在数据结构方面,我了解常见的数据结构的概念、实现和应用,例如链表、队列、栈、树、图等。我还了解一些高级数据结构,例如哈希表、B树、AVL树等。 在JVM方面…

centos清理日志和缓存

今天使用redmine修改密码&#xff0c;修改报错&#xff0c;再去试试创建用户&#xff0c;创建用户的页面直接报错显示不出来。然后看了一下服务器&#xff0c;发现服务器磁盘空间全部占满了。 CentOS系统也会在使用很长一段时间后出现硬盘空间开始不够的情况&#xff0c;而这并…

GPT4 Advanced data analysis Code Interpreter 做行业数据分析、可视化处理图像、视频、音频等

1. 跨境电商如何用ChatGPT选品 ChatGPT Jungle scout 案例&#xff1a;跨境电商如何用ChatGFT选品 ChatGPTJungle scout 素材和资料来自&#xff1a; Jungle ScoutEM, Michael Soltis 和 文韬武韬AIGC 1.1 从Jungle scout上下载数据 Date Range > Last 90 days Downlo…

uniapp(uncloud) 使用生态开发接口详情3(新增产品分类,产品列表,新闻列表)

我的想法是有产品分类,产品列表,新闻咨询,新闻列表 项目中, uniCloud > database 目录下新建 sy_product_nav.schema.json // 代码如下 {"bsonType": "object","required": ["classname"],"permission": {"read&…

rabbitMq (2)

RabbitMQ 消息应答与发布 文章目录 1. 消息应答1.2 自动应答1.2 手动应答1.3 代码案例 2. RabbitMQ 持久化2.1 队列持久化2.2 消息持久化 3. 不公平分发4. 预取值分发5. 发布确认5.1 发布确认逻辑5.2 开启发布确认的方法5.3 单个确认发布5.4 批量确认发布5.5 异步确认5.5.1 处理…

【LeetCode热题100】--31.下一个排列

31.下一个排列 思路&#xff1a; 方法&#xff1a;两遍扫描 注意到下一个排列总是比当前排列要大&#xff0c;除非该排列已经是最大的排列。我们希望找到一种方法&#xff0c;能够找到一个大于当前序列的新序列&#xff0c;且变大的幅度尽可能小。具体地&#xff1a; 我们需要…