C#,计算几何,二维贝塞尔拟合曲线(Bézier Curve)参数点的计算代码

本文主要是介绍C#,计算几何,二维贝塞尔拟合曲线(Bézier Curve)参数点的计算代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 Pierre Bézier

Bézier 算法用于曲线的拟合与插值。

插值是一个或一组函数计算的数值完全经过给定的点。

拟合是一个或一组函数计算的数值尽量路过给定的点。

这里给出 二维 Bézier 曲线拟合的参数点计算代码。

区别于另外一种读音接近的贝塞耳插值算法Bessel's interpolation)哈!德国,法国。

1 文本格式


class Point
{
    double X;
    double Y;
}

public Point GetBezierPoint(double t, Point p0, Point p1, Point p2, Point
p3)
{
    double cx = 3 * (p1.X - p0.X);
    double bx = 3 * (p2.X - p1.X) - cx;
    double ax = p3.X - p0.X - cx - bx;
    double cy = 3 * (p1.Y - p0.Y);
    double by = 3 * (p2.Y - p1.Y) - cy;
    double ay = p3.Y - p0.Y - cy - by;
    double tCubed = t * t * t;
    double tSquared = t * t;
    double resultX = (ax * tCubed) + (bx * tSquared) + (cx * t) + p0.X;
    double resultY = (ay * tCubed) + (by * tSquared) + (cy * t) + p0.Y;
    return new Point((int)resultX, (int)resultY);
}
 

 ——————————————————————

POWER BY 315SOFT.COM &
TRUFFER.CN

2 代码格式


class Point
{double X;double Y;
}public Point GetBezierPoint(double t, Point p0, Point p1, Point p2, Point
p3)
{double cx = 3 * (p1.X - p0.X);double bx = 3 * (p2.X - p1.X) - cx;double ax = p3.X - p0.X - cx - bx;double cy = 3 * (p1.Y - p0.Y);double by = 3 * (p2.Y - p1.Y) - cy;double ay = p3.Y - p0.Y - cy - by;double tCubed = t * t * t;double tSquared = t * t;double resultX = (ax * tCubed) + (bx * tSquared) + (cx * t) + p0.X;double resultY = (ay * tCubed) + (by * tSquared) + (cy * t) + p0.Y;return new Point((int)resultX, (int)resultY);
}

 

这篇关于C#,计算几何,二维贝塞尔拟合曲线(Bézier Curve)参数点的计算代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/653865

相关文章

SpringBoot请求参数接收控制指南分享

《SpringBoot请求参数接收控制指南分享》:本文主要介绍SpringBoot请求参数接收控制指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring Boot 请求参数接收控制指南1. 概述2. 有注解时参数接收方式对比3. 无注解时接收参数默认位置

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

C# foreach 循环中获取索引的实现方式

《C#foreach循环中获取索引的实现方式》:本文主要介绍C#foreach循环中获取索引的实现方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、手动维护索引变量二、LINQ Select + 元组解构三、扩展方法封装索引四、使用 for 循环替代

C# Where 泛型约束的实现

《C#Where泛型约束的实现》本文主要介绍了C#Where泛型约束的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用的对象约束分类where T : structwhere T : classwhere T : ne

C#实现将Excel表格转换为图片(JPG/ PNG)

《C#实现将Excel表格转换为图片(JPG/PNG)》Excel表格可能会因为不同设备或字体缺失等问题,导致格式错乱或数据显示异常,转换为图片后,能确保数据的排版等保持一致,下面我们看看如何使用C... 目录通过C# 转换Excel工作表到图片通过C# 转换指定单元格区域到图片知识扩展C# 将 Excel

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析