eryar

PipeCAD - Plant Piping Design Software.
RvmTranslator - Translate AVEVA RVM to OBJ, glTF, etc.
posts - 603, comments - 590, trackbacks - 0, articles - 0

OpenCascade中的Delaunay三角剖分

Posted on 2013-05-26 16:51 eryar 阅读(27516) 评论(17)  编辑 收藏 引用 所属分类: 2.OpenCASCADE

Delaunay Triangulation in OpenCascade

eryar@163.com

摘要:本文简要介绍了Delaunay三角剖分的基础理论,并使用OpenCascade的三角剖分算法将边界BRep表示的几何体进行三角离散化后在OpenSceneGraph中显示。

关键字:Delaunay Triangulation、OpenCascade、OpenSceneGraph

一、 概述

三角剖分是平面剖分中的一个重要课题,在数字图像处理、计算机三维曲面造型、有限元计算、逆向工程等领域有着广泛应用。由于三角形是平面域中的单纯形,与其他平面图形相比,其有描述方便、处理简单等特性,很适合于对复杂区域进行简化处理。因此,无论在计算几何、计算机图形处理、模式识别、曲面逼近,还有有限元网格生成方面有广泛的应用。

虽然曲线、曲面等有精确的方程来表示,但是在在计算机中,只能用离散的方式来逼近。如曲线可用直线段来逼近,而曲面可用多边形或三角形来表示。用多边形网格表示曲面是设计中经常使用的形式,可以根据应用要求选择网格的密度。利用三角形面片表示的曲面在计算机图形学中也称为三角形网格。用三角形网格表示曲面需要解决几个问题:三角形的产生、描述、遍历、简化和压缩等,这些问题都是计算几何研究的范畴,相关问题都可以从中找到答案。下图所示的圆柱和立方体是由OpenCascade生成,使用OpenCascade的算法离散成三角网格后在OpenSceneGraph中显示的效果。

wps_clip_image-27228

Figure 1.1 Shaded Cylinder and Box

wps_clip_image-22196

Figure 1.2 Mesh generated by OpenCascade

从图中可以看出,平面的三角形网格效果还不错,曲面的三角形网格表示只能是近似表示,可以通过提高网格的密度来增加真实性,但相应渲染的数据量就大了。有人说OpenCascade的显示模块做得不是很好,上述方法则可以只使用OpenCascade的造型模块,再结合OpenSceneGraph来对图形进行显示。

三维数据交换STL格式文件中保存的都是三角面片的数据,STL文件格式是由美国3D System公司开发,已被工业界认为是目前快速自动成型领域的准标准零件描述文件格式。它对三维实体描述的解释具有惟一性。几乎所有的几何造型系统都提供STL文件数据交换接口。OpenCascade中的数据交换模块也提供对STL格式的支持,由此可见三角网格在几何造型系统中的重要性。

Voronoi图和Delaunay三角剖分的应用领域十分广泛:几何建模——用来寻找三维曲面“好的”三角剖分;有限元分析——用来生成“好的”有限元网格;地理信息系统——用来进行空间领域分析;结晶学——用来确定合金的结构;人类学和考古学——用来确定氏族部落、首领权威、居住中心或堡垒等的影响范围;天文学——用来确定恒星和星系的分布;生物学生态学和林学——用来确定动植物的竞争;动物学——分析动物的领地;统计学和数据分析——用来分析统计聚合;机器人学——用来进行运动轨迹规划(在存在障碍物的情况下);模式识别——作为寻找物体骨架点的工具;生理学——用来分析毛细作用的领域;气象学——用来估计区域平均降雨量;市场学——用来建立城市的市场辐射范围;以及在遥感图像处理、化学、地理学、地质学、冶金学、数学等学科的应用等。

本文只对OpenCascade中的三角剖分进行简要介绍,希望对三角剖分在三维几何造型方面有兴趣的朋友可以对其深入研究。水平很有限,文中不当之处欢迎批评指正、指导,联系邮箱:eryar@163.com

二、 Voronoi图

