OpenCascade Modeling Algorithms Fillets and Chamfers
Modeling Algorithms Fillets and Chamfers
造型算法——倒圆与倒角
一、倒圆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
下面给出一个将创建一个倒圆的长方体,其尺寸分别为a,b,c,倒圆半径r。
Figure 2. Filleting a box
代码如下所示,创建上图所示的倒圆的长方体的参数分别为:
a = 100,b = 60,c = 80,r = 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
1.BRepFilletAPI_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:
PDF Version: Modeling Algorithms Fillets and Chamfers
OpenCascade Modeling Algorithms Fillets and Chamfers的更多相关文章
- OpenCascade Modeling Algorithms Boolean Operations
Modeling Algorithms Boolean Operations of Opencascade eryar@163.com 布尔操作(Boolean Operations)是通过两个形状( ...
- OpenCASCADE Hidden Line Removal
OpenCASCADE Hidden Line Removal eryar@163.com Abstract. To provide the precision required in industr ...
- OpenCascade Sweep Algorithm
OpenCascade Sweep Algorithm eryar@163.com Abstract. Sweeps are the objects you obtain by sweeping a ...
- Overview of OpenCascade Library
Overview of OpenCascade Library eryar@163.com 摘要Abstract:对OpenCascade库的功能及其实现做简要介绍. 关键字Key Words:Ope ...
- OpenCascade简介
OpenCascade简介 Overview of OpenCascade Library eryar@163.com 摘要Abstract:对OpenCascade库的功能及其实现做简要介绍. ...
- A Simple OpenCASCADE Qt Demo-occQt
A Simple OpenCASCADE Qt Demo-occQt eryar@163.com Abstract. OpenCASCADE have provided the Qt samples ...
- Building OpenCascade on Windows with Visual Studio
Building OpenCascade on Windows with Visual Studio eryar@163.com 摘要Abstract:详细说明OpenCascade的编译配置过程,希 ...
- The Installation and Compilation of OpenCASCADE
OpenCASCADE的编译 The Installation and Compilation of OpenCASCADE eryar@163.com 一. 安装OpenCASCADE 可以从Ope ...
- OpenCascade Primitives BRep - Box
OpenCascade Primitives BRep - Box eryar@163.com Abstract. BRep is short for Boundary Representation. ...
随机推荐
- 我的Sharepoint母版页的使用
在Sharepoint 2010母版页文件夹里面,有一个叫v4.master的母版页文件. 在它的基础上修改成想要的母版页.我们用最少的修改完成我们想要的效果. 我们有时是要这样的一个母版页,顶部Ri ...
- ok
第一个姑娘该是个爱你的人,出现在你没法区分爱和饥渴的时候.那时候你还在青春期的尾巴上,满脑子的性冲动混合着韩剧爱情幻想.你自尊脆弱而又怯懦无助,随便抓住哪一根稻草都当是救命的灵药. 她也许相貌平平,但 ...
- LightHttpd源码分析
源码:https://github.com/EZLippi/Tinyhttpd 要在Linux中编译,无需像代码注释所说那样: /* This program compiles for Sparc S ...
- hdu 4698 - Counting(思路)
转:题意:给定一个二维平面,其中x取值为1-N,y取值为1-M,现给定K个点,问至少包括K个点中的一个的满足要求的<Xmin, Xmax, Ymin, Ymax>共有多少中取值情况.也就是 ...
- python学习GUIwxpython不支持中文输出入的问题
# -*- coding: utf8 -*- import wx def load(event): file = open(filename.GetValue()) contents.SetValue ...
- Ubuntu Tftpd服务配置
---恢复内容开始--- 服务器端(ip:192.168.1.100) #安装tftpd-hpa sudo apt-get install tftpd-hpa 修改配置文件 sudo vim /etc ...
- Ubuntu NFSserver 简易安装及使用
服务器端(ip:192.168.1.100): sudo apt-get install nfs-kernel-server #安装nfs 客户端(ip:192.168.1.110): sudo ap ...
- STC12C5A60S2笔记3(I/O 端口)
1. 基本特性 STC 单片机IO口可由软件配置成四种工作模式: 1)准双向口:标准51单片机模式,可用作输入和输出 2) 推挽输入输出:需要更大的驱动电流,当高电平时,拉电流20mA.当低电平时,灌 ...
- MySQL3:索引
什么是索引 索引是对数据库表中一列或者多列的值进行排序的一种结构,所引用于快速找出在某个列中有一特定值的行.不使用索引,MySQL必须从第一条记录开始读完整个表,直到找出相关的行.表越大,查询数据所花 ...
- 今天心情好,一起探讨下《送给大家的200兆SVN代码服务器》怎么管理我们的VS代码?
前几天给大家免费送了个200兆SVN代码服务器(今天心情好,给各位免费呈上200兆SVN代码服务器一枚,不谢!),还木有领取的速度戳链接哦! 好几位园友拿到SVN服务器都对其赞不绝口,我也用这个服务器 ...