Open CASCADE学习|创建多段线与圆

使用Open CASCADE Technology (OCCT)库来创建和显示一些2D几何形状。

主要过程如下:

**包含头文件:**代码首先包含了一些必要的头文件,这些头文件提供了创建和显示几何形状所需的类和函数。

**定义变量:**在main函数中,定义了一些变量来表示圆的半径、直径、螺旋部分的高度、旋转的总角度等。

**创建矩形:**使用BRepBuilderAPI_MakePolygon类来创建一个矩形。矩形的顶点坐标被添加到rectangle1中。

**创建圆:**使用Geom2d_Circle类创建两个2D圆。这些圆在XY平面上,并且中心在原点。第一个圆的半径为R,第二个圆的半径为Rr。使用BRepBuilderAPI_MakeEdge2d类将上述的两个2D圆转换为2D边(TopoDS_Edge)。

**显示形状:**创建了一个Viewer对象vout,该对象用于显示几何形状。使用vout << rectangle1;、vout << circle1;和vout << circle2;将矩形和两个圆添加到视图中。使用vout.StartMessageLoop();启动消息循环,以便用户可以与显示的形状进行交互。

cpp 复制代码
#include <AIS_Shape.hxx>
#include <V3d_View.hxx>
#include <V3d_Viewer.hxx>
#include <AIS_InteractiveContext.hxx>
#include <V3d_View.hxx>
#include "Viewer.h"
​
​
#include <TopoDS.hxx>
#include <BRepBuilderAPI_MakePolygon.hxx>
#include <Geom2d_Circle.hxx>
#include <BRepBuilderAPI_MakeEdge2d.hxx>
#include <Geom_Plane.hxx>
​
​
int main(int argc, char** argv)
{
  Standard_Real R = 4.;//outer radius
  Standard_Real D = 2 * R;//diameter
  Standard_Real Rr = 3.5;//outer radius minus body clearance
  Standard_Real b = 1.;//web thickness
  Standard_Real d = b / 2;//
  Standard_Real H = 80.;//height of the spiral part
  Standard_Real a = 3. * M_PI;//total angle of spiral rotation
  Standard_Real sigma = 118;//point angel in degrees
​
  BRepBuilderAPI_MakePolygon rectangle1;
  rectangle1.Add(gp_Pnt(d, -R, 0));
  rectangle1.Add(gp_Pnt(R, -R, 0));
  rectangle1.Add(gp_Pnt(-d, R, 0));
  rectangle1.Add(gp_Pnt(-R, R, 0));
  rectangle1.Add(gp_Pnt(d, -R, 0));
  Handle(Geom2d_Circle) c1=new Geom2d_Circle(gp_Ax22d(gp_Pnt2d(0, 0), gp_Dir2d(0,1)), R);
  TopoDS_Edge circle1 = BRepBuilderAPI_MakeEdge2d(c1);
  Handle(Geom2d_Circle) c2 = new Geom2d_Circle(gp_Ax22d(gp_Pnt2d(0, 0), gp_Dir2d(0, 1)), Rr);
  TopoDS_Edge circle2 = BRepBuilderAPI_MakeEdge2d(c2);
  Viewer vout(50, 50, 500, 500);
  vout << rectangle1;
  vout << circle1;
  vout << circle2;
  vout.StartMessageLoop();
  return 0;
​
}
​
相关推荐
xlp666hub1 小时前
Leetcode 第三题:用C++解决最长连续序列
c++·leetcode
会员源码网2 小时前
构造函数抛出异常:C++对象部分初始化的陷阱与应对策略
c++
xlp666hub5 小时前
Leetcode第二题:用 C++ 解决字母异位词分组
c++·leetcode
不想写代码的星星5 小时前
static 关键字:从 C 到 C++,一篇文章彻底搞懂它的“七十二变”
c++
xlp666hub21 小时前
Leetcode第一题:用C++解决两数之和问题
c++·leetcode
不想写代码的星星1 天前
C++继承、组合、聚合:选错了是屎山,选对了是神器
c++
不想写代码的星星2 天前
std::function 详解:用法、原理与现代 C++ 最佳实践
c++
樱木Plus4 天前
深拷贝(Deep Copy)和浅拷贝(Shallow Copy)
c++
blasit6 天前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip
肆忆_7 天前
# 用 5 个问题学懂 C++ 虚函数(入门级)
c++