Dirichlet于1850年研究了平面点的邻域问题,Voronoi于1908年将其结果扩展到高维空间。半空间定义Voronoi图:给定平面上n个点集S,S={p1, p2, …, pn}。定义:

wps_clip_image-1602

PiPj连线的垂直平分面将空间分为两半,V(Pi)表示比其他点更接近Pi的点的轨迹是n-1个半平面的交,它是一个不多于n-1条边的凸多边形域,称为关联于Pi的Voronoi多边形或关联于Pi的Voronoi域。如下图所示为关联于P1的Voronoi多边形,它是一个四边形,而n=6.

wps_clip_image-4421

Figure 2.1 n=6时的一种V(p1)

对于点集S中的每个点都可以做一个Voronoi多边形,这样的n个Voronoi多边形组成的图称为Voronoi图,记为Vor(S)。如下图所示:

wps_clip_image-31980

Figure 2.2 Voronoi diagram for 10 randomly points (Generated by MATLAB)

图中的顶点和边分别称为Voronoi顶点和Voronoi边。显然,|S|=n时,Vor(S)划分平面成n个多边形域,每个多边形域V(Pi)包含S中的一个点而且只包含S中的一个点,Vor(S)的边是S中某点对的垂直平分线上的一条线段或半直线,从而为该点对所在的两个多边形域所共有。Vor(S)中有的多边形域是无界的。

wps_clip_image-18135

Figure 2.3 Ten shops in a flat city and their Voronoi cells

