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;
}
相关推荐
kong79069282 小时前
Java-Intellij IDEA 自动导包设置
java·ide·intellij-idea
alphaTao2 小时前
LeetCode 每日一题 2025/12/15-2025/12/21
算法·leetcode
写写闲篇儿4 小时前
下一个更大元素(一)
数据结构·算法
twj_one6 小时前
Arthas使用
java
MobotStone6 小时前
从金鱼记忆到过目不忘:Transformer 如何让AI真正理解一句话?
算法
lizz316 小时前
C++模板编程:从入门到精通
java·开发语言·c++
炽烈小老头7 小时前
【每天学习一点算法 2025/12/19】二叉树的层序遍历
数据结构·学习·算法
shoubepatien7 小时前
JAVA -- 05
java·开发语言
寰天柚子7 小时前
Java并发编程中的线程安全问题与解决方案全解析
java·开发语言·python
memgLIFE7 小时前
Springboot 分层结构
java·spring boot·spring