OCC 细分TopoDS_Edge

// 任意Edge

TopoDS_Edge edge;
BRepAdaptor_Curve curveAdaptor(edge);

// 方法1
double start = curveAdaptor.FirstParameter();
double end = curveAdaptor.LastParameter();

for (double v = start; v < end; v += 0.01)
{
    // 得到Edge上一个点 point
    gp_Pnt point = BRepGProp_EdgeTool::Value(curveAdaptor, v);
}

// 方法2
// 上述代码在处理直线时不合适,改用以下方法
// 1、最好先调用 IsDone()确保有效,否则,有些步骤会抛出异常
// 2、Value()函数参数起始下标为1
GCPnts_UniformDeflection gcUD(curveAdaptor, 0.01);
if (gcUD.IsDone())
{
    for (int p = 1; p <= gcUD.NbPoints(); ++p)
    {
        gp_Pnt point = gcUD.Value(p);
    }
}

posted @   xl-better  阅读(325)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示