(http://en.wikipedia.org/wiki/Voronoi_diagram)

wps_clip_image-27044

Figure 2.4 Voronoi tessellation in a cylinder (Voro++ library: http://math.lbl.gov/voro++/)

Voronoi图有如下性质:

l n个点的点集S的Voronoi图至多有2n-5个顶点和3n-6条边;

l 每个Voronoi点恰好是三条Voronoi边的交点;

l 设v是Vor(S)的顶点,则圆C(v)内不含S的其他点;

l 点集S中点Pi的每一个最近邻近点确定V(Pi)的一条边;

l Voronoi图的直线对偶图是S的一个三角剖分;

l 如果Pi,Pj属于S,并且通过Pi,Pj有一个不包含S中其他点的圆,那么线段PiPj是点集S三角剖分的一条边,反之亦成立。

三、 Delaunay三角剖分 

1. 二维实数域上的三角剖分

假设V是二维实数域上的有限点集,边e是由点集中的点作端点构成的封闭线段,E为e的集合,那么该点集V的一个三角剖分T=(V,E)是一个平面图:

l 除了端点,平面图中的边不包含点集中的任何点;

l 没有相交边;

l 平面图中所有的面都是三角面,且所有三角面的合集是点集V的凸包。

2. Delaunay边

假设E中的一条边(两端点a,b),e满足下列条件,则称为Delaunay边:存在一个圆经过a,b两点,圆内不包含点集V中的任何的点。这一特性又称为空圆特性。

3. Delaunay三角剖分

如果点集V的一个三角剖分T中只包含Delaunay边,那么该三角剖分称为Delaunay剖分。

最近点意义下的Voronoi图的对偶图实际上是点集的一种三角剖分,该三角剖分就是Delaunay剖分(表示为DT(S)),其中每个三角形的外接圆不包含点集中的其他任何点。因此,在构造点集的Voronoi图之后,再作其对偶图,即对每条Voronoi边作通过点集中某两点的垂直平分线,即得到Delaunay三角剖分。

wps_clip_image-18943

Figure 3.1 Delaunay Triangulation (Generated by MATLAB)

再看几个图片,加深对Delaunay三角剖分的理解:

wps_clip_image-12125

Figure 3.2 Delaunay Edge 

wps_clip_image-2535

Figure 3.3 Illustrate Delaunay Edge

wps_clip_image-16525

Figure 3.4 Delaunay Edge

4. Delaunay三角剖分的特性

l 1978年Sibson证明了在二维的情况下,在点集的所有三角剖分中,Delaunay三角剖分使得生成的三角形的最小角达到最大(max-min angle)。因为这一特性,对于给定点集的Delaunay三角剖分总是尽可能避免“瘦长”三角形,自动向等边三角形逼近;

l 局部优化与整体优化(locally optimal and globally optimal);

l Delaunay空洞(cavity)与局部重连(local reconnection);

5. 经典的Delaunay三角剖分算法

目前常用的算法分为几种,有扫描线法(Sweepline)、随机增量法(Incremental)、分治法(Divide and Conquer)等。

经典的Delaunay三角剖分算法主要有两类:Bowyer/Watson算法和局部变换法。

l Bowyer/Watson算法又称为Delaunay空洞算法或加点法,以Bowyer和Watson算法为代表。从一个三角形开始,每次加一个点,保证每一步得到的当前三角形是局部优化的。以英国Bath大学数学分校Bowyer,Green,Sibson为代表的计算Dirichlet图的方法属于加点法,是较早成名的算法之一;以澳大利亚悉尼大学地学系Watson为代表的空外接球法也属于加点法。加点法算法简明,是目前应用最多的算法,该方法利用了Delaunay空洞性质。Bowyer/Watson算法的优点是与空间的维数无关,并且算法在实现上比局部变换算法简单。该算法在新点加入到Delaunay网格时,部分外接球包含新点的三角形单元不再符合Delaunay属性,则这些三角形单元被删除,形成Delaunay空洞,然后算法将新点与组成空洞的每一个顶点相连生成一个新边,根据空球属性可以证明这些新边都是局部Delaunay的,因此新生成的三角网格仍是Delaunay的。

wps_clip_image-22333

Figure 3.5 Illustration of 2D Bowyer/Watson algorithm for Delaunay Triangulation

l 局部变换法又称为换边、换面法。当利用局部变换法实现增量式点集的Delaunay三角剖分时,首先定位新加入点所在的三角形,然后在网格中加入三个新的连接该三角形顶点与新顶点的边,若该新点位于某条边上,则该边被删除,四条连接该新点的边被加入。最后,在通过换边方法对该新点的局部区域内的边进行检测和变换,重新维护网格的Delaunay性质。局部变换法的另一个优点是其可以对已存在的三角网格进行优化,使其变换成为Delaunay三角网格,该方法的缺点则是当算法扩展到高维空间时变得较为复杂。

四、 Delaunay三角剖分在OpenCascade的应用

OpenCascade中网格剖分的包主要有BRepMesh、MeshAlgo、MeshVS,其中,类MeshAlgo_Delaunay使用算法Watson来进行Delaunay三角剖分。从类StlTransfer中的注释The triangulation is computed with the Delaunay algorithm implemented in package BRepMesh.可以看出包BRepMesh就是Delaunay三角剖分的具体实现。使用方法如下:

BRepMesh::Mesh (aShape, Deflection);

这个函数主要是用来对拓扑形状进行三角剖分。以下通过将一个圆柱三角剖分为例说明如何将一个拓扑形状进行三角剖分并将结果进行可视化。

 

/*

*    Copyright (c) 2013 eryar All Rights Reserved. 



*        File    : Main.cpp 

*        Author  : eryar@163.com 

*        Date    : 2013-05-26 

*        Version : 0.1 



*    Description : Use BRepMesh_Delaun class to learn  

*                  Delaunay's triangulation algorithm. 



*/
 

// Open Cascade library. 

#include 
<gp_Pnt.hxx> 

#include 
<gp_Pln.hxx> 

#include 
<BRep_Tool.hxx> 

#include 
<TopoDS.hxx> 

#include 
<TopoDS_Edge.hxx> 

#include 
<TopoDS_Wire.hxx> 

#include 
<TopoDS_Face.hxx> 

#include 
<BRepBuilderAPI_MakeEdge.hxx> 

#include 
<BRepBuilderAPI_MakeWire.hxx> 

#include 
<BRepBuilderAPI_MakeFace.hxx> 

#include 
<BRepPrimAPI_MakeBox.hxx> 

#include 
<BRepPrimAPI_MakeCone.hxx> 

#include 
<BRepPrimAPI_MakeCylinder.hxx> 

#include 
<BRepPrimApI_MakeSphere.hxx> 

#include 
<BRepMesh.hxx> 

#include 
<TopExp_Explorer.hxx> 

#include 
<Poly_Triangulation.hxx> 

#include 
<TShort_Array1OfShortReal.hxx> 

#pragma comment(lib, 
"TKernel.lib"

#pragma comment(lib, 
"TKMath.lib"

#pragma comment(lib, 
"TKBRep.lib"

#pragma comment(lib, 
"TKPrim.lib"

#pragma comment(lib, 
"TKMesh.lib"

#pragma comment(lib, 
"TKTopAlgo.lib"

// OpenSceneGraph library. 

#include 
<osgDB/ReadFile> 

#include 
<osgViewer/Viewer> 

#include 
<osgViewer/ViewerEventHandlers> 

#include 
<osgGA/StateSetManipulator> 

#pragma comment(lib, 
"osgd.lib"

#pragma comment(lib, 
"osgDbd.lib"

#pragma comment(lib, 
"osgGAd.lib"

#pragma comment(lib, 
"osgViewerd.lib"

osg::Node
* BuildShapeMesh(const TopoDS_Shape& aShape) 



    osg::ref_ptr
<osg::Group> root = new osg::Group(); 

    osg::ref_ptr
<osg::Geode> geode = new osg::Geode(); 

    osg::ref_ptr
<osg::Geometry> triGeom = new osg::Geometry(); 

    osg::ref_ptr
<osg::Vec3Array> vertices = new osg::Vec3Array(); 

    osg::ref_ptr
<osg::Vec3Array> normals = new osg::Vec3Array(); 

    BRepMesh::Mesh(aShape, 
1); 

    TopExp_Explorer faceExplorer; 

for (faceExplorer.Init(aShape, TopAbs_FACE); faceExplorer.More(); faceExplorer.Next()) 



        TopLoc_Location loc; 

        TopoDS_Face aFace 
= TopoDS::Face(faceExplorer.Current()); 

        Handle_Poly_Triangulation triFace 
= BRep_Tool::Triangulation(aFace, loc); 

        Standard_Integer nTriangles 
= triFace->NbTriangles(); 

        gp_Pnt vertex1; 

        gp_Pnt vertex2; 

        gp_Pnt vertex3; 

        Standard_Integer nVertexIndex1 
= 0

        Standard_Integer nVertexIndex2 
= 0

        Standard_Integer nVertexIndex3 
= 0

        TColgp_Array1OfPnt nodes(
1, triFace->NbNodes()); 

        Poly_Array1OfTriangle triangles(
1, triFace->NbTriangles()); 

        nodes 
= triFace->Nodes(); 

        triangles 
= triFace->Triangles(); 

for (Standard_Integer i = 1; i <= nTriangles; i++



            Poly_Triangle aTriangle 
= triangles.Value(i); 

            aTriangle.Get(nVertexIndex1, nVertexIndex2, nVertexIndex3); 

            vertex1 
= nodes.Value(nVertexIndex1); 

            vertex2 
= nodes.Value(nVertexIndex2); 

            vertex3 
= nodes.Value(nVertexIndex3); 

            gp_XYZ vector12(vertex2.XYZ() 
- vertex1.XYZ()); 

            gp_XYZ vector13(vertex3.XYZ() 
- vertex1.XYZ()); 

            gp_XYZ normal 
= vector12.Crossed(vector13); 

            Standard_Real rModulus 
= normal.Modulus(); 

if (rModulus > gp::Resolution()) 



                normal.Normalize(); 

}
 

else 



                normal.SetCoord(
0., 0., 0.); 

}
 

            vertices
->push_back(osg::Vec3(vertex1.X(), vertex1.Y(), vertex1.Z())); 

            vertices
->push_back(osg::Vec3(vertex2.X(), vertex2.Y(), vertex2.Z())); 

            vertices
->push_back(osg::Vec3(vertex3.X(), vertex3.Y(), vertex3.Z())); 

            normals
->push_back(osg::Vec3(normal.X(), normal.Y(), normal.Z())); 

}
 

}
 

    triGeom
