opencascade:计算点在平面的投影

复制代码
#include <GeomAPI_ProjectPointOnSurf.hxx>

//计算三维点到三维平面的投影
//成功:返回投影点
//失败: 返回(0, 0, 0)点
static  gp_Pnt   calculateOrthoProject(const TopoDS_Face& face, const gp_Pnt& p)
{
    gp_Pnt resultPt;
   // TopoDS_Face  face =  BRepBuilderAPI_MakeFace(plane);
    const Handle(Geom_Surface)& RefSurf = BRep_Tool::Surface(face);
    Extrema_ExtAlgo Algo = Extrema_ExtAlgo_Tree;
    GeomAPI_ProjectPointOnSurf generator(p, RefSurf, Algo );
    if (generator.NbPoints() > 0)
    {
        resultPt = generator.NearestPoint();
    }
    return resultPt;
}
复制代码

 

posted @   unicornsir  阅读(25)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示