首页 > 其他分享 >如何在网页3D CAD中创建一个三维管道模型

如何在网页3D CAD中创建一个三维管道模型

时间:2024-09-03 11:52:14浏览次数:3  
标签:Mx3dShapeEdge const 管道 Mx3dGePoint 一个三维 new 100 3D CAD

前言

在网页CAD中进行三维建模是一项有趣的任务。本文将介绍如何利用mxcad3d来创建三维管道模型。该工具提供了一系列三维建模功能的API,使得建立复杂的管道结构变得简单直观。

公众号:梦想云图网页CAD。

安装

在此之前,需要先安装mxcad包,安装的步骤可以查看梦想CAD官方的入门教程:https://help.mxdraw.com/?pid=32,如下图:

 

本次教程我们新建一个Test3dPipe目录,然后在此目录中按照官方入门教程进行初始化项目,最后使用VS Code打开这个项目,如下图:  

本次教程的完整项目代码可以在这里下载:https://gitee.com/mxcadx/mxcad_docs/tree/master/examples3D/Test3dPipe.7z

代码编写及效果展示

1. 添加绘制按钮

在index.html文件中添加一个按钮,用于点击后绘制管道,如下图: 

2. 编写绘制管道的函数

2.1本教程演示如何创建一个圆角方管,以下是在index.ts绘制圆角方管的函数代码,先导入需要用到的模块,代码如下:

// 从mxcad中导入需要用到的模块
import { MxCAD3DObject, MdGe, Mx3dAlgoFillet2d, Mx3dGeColor, Mx3dGeCSYSR, Mx3dGeDir, Mx3dGeMaterial, Mx3dGeomCircle,
Mx3dGePlane, Mx3dGePoint, Mx3dMkFace, Mx3dMkPipe, Mx3dShapeDownCast, Mx3dShapeEdge,
Mx3dShapeFace, Mx3dShapeWire, Mx3dWireTool } from "mxcad"

