N阶Bezier

cpp 复制代码
deque<QPointF> mapToolCurve::getBezier(deque<QPointF>& cps)
{
    deque<QPointF> _resp;

    for (double t = 0.0; t < 1.0; t += 0.01)
    {
        auto pointf = getBezierLoop(cps, t);
        _resp.emplace_back(pointf);
    }

    return _resp;
}

QPointF mapToolCurve::getBezierLoop(deque<QPointF>& cps,double t)
{
    QPointF outPoint;
    deque<QPointF> newCps;
    for (size_t i = 0; i < cps.size() - 1; i++)
    {
        auto p = cps[i] + (cps[i + 1] - cps[i]) * t;
        newCps.emplace_back(p);
    }

    if (1 == newCps.size())
    {
        return newCps[0];
    }else
    {
        outPoint = getBezierLoop(newCps,t);
    }
    return outPoint;
}
相关推荐
Coder_Boy_几秒前
前端和后端软件系统联调经典问题汇总
java·前端·驱动开发·微服务·状态模式
一招定胜负2 分钟前
决策树开篇
算法·决策树·机器学习
GoWjw3 分钟前
C语言高级特性
c语言·开发语言·算法
carver w6 分钟前
说人话版 K-means 解析
算法·机器学习·kmeans
雨中飘荡的记忆11 分钟前
Retrofit:优雅的JAVA网络请求框架实战
java
小O的算法实验室12 分钟前
2026年SEVC SCI2区,基于差分向量内学习策略的自适应指数交叉差分进化算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
Thexhy13 分钟前
基础篇:Redis核心命令及用法
java·linux·redis
狂奔小菜鸡14 分钟前
Day33 | Java中的Optional
java·后端·java ee
啃火龙果的兔子14 分钟前
IntelliJ IDEA社区版下载安装
java·ide·intellij-idea
ckm紫韵19 分钟前
Cursor 与 IDEA 互相跳转教程
java·ide·intellij-idea·cursor·ai工具