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();启动消息循环,以便用户可以与显示的形状进行交互。

#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 radiusStandard_Real D = 2 * R;//diameterStandard_Real Rr = 3.5;//outer radius minus body clearanceStandard_Real b = 1.;//web thicknessStandard_Real d = b / 2;//Standard_Real H = 80.;//height of the spiral partStandard_Real a = 3. * M_PI;//total angle of spiral rotationStandard_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;
​
}
​

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/459713.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

seata安装部署手册

1. 准备介质 seata-server-1.5.2.tar.gz2. 解压 tar-xzvf seata-server-1.5.2.tar.gz3. 创建数据库 数据库脚本位置&#xff1a;seata/script/server/db 4. 修改配置文件 bin目录 ---> 运行脚本 conf目录 ---> 配置文件 lib目录 ---> 依赖库 logs目录 ---> …

网神 SecGate 3600 防火墙 route_ispinfo_import_save 文件上传漏洞

免责声明&#xff1a;文章来源互联网收集整理&#xff0c;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;所产生的一切不良后果与文章作者无关。该…

codemirror光标样式问题

输入框为空时会显示placeholder&#xff0c;文字有点长换行了&#xff0c;光标竟然变成上图那样了&#xff0c;我试过如果placeholder文字是三行&#xff0c;那么光标就是三行高。真是见了鬼了。查到最后&#xff0c;原因竟然是因为我在用vue-codemirror时为了去掉一些basicSet…

9.6整数拆分(LC343-M)

算法&#xff1a; 动规五部曲&#xff1a; 1.确定dp[i]及i dp[i]&#xff1a;分拆数字i&#xff0c;可以得到的最大乘积为dp[i] 2.确定递推公式&#xff1a; 思路&#xff1a;dp[i]最大乘积是怎么得到的&#xff1f; 其实可以从1遍历j&#xff0c;然后有两种渠道得到dp[i…

洛希极限

L1-3 洛希极限 分数 10 作者 陈越 单位 浙江大学 科幻电影《流浪地球》中一个重要的情节是地球距离木星太近时&#xff0c;大气开始被木星吸走&#xff0c;而随着不断接近地木“…

OpenShift AI - 运行欺诈检测模型和流程

《OpenShift / RHEL / DevSecOps 汇总目录》 说明&#xff1a;本文已经在 OpenShift 4.14 RHODS 2.50 的环境中验证 文章目录 准备运行环境安装 OpenShift AI 环境安装 Minio 对象存储软件创建 Data Science Project创建 Data connection创建 Workbench配置 Model server创建 …

AD9361多片同步设计方法

本文基于ZC706FMCOMMS5的平台&#xff0c;介绍了多片AD9361同步的方法。并将该设计移植到自行设计的ZYNQ70354片AD9361(实现8路同步收发)的电路板上。本设计采用纯逻辑的方式&#xff0c;仅使用了ZYNQ芯片的PL部分。 9361多芯片同步主要包括基带同步和射频同步两大块任务。其中…

【JavaScript 漫游】【011】ES5 规范中 Array 对象方法汇总

文章简介 本文为【JavaScript 漫游】专栏的第 011 篇文章&#xff0c;记录的内容包含了 ES5 规范中Array 对象的所有方法。 Array()Array.isArray()valueOf()、toString()push()、pop()shift()、unshift()join()concat()reverse()slice()splice()sort()map()forEach()filter(…

基于AST实现一键自动提取替换国际化文案

背景&#xff1a;在调研 formatjs/cli 使用&#xff08;使用 formatjs/cli 进行国际化文案自动提取 &#xff09;过程中&#xff0c;发现有以下需求formatjs/cli 无法满足&#xff1a; id 需要一定的语义化&#xff1b; defaultMessage和Id不能直接hash转换&#xff1b; 需要…

怎么将文件夹里的所有 js 文件按照名称跟内容拼接生成一个 md 文件?

实现 编写脚本 build/generate-md.js const fs require("fs"); const path require("path");function traverseDirectorySync(dirPath) {const files fs.readdirSync(dirPath);files.forEach((file) > {const filePath path.join(dirPath, file);…

ctfshow——命令执行

文章目录 web 29——通配符*绕过web30——调用其他命令执行函数web 31——参数逃逸web 32-web 36——配合文件包含伪协议web 37-web 39——文件包含web 40—— web 29——通配符*绕过 i不区分大小写&#xff0c;直接?csystem(tac fl*.php); web30——调用其他命令执行函数 调用…

携程网首页案例制作(移动端)

技术选型 方案&#xff1a;采用单独制作移动页面方案 技术&#xff1a;布局采用flex布局 body样式 通常要设置最大宽度&#xff0c;最小宽度&#xff0c;水平居中&#xff0c;字体设置&#xff0c;背景颜色以及相关初始化 body {max-width: 540px;min-width: 320px;margin…