2.2编写绘制管道的函数,代码如下:

  function drawRoundRectPipe() {  
     // 管道用到的颜色材质  
    const grayColor = new Mx3dGeColor(MdGe.MxNameOfColor.Color_NOC_GRAY25);  
    const mat = new Mx3dGeMaterial(MdGe.MxNameOfMaterial.Material_NOM_Steel);  
     // 管道的路径,由直线和圆弧构成,必须C1连续。  
    let wire: Mx3dShapeWire;  
    {  
      const pt1 = new Mx3dGePoint(0, 0, 0);  
      const pt2 = new Mx3dGePoint(0, 0, 85);  
       // 直线段  
      const edge1 = new Mx3dShapeEdge(pt1, pt2);         
      const filletCsysr1 = new Mx3dGeCSYSR(new Mx3dGePoint(15, 0, 85), new Mx3dGeDir(0, -1, 0), new Mx3dGeDir(0, 0, 1));  
      const fillet1 = new Mx3dGeomCircle(filletCsysr1, 15);  
       // 圆弧  
      const edge2 = fillet1.Edge(0, Math.PI / 2);  
      const pt3 = new Mx3dGePoint(15, 0, 100);  
      const pt4 = new Mx3dGePoint(85, 0, 100);  
       // 直线段  
      const edge3 = new Mx3dShapeEdge(pt3, pt4);  
      const filletCsysr2 = new Mx3dGeCSYSR(new Mx3dGePoint(85, 15, 100), new Mx3dGeDir(0, 0, 1), new Mx3dGeDir(0, -1, 0));  
      const fillet2 = new Mx3dGeomCircle(filletCsysr2, 15);  
       // 圆弧  
      const edge4 = fillet2.Edge(0, Math.PI / 2);  
      const pt5 = new Mx3dGePoint(100, 15, 100);  
      const pt6 = new Mx3dGePoint(100, 85, 100);  
       // 直线段  
      const edge5 = new Mx3dShapeEdge(pt5, pt6);  
      const filletCsysr3 = new Mx3dGeCSYSR(new Mx3dGePoint(100, 85, 115), new Mx3dGeDir(1, 0, 0), new Mx3dGeDir(0, 0, -1));  
      const fillet3 = new Mx3dGeomCircle(filletCsysr3, 15);  
       // 圆弧  
      const edge6 = fillet3.Edge(0, Math.PI / 2);  
      const pt7 = new Mx3dGePoint(100, 100, 115);  
      const pt8 = new Mx3dGePoint(100, 100, 200);  
       // 直线段  
      const edge7 = new Mx3dShapeEdge(pt7, pt8);  
      const shape = Mx3dWireTool.ConnectEdgesToWires([edge1, edge2, edge3, edge4, edge5, edge6, edge7], 1e-6, false)[0];  
       // 得到最后连接组合而成的管道路径  
      wire = Mx3dShapeDownCast.Wire(shape);  
    }  
     // 管道横截面形状,由一个内圆角方形和外圆角方形之间构成的区域  
    let faceRoundRect:Mx3dShapeFace;  
    {  
      const pts: Mx3dGePoint[] = [];  
      const pt1 = new Mx3dGePoint(0, 0, 0);  
      const pt2 = new Mx3dGePoint(0, 10, 0);  
      const pt3 = new Mx3dGePoint(10, 10, 0);  
      const pt4 = new Mx3dGePoint(10, 0, 0);     
      pts.push(pt2);  
      pts.push(pt3);  
      pts.push(pt4);  
      pts.push(pt1);  
       // 四条直线段构成正方形  
      const edges: Mx3dShapeEdge[] = [];  
      const edge1 = new Mx3dShapeEdge(pt1, pt2);  
      const edge2 = new Mx3dShapeEdge(pt2, pt3);  
      const edge3 = new Mx3dShapeEdge(pt3, pt4);  
      const edge4 = new Mx3dShapeEdge(pt4, pt1);  
      edges.push(edge1);  
      edges.push(edge2);  
      edges.push(edge3);  
      edges.push(edge4);     
       // 四条直线段,循环进行二维倒圆角,圆角放入arcs数组。  
      const arcs: Mx3dShapeEdge[] = [];  
      for(let i = 0; i < edges.length; i++)  
      {  
         // 矩形所在平面,默认构造就是在XOY平面(右手系)  
        const pln = new Mx3dGePlane();  
         // 二维倒圆角算法对象  
        const f2d = new Mx3dAlgoFillet2d();  
        if (i < edges.length - 1) {  
           // 初始化时,传入两条要进行倒圆角的直线段,以及他们所在的平面(必须是在同一平面)  
          f2d.Init(edges[i], edges[i + 1], pln);  
           // 执行倒圆角算法,圆角半径为2  
          f2d.Perform(2);  
           // Result方法返回倒圆角算法在所在点执行倒圆角后的圆弧段,Result方法传入第一个参数是要执行倒圆角的点,因为我们当前是两个直线段倒圆角,所以就只有在这两个直线段的交点或延长后的交点倒圆角,只有这个一个交点,所以这里就传入这个交点,如果不是两直线段倒圆角,比如一个直线段和一个圆弧,他们就可能有两个交点,这时就要指定要返回哪个交点处倒圆角的结果了。第二个参数和第三个参数分别传入参与倒圆角的两条直线段,Result方法会将这两个参数修改为倒圆角之后改变过后的两条直线段。  
          arcs.push(f2d.Result(pts[i], edges[i], edges[i + 1]));  
        }  
        else{  
          f2d.Init(edges[i], edges[0], pln);  
          f2d.Perform(2);  
          arcs.push(f2d.Result(pts[i], edges[i], edges[0]));  
        }  
      }  
       // 连接所有的直线段和圆弧  
      const wireOuterShape = Mx3dWireTool.ConnectEdgesToWires([...edges, ...arcs], 1e-6, false)[0];  
       // 外圈  
      const wireOuter = Mx3dShapeDownCast.Wire(wireOuterShape);  
       // 内圈  
      const wireInner = wireOuter.Scaled(new Mx3dGePoint(5, 5, 0), 0.8);  
       // 内圈方向要进行个反向  
      wireInner.reverse();  
       // 生成内外圈之间构成的环面  
      const faceMaker = new Mx3dMkFace(wireOuter, true);  
      faceMaker.Add(wireInner);  
      faceRoundRect = faceMaker.Face();  
       // 移动到中心位置和管道路径起点一致  
      faceRoundRect.TranslateByVec(-5, -5, 0);  
    }  
   // 通过路径和截面生成管道形状  
    const pipe = new Mx3dMkPipe(wire, faceRoundRect);  
    const pipeShape = pipe.Shape();  
    
   // 给pipeShape设置材质颜色,放入模型文档并显示  
    mxcad3d.removeAll();  
    const doc = mxcad3d.getDocument();  
    const pipeShapeLabel = doc.addShapeLabel();  
    pipeShapeLabel.setShape(pipeShape);  
    pipeShapeLabel.setMaterial(mat);  
    pipeShapeLabel.setColor(grayColor);  
    mxcad3d.update();  
}

2.3然后给绘制按钮添加点击事件,触发绘制管道函数的调用,代码如下:

// 给button添加点击事件,点击后调用drawRoundRectPipe函数,进行圆角方管的绘制
// 立即执行函数 
(function addEventToButton(){  
  const btn = document.querySelector("button");  
  if (btn) {  
    btn.addEventListener("click", () =>  {  
      drawRoundRectPipe();  
    });  
  }  
})()