->setVertexArray(vertices.get()); 

    triGeom
->addPrimitiveSet(new osg::DrawArrays(osg::PrimitiveSet::TRIANGLES, 0, vertices->size())); 

    triGeom
->setNormalArray(normals); 

    triGeom
->setNormalBinding(osg::Geometry::BIND_PER_PRIMITIVE); 

    geode
->addDrawable(triGeom); 

    root
->addChild(geode); 

return root.release(); 

}
 

int main(int argc, char* argv[]) 



    osgViewer::Viewer myViewer; 

    osg::ref_ptr
<osg::Group> root = new osg::Group(); 

    root
->addChild(BuildShapeMesh(BRepPrimAPI_MakeCylinder(.61))); 

    myViewer.setSceneData(root); 

    myViewer.addEventHandler(
new osgGA::StateSetManipulator(myViewer.getCamera()->getOrCreateStateSet())); 

    myViewer.addEventHandler(
new osgViewer::StatsHandler); 

    myViewer.addEventHandler(
new osgViewer::WindowSizeHandler); 

return myViewer.run(); 

}
 


结果如下图所示:

wps_clip_image-31478

Figure 4.1 Cylinder mesh generated by BRepMesh::Mesh

BRepMesh::Mesh是经过封装的,便于对拓扑形状进行三角剖分。以下通过一个简单的例子来说明直接使用BRepMesh_Delaun的方法:

 

