Modeling Algorithms Fillets and Chamfers

造型算法——倒圆与倒角

eryar@163.com

一、倒圆Fillet Constructor

1. BRepFilletAPI_MakeFillet

使用类BRepFilletAPI_MakeFillet来为形状添加倒圆。倒圆是用光滑面来代替角边。使用方法如下:

l 首先,给定一个需要倒圆的形状;

l 然后,通过Add方法来添加描述倒圆的参数,倒圆所需的参数包括一个边edge和半径radius。当然,边edge必须由两个面face所共有。倒圆会将原来的边替换成光滑的圆面过渡。

l 最后,通过询问结果来执行倒圆操作。

注:添加一个倒圆两次并不会出错,因为只保留了最后一次添的倒圆。

Figure 1. Filleting two edges using radius r1 and r2

下面给出一个将创建一个倒圆的长方体,其尺寸分别为abc,倒圆半径r

Figure 2. Filleting a box

代码如下所示,创建上图所示的倒圆的长方体的参数分别为:

a = 100b = 60c = 80r = 10

#include <TopoDS_Shape.hxx>
#include <TopoDS.hxx>
#include <BRepPrimAPI_MakeBox.hxx>
#include <TopoDS_Solid.hxx>
#include <BRepFilletAPI_MakeFillet.hxx>
#include <TopExp_Explorer.hxx> TopoDS_Shape FilletedBox(const Standard_Real a,
const Standard_Real b,
const Standard_Real c,
const Standard_Real r)
{
TopoDS_Solid Box = BRepPrimAPI_MakeBox(a,b,c);
BRepFilletAPI_MakeFillet MF(Box); // add all the edges to fillet
TopExp_Explorer ex(Box,TopAbs_EDGE); while (ex.More())
{
MF.Add(r,TopoDS::Edge(ex.Current()));
ex.Next();
}
return MF.Shape();
}

如下图所示为创建一个半径变化的倒圆操作:

Figure 3. Evolutive radius fillet

Figure 4. Evolutive radius fillet a box

程序代码如下所示:

  1:     TopoDS_Shape theBox = BRepPrimAPI_MakeBox(200, 200, 200);
  2:     BRepFilletAPI_MakeFillet Rake(theBox);
  3:     ChFi3d_FilletShape FSH = ChFi3d_Rational;
  4:     Rake.SetFilletShape(FSH);
  5:
  6:     TColgp_Array1OfPnt2d parAndRad(1, 6);
  7:     parAndRad.SetValue(1, gp_Pnt2d(0, 10));
  8:     parAndRad.SetValue(2, gp_Pnt2d(50, 20));
  9:     parAndRad.SetValue(3, gp_Pnt2d(70, 20));
 10:     parAndRad.SetValue(4, gp_Pnt2d(130, 60));
 11:     parAndRad.SetValue(5, gp_Pnt2d(160, 30));
 12:     parAndRad.SetValue(6, gp_Pnt2d(200, 20));
 13:
 14:     TopExp_Explorer ex(theBox, TopAbs_EDGE);
 15:     Rake.Add(parAndRad, TopoDS::Edge(ex.Current()));
 16:     TopoDS_Shape evolvedBox = Rake.Shape();
 17: 

2. BRepFilletAPI_MakeFillet2d

BRepFilletAPI_MakeFillet2d is used to construct fillets and chamfers on planar faces.

我按照示例代码运行了一下程序,结果程序总是崩溃,其操作的效果不得而知,所以也得不到真实的效果图。将其程序代码列出如下所示:

  1: #include “BRepPrimAPI_MakeBox.hxx”
  2: #include “TopoDS_Shape.hxx”
  3: #include “TopExp_Explorer.hxx”
  4: #include “BRepFilletAPI_MakeFillet2d.hxx”
  5: #include “TopoDS.hxx”
  6: #include “TopoDS_Solid.hxx”
  7:
  8: TopoDS_Shape FilletFace(const Standard_Real a,
  9:     const Standard_Real b,
 10:     const Standard_Real c,
 11:     const Standard_Real r)
 12: {
 13:     TopoDS_Solid Box = BRepPrimAPI_MakeBox (a,b,c);
 14:     TopExp_Explorer ex1(Box,TopAbs_FACE);
 15:
 16:     const TopoDS_Face& F = TopoDS::Face(ex1.Current());
 17:     BRepFilletAPI_MakeFillet2d MF(F);
 18:     TopExp_Explorer ex2(F, TopAbs_VERTEX);
 19:
 20:     while (ex2.More())
 21:     {
 22:         MF.AddFillet(TopoDS::Vertex(ex2.Current()),r);
 23:         ex2.Next();
 24:     }
 25:
 26:     // while...
 27:     return MF.Shape();
 28: }
 29: 

二、倒角Chamfer Constructor

1BRepFilletAPI_MakeChamfer

BREpFilletAPI_MakeChamfer的使用方法与BRepFilletAPI_MakeFillet大致类似,但稍有不同:

a) The surfaces created are ruled and not smooth;

b) The Add syntax for selecting edges requires one or two distances, one edge and one face(contiguous to the edge);

Add(dist, E, F);

Add(d1, d2, E, F); with d1 on the face F.

Figure 5. Creating a chamfer

Figure 6. The box with chamfers