点击绘制管道按钮,效果如下图:

 

 

标签:Mx3dShapeEdge,const,管道,Mx3dGePoint,一个三维,new,100,3D,CAD
From: https://www.cnblogs.com/yzy0224/p/18394267

相关文章

  • Vue2 - 最新实现百度地图3D立体感视角教程及示例代码,利用WebGL实现3d百度地图详细流程
    前言如果您需要Vue3版本,请访问在vue2|nuxt2项目开发中,详解实现“安装引入百度地图webgl技术,实现3d地图教程”将百度地图变成3D视角效果,让百度地图平面2D视图和3D立体视图进行切换渲染显示,vue如何实现百度地图的三维立体地图效果,解决WebGL引入报错或无效、3D地图......
  • 中望CAD 专业 v2024 解锁版下载与安装教程 (CAD三维制图)
    安装步骤ZWCAD2024-SP1.3-x64-Chs-Setup+Crack:ZWCAD2024-SP1.3-x64-Chs-Setup+Crack.zip1、下载解压后点击如下进行安装2、选择安装目录,最好不要安装在系统盘(C盘)3、安装中...耐心等待2-3分钟4、安装完先不要运行它,点击完成即可5、回到我们解压的文件夹里面,访问crack文件......
  • Autodesk 3DS Max v2025 激活版下载及安装教程
    前言Autodesk3dsMax是一款功能强大的3D建模和动画解决方案,游戏开发人员、视觉效果艺术家和平面设计师使用它来创建庞大的世界、令人惊叹的场景和引人入胜的虚拟现实(VR)体验。Autodesk3DSMAX是业界使用最广泛的3D建模和动画软件程序之一,它将为用户提供一系列新功能和工......
  • 中望CAD 专业 v2024 激活版下载与安装教程 (CAD三维制图)
    下载链接:https://pan.xunlei.com/s/VO5mffK30G6Mota3eRjZpGB5A1?pwd=4gyi#安装步骤1、下载解压后点击如下进行安装2、选择安装目录,最好不要安装在系统盘(C盘)3、安装中...耐心等待2-3分钟4、安装完先不要运行它,点击完成即可5、回到我们解压的文件夹里面,访问crack文件夹,把里......
  • Unity3d 截屏保存到相册,并且刷新相册
    要做一个截图的功能,并且玩家可以在相册中看到。 做的时候遇到了三个问题: 1、unity自带的截图API,Application.CaptureScreenshot在Android上不生效 2、图片保存的路径获取 3、保存的图片可以在手机的文件管理中找到,但是相册中没有。 解决......
  • 打破工业实时库势力边界,TDengine 与工业 SCADA 深度融合
    TDengine随着时序数据库(TimeSeriesDatabase)的日益普及,越来越多的工业自动化控制(工控)人员开始认识到其强大能力。然而,时序数据库在传统实时数据库应用领域,特别是在过程监控层的推广仍面临挑战,主要原因在于缺乏适合操作技术(OT)人员使用的连接方式。在工业自动化的五层架构中,过程监控......
  • ARC183D 做题记录
    超棒的贪心构造题。可以观察到每次操作的两个叶子,充要条件是路径上匹配边和非匹配边交替出现,操作完后全部取反。首先考虑答案上界,从是否能取到上界入手,是本题的突破口。考虑操作两个叶子\(x,y\),收益为\(dep[x]+dep[y]-2dep[\text{LCA}(x,y)]\)。若固定根\(r\),当\(\text......
  • Open3D mesh Taubin滤波
    目录一、概述1.1原理1.2实现步骤1.3应用场景二、代码实现2.1关键函数参数详解返回值2.2完整代码三、实现效果3.1加入噪声的mesh3.2Taubin迭代10次3.3Taubin迭代100次Open3D点云算法汇总及实战案例汇总的目录地址:Open3D点云算法与点云深度学习案例汇总(长期更新)-......
  • 【从头写CAD】 转换矩阵类系列八,代码汇总
    为了找出优化代码的方案,梳理矩阵类现有代码。现汇总转换矩阵所有代码在同一个文件中,同时调整了与矩阵类重载的代码的先后次序。完整代码如下:/*矩阵类编程思路总说明:平面CAD对象主要包括点(point)、线(line含线段、直线、射线,宽线、多段线)、平面形状(shap含矩形、圆形、椭......
  • 点云和vtk 在3d处理上的优势
    点云和VTK在3D处理上各有其优势。让我们详细比较一下这两种方法在3D处理中的特点:点云(PointCloud)的优势:1.数据原始性:  -点云保留了原始的3D扫描数据,没有经过插值或重建,因此保持了最高的数据准确性。2.灵活性:  -可以轻松地进行空间操作,如旋转、平移、缩放等。 ......