/*

*    Copyright (c) 2013 eryar All Rights Reserved. 



*        File    : Main.cpp 

*        Author  : eryar@163.com 

*        Date    : 2013-05-26 

*        Version : 0.1 



*    Description : Use BRepMesh_Delaun class to learn  

*                  Delaunay's triangulation algorithm. 



*/ 

#include 
<BRepMesh_Edge.hxx> 

#include 
<BRepMesh_Delaun.hxx> 

#include 
<BRepMesh_Array1OfVertexOfDelaun.hxx> 

#include 
<TColStd_MapIteratorOfMapOfInteger.hxx> 

#pragma comment(lib, 
"TKernel.lib"

#pragma comment(lib, 
"TKMesh.lib"

int main(int argc, char* argv[]) 



    BRepMesh_Array1OfVertexOfDelaun vertices(
14); 

    vertices.SetValue(
1, BRepMesh_Vertex(00, MeshDS_Free)); 

    vertices.SetValue(
2, BRepMesh_Vertex(10, MeshDS_Free)); 

    vertices.SetValue(
3, BRepMesh_Vertex(11, MeshDS_Free)); 

    vertices.SetValue(
4, BRepMesh_Vertex(01, MeshDS_Free)); 

    BRepMesh_Delaun triangulation(vertices); 

//triangulation.AddVertex(BRepMesh_Vertex(0.5, 0.5, MeshDS_OnSurface)); 

    Handle_BRepMesh_DataStructureOfDelaun meshData 
= triangulation.Result(); 

    std::cout
<<"Iterate Mesh Triangles:"<<std::endl; 

    MeshDS_MapOfInteger::Iterator triDom; 

for (triDom.Initialize(meshData->ElemOfDomain()); triDom.More(); triDom.Next()) 



        Standard_Integer triId 
= triDom.Key(); 

const BRepMesh_Triangle& curTri = meshData->GetElement(triId); 

        Standard_Integer vertexIndex1 
= 0

        Standard_Integer vertexIndex2 
= 0

        Standard_Integer vertexIndex3 
= 0

        Standard_Integer edgeIndex1 
= 0

        Standard_Integer edgeIndex2 
= 0

        Standard_Integer edgeIndex3 
= 0

        Standard_Boolean o1 
= Standard_False; 

        Standard_Boolean o2 
= Standard_False; 

        Standard_Boolean o3 