程序代码如下所示:

  1: TopoDS_Shape theBox = BRepPrimAPI_MakeBox(130,200,170);
  2: BRepFilletAPI_MakeChamfer MC(theBox);
  3: TopTools_IndexedDataMapOfShapeListOfShape M;
  4: TopExp::MapShapesAndAncestors(theBox,TopAbs_EDGE,TopAbs_FACE,M);
  5:
  6: for (Standar1d_Integer i;i<M.Extent();i++)
  7: {
  8:     TopoDS_Edge E = TopoDS::Edge(M.FindKey(i));
  9:     TopoDS_Face F = TopoDS::Face(M.FindFromIndex(i).First());
 10:     MC.Add(15,15,E,F);
 11: }
 12:
 13: TopoDS_Shape ChanfrenedBox = MC.Shape();
 14: 

OpenCascade Modeling Algorithms Fillets and Chamfers的更多相关文章

  1. OpenCascade Modeling Algorithms Boolean Operations

    Modeling Algorithms Boolean Operations of Opencascade eryar@163.com 布尔操作(Boolean Operations)是通过两个形状( ...

  2. OpenCASCADE Hidden Line Removal

    OpenCASCADE Hidden Line Removal eryar@163.com Abstract. To provide the precision required in industr ...

  3. OpenCascade Sweep Algorithm

    OpenCascade Sweep Algorithm eryar@163.com Abstract. Sweeps are the objects you obtain by sweeping a ...

  4. Overview of OpenCascade Library

    Overview of OpenCascade Library eryar@163.com 摘要Abstract:对OpenCascade库的功能及其实现做简要介绍. 关键字Key Words:Ope ...

  5. OpenCascade简介

    OpenCascade简介   Overview of OpenCascade Library eryar@163.com 摘要Abstract:对OpenCascade库的功能及其实现做简要介绍. ...

  6. A Simple OpenCASCADE Qt Demo-occQt

    A Simple OpenCASCADE Qt Demo-occQt eryar@163.com Abstract. OpenCASCADE have provided the Qt samples ...

  7. Building OpenCascade on Windows with Visual Studio

    Building OpenCascade on Windows with Visual Studio eryar@163.com 摘要Abstract:详细说明OpenCascade的编译配置过程,希 ...

  8. The Installation and Compilation of OpenCASCADE

    OpenCASCADE的编译 The Installation and Compilation of OpenCASCADE eryar@163.com 一. 安装OpenCASCADE 可以从Ope ...

  9. OpenCascade Primitives BRep - Box

    OpenCascade Primitives BRep - Box eryar@163.com Abstract. BRep is short for Boundary Representation. ...

随机推荐

  1. 神经网络hopfield的学习

    Hopfield神经网络使用说明. 该神经网络有两个特点: 1,输出值只有0,1 2,Hopfield没有输入(input) 这里解释一下第二个特点,什么叫没有输入?因为在使用Hopfield网络的时 ...

  2. ASDM through site to site VPN

    网上大部分文档只提到两个地方需要设置: 在6.2版本确实可以.但在7.2版本上只有用vpn client或anyconnect client连上的客户端可以用ASDM连上ASA,而通过site to ...

  3. php 正则

    1.中括号 [0-9]匹配0-9 [a-z]匹配a-z小写字母 [A-Z]匹配A-Z大写字母 [a-zA-Z]匹配所有大小写字母 可以使用ascii来制定更多 2.量词 p+匹配至少一个含p的字符串 ...

  4. .net(C#)访问Oracle数据库的几种免安装组件的对比

    Oracle 数据存取组件(ODAC) 库为Borland Delphi,C++ Builder 以及 Kylix提供了一些非可视化的组件.它们用来存取Oracle关系数据库系统.与BDE类似, OD ...

  5. Linux内核--网络栈实现分析(八)--应用层发送数据(下)

    本文分析基于Linux Kernel 1.2.13 原创作品,转载请标明http://blog.csdn.net/yming0221/article/details/7547826 更多请查看专栏,地 ...

  6. glibc2.14 install from centos

    安装glibc2.14 Tar xf glibc-2.14.tar.gz Cd glibc-2.14 Mkdir build Cd build ../configure –prefix=/opt/gl ...

  7. Linux下安装tomcat

    安装tomcat之前首先安装jdk,这个看前面的帖子. 下面说centeros6.5安装tomcat7的方法: 1.将apache-tomcat-7.0.29.tar.gz文件上传到/home/zha ...

  8. cocos2d-x 2.2.2 android平台移植

    1.完成以上工具的下载安装--cocos2d-x 2.2.2 --eclipse+adt+sdk --ndk 2.创建cocos2d-x工程 在"cocos2d-x-2.2.2\tools\ ...

  9. 在CentOS上搭建svn服务器及注意事项

    系统环境 CentOS 5.9 推荐使用yum install安装,比较简单   一.检查是否已经安装其他版本svn # rpm -qa subversion #卸载svn # yum remove ...

  10. mysql sql_safe_updates 不支持子查询的更新。

    考虑到开发人员有时候不小心误更新数据,要求线上库的 MySQL 实例都设置 sql_safe_updates=1 来避免没有索引的 update.delete. 结果有一天开发发现下面的一个SQL 没 ...