= Standard_False; 

        curTri.Edges(edgeIndex1, edgeIndex2, edgeIndex3, o1, o2, o3); 

const BRepMesh_Edge& edge1 = meshData->GetLink(edgeIndex1); 

const BRepMesh_Edge& edge2 = meshData->GetLink(edgeIndex2); 

const BRepMesh_Edge& edge3 = meshData->GetLink(edgeIndex3); 

        vertexIndex1 
= (o1? edge1.FirstNode(): edge1.LastNode()); 

        vertexIndex2 
= (o1? edge1.LastNode() : edge1.FirstNode()); 

        vertexIndex3 
= (o2? edge2.LastNode() : edge2.FirstNode()); 

const BRepMesh_Vertex& vertex1 = meshData->GetNode(vertexIndex1); 

const BRepMesh_Vertex& vertex2 = meshData->GetNode(vertexIndex2); 

const BRepMesh_Vertex& vertex3 = meshData->GetNode(vertexIndex3); 

const gp_XY& p1 = vertex1.Coord(); 

const gp_XY& p2 = vertex2.Coord(); 

const gp_XY& p3 = vertex3.Coord(); 

        std::cout
<<"--------"<<std::endl; 

        std::cout
<<p1.X()<<" , "<<p1.Y()<<std::endl; 

        std::cout
<<p2.X()<<" , "<<p2.Y()<<std::endl; 

        std::cout
<<p3.X()<<" , "<<p3.Y()<<std::endl; 

        std::cout
<<"========"<<std::endl; 



return 0




上述程序是以一个正方形为例,使用BRepMesh_Delaun三角剖分的结果为两个三角形,如下所示:

 

Iterate Mesh Triangles: 

-------- 

1 , 1 

0 , 0 

1 , 0 

======== 

-------- 

1 , 1 

0 , 1 

0 , 0 

======== 

 

以上结果都是二维空间上的,三维空间中的使用方法可以参考类:BRepMesh_FastDiscretFace。这个类说明了如何将一个面进行网格划分。

五、 结论

Delaunay三角剖分理论在三维几何造型中还是比较重要的,通过对形状的三角剖分,不仅可以对其进行可视化,还便于对形状做进一步的处理,如消隐、光照处理等。通过对OpenCascade中三角剖分算法的使用,以进一步了解三角剖分理论应用及其算法实现。

六、 参考资料

1. 周培德. 计算几何—算法设计与分析. 清华大学出版社, 2011

2. 李海生. Delaunay三角剖分理论及可视化应用研究. 哈尔滨工业大学出版社, 2010

3. 何援军. 计算机图形学. 机械工业出版社, 2010

4. 周元峰, 孙峰, 王文平, 汪嘉业, 张彩明. 基于局部修复的移动数据点Delaunay三角化快速更新方法. 计算机辅助设计与图形学学报, 2011, 12: 2006-1012

5. http://en.wikipedia.org/wiki/Voronoi_diagram

 

Feedback

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-03-13 19:18 by OpenCASCADE->3D
称呼您一声E老师,一点都不为过。路漫漫其修远兮,吾将上下而求索!

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-03-13 19:52 by eryar
@OpenCASCADE->3D
老师实不敢当。

后半句共勉之……

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-09-24 11:08 by 佚名
博主很厉害,怎么对occ研究这么透。如果occ能在国内普及。博主功不可没!另请教博主一个问题,如何将一组散点组成nurbs曲面,假设这些点是从已有曲面上得到的,不仅仅包含边界线上的点,还有面内部点。

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-09-24 17:49 by eryar
@佚名
过奖了。

我看OCC的例子程序中有个根据点生成面的功能,使用的类有:
1. Plate_Plate;
2. GeomPlate_Surface;
3. GeomPlate_MakeApprox;

相关实现可以参考示例程序。

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-09-24 22:10 by 佚名
@eryar
谢谢您的回复,我好好看看这些算例。

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-09-24 22:33 by eryar
@佚名
不客气。。。

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-09-25 17:22 by 佚名
博主您好!
按您的指点我看了occ附带的例子11,它确实可以由离散点组成样条曲面,美中不足的是曲面的一部分延伸出了边界线(由离散的外围点组成),试着通过调整参数将面限制在点的范围内,然而毫无效果. 是否有更好的方法,如果我先将这些点连成delaunay三角面,能否由这些面组成样条曲面?谢谢!


# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-09-25 17:39 by eryar
@佚名

你好!

拟合曲面的算法还没有细看。

不过好像OCC有收费的模块,专门用来从点云数据生成几何数据,可以看看:
Surfaces from Scattered Points:
http://www.opencascade.org/support/products/ssp/

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-09-25 19:49 by 佚名
非常感谢

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-11-25 10:52 by xmzzy
请教个问题:
在使用BRepMesh::Mesh (aShape, Deflection);时,编译提示“Mesh”: 不是“BRepMesh”的成员。
这个怎么处理呢?

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-11-25 12:43 by eryar
@xmzzy
你可能用的occ6.8.0,这个版本中去掉BRepMesh::Mesh()函数了,官方给的答复是这个函数只是调用了BRepMesh_IncrementalMesh来生成网格,没有存在的意义,所以予以去除。
详细可参考官方论坛:
http://www.opencascade.org/org/forum/thread_26649/?forum=3

6.8.0: BRepMesh::Mesh removed
去除原因及新的用法都有提及,原文如下:
Forum supervisor 2014/11/13 17:30
Dear Thorsen,

Method BRepMesh::Mesh did nothing more than called BRepMesh_IncrementalMesh with the given parameter, so it had no significant meaning and as result it was removed.
To perform meshing user should use BRepMesh_IncrementalMesh directly, for instance:

#include<BRepMesh_IncrementalMesh.hxx>
...
BRepMesh_IncrementalMesh(aShape, 0.001);
...

It is exactly the same what BRepMesh::Mesh did.

Best regards
FSR

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-11-25 13:29 by xmzzy
@eryar
十分感谢。大神啊。

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-12-11 11:26 by zhx
您好,楼主!我想实现对点集的DELAUNAY三角剖分,点集在三维空间的一个平面上(该平面时任意位置的平面),点可以获取为gp_pnt类型,请问能不能用BRepMesh_Delaun实现对该点集的剖分呢?
另外,请问下BRepMesh_Array1OfVertexOfDelaun类型的赋值怎么由GP_PNT类的值实现呢 非常感谢楼主!

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-12-11 14:52 by zhx
@xmzzy
你好啊 我也是在用OCC,之前用的是OCC6.5.0,现在想换位OCC6.8.0,可是安装完之后发现6.8.0版本的网页版的OCC文档不能查找函数,是为什么呢?

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-12-11 17:33 by eryar
@zhx
Hi,

你好!

OpenCASCADE的mesh算法只是针对二维的点集(即参数空间中的点),主要是为了替换掉6.3版本以前用的Triangle库。

如果你是三维的点且可确定都在一个平面上,可以考虑将这些点投影到这个平面,Delaunay三角剖分后再映射回三维空间。

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2014-12-15 22:25 by eryar
@zhx
你好啊 我也是在用OCC,之前用的是OCC6.5.0,现在想换位OCC6.8.0,可是安装完之后发现6.8.0版本的网页版的OCC文档不能查找函数,是为什么呢?
=================================================

我也试了下,occ6.8.0开发文档中的search功能的确不能用。
看了下,它是用php来调用javascript的,所以应该需要放到支持php的服务器上运行这个文档就可以搜索了。

我在occ官网上search是可以的,如下为在occ官网上search类gp_Pnt:
http://dev.opencascade.org/doc/refman/html/search.php?query=gp_Pnt

# re: OpenCascade中的Delaunay三角剖分  回复  更多评论   

2016-03-12 14:33 by loveabcc
@佚名
你好:不知道你能收到我的回复不,我想实现的是和你是一样的东西,就是点云转换成Nurbs,你说的OCC例子11是哪个呢,还有现在你找到OCC的方法了吗,如果可以分享下。谢谢兄弟

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理