百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

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

yund56 2025-05-12 16:43 27 浏览

前言

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

安装

在此之前,需要先安装mxcad包,安装的步骤可以查看梦想CAD官方的入门教程,如下图:

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

代码编写及效果展示

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();  
    });  
  }  
})()

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

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

相关推荐

SM小分队Girls on Top,女神战队少了f(x)?

这次由SM娱乐公司在冬季即将开演的smtown里,将公司的所有女团成员集结成了一个小分队project。第一位这是全面ACE的大姐成员权宝儿(BoA),出道二十年,在日本单人销量过千万,韩国国内200...

韩国女团 aespa 首场 VR 演唱会或暗示 Quest 3 将于 10 月推出

AmazeVR宣布将在十月份举办一场现场VR音乐会,观众将佩戴MetaQuest3进行体验。韩国女团aespa于2020年11月出道,此后在日本推出了三张金唱片,在韩国推出了...

韩网热议!女团aespa成员Giselle在长腿爱豆中真的是legend

身高163的Giselle,长腿傲人,身材比例绝了...

假唱而被骂爆的女团:IVE、NewJeans、aespa上榜

在韩国,其实K-pop偶像并不被认为是真正的歌手,因为偶像们必须兼备舞蹈能力、也经常透过对嘴来完成舞台。由于科技的日渐发达,也有许多网友会利用消音软体来验证K-pop偶像到底有没有开麦唱歌,导致假唱这...

新女团Aespa登时尚大片 四个少女四种style

来源:环球网

韩国女团aespa新歌MV曝光 画面梦幻造型超美

12月20日,韩国女团aespa翻唱曲《DreamsComeTrue》MV公开,视频中,她们的造型超美!WINTER背后长出一双梦幻般的翅膀。柳智敏笑容甜美。宁艺卓皮肤白皙。GISELLE五官精致...

女网友向拳头维权,自称是萨勒芬妮的原型?某韩国女团抄袭KDA

女英雄萨勒芬妮(Seraphine)是拳头在2020年推出的第五位新英雄,在还没有正式上线时就备受lsp玩家的关注,因为她实在是太可爱了。和其他新英雄不同的是,萨勒芬妮在没上线时就被拳头当成虚拟偶像来...

人气TOP女团是?INS粉丝数见分晓;TWICE成员为何在演唱会落泪?

现在的人气TOP女团是?INS粉丝数见分晓!现在爱豆和粉丝之间的交流方法变得多种多样,但是Instagram依然是主要的交流手段。很多粉丝根据粉丝数评价偶像的人气,拥有数百、数千万粉丝的组合作为全球偶...

韩国女团MVaespa Drama MV_韩国女团穿超短裙子跳舞

WelcometoDrama.Pleasefollow4ruleswhilewatchingtheDrama.·1)Lookbackimmediatelywhenyoufe...

aespa师妹团今年将出道! SM职员亲口曝「新女团风格、人数」

记者刘宛欣/综合报导南韩造星工厂SM娱乐曾打造出东方神起、SUPERJUNIOR、少女时代、SHINee、EXO等传奇团体,近年推出的aespa、RIIZE更是双双成为新生代一线团体,深受大众与粉丝...

南韩最活跃的女团aespa,新专辑《Girls》即将发布,盘点昔日经典

女团aespa歌曲盘点,新专辑《Girls》即将发布,期待大火。明天也就是2022年的7月8号,aespa新专辑《Girls》即将发行。这是继首张专辑《Savage》之后,时隔19个月的第二张专辑,这...

章泽天女团aespa出席戛纳晚宴 宋康昊携新片亮相

搜狐娱乐讯(山今/文玄反影/图科明/视频)法国时间5月23日晚,女团aespa、宋康昊、章泽天等明星亮相戛纳晚宴。章泽天身姿优越。章泽天肩颈线优越。章泽天双臂纤细。章泽天仪态端正。女团aespa亮...

Aespa舞台暴露身高比例,宁艺卓脸大,柳智敏有“TOP”相

作为SM公司最新女团aespa,初舞台《BlackMamba》公开,在初舞台里,看得出来SM公司是下了大功夫的,虽然之前SM公司新出的女团都有很长的先导片,但是aespa显然是有“特殊待遇”。运用了...

AESPA女团成员柳智敏karina大美女

真队内速度最快最火达成队内首个且唯一两百万点赞五代男女团中输断层第一(图转自微博)...

对来学校演出的女团成员语言性骚扰?韩国这所男高的学生恶心透了

哕了……本月4日,景福男子高中相关人士称已经找到了在SNS中上传对aespa成员进行性骚扰文章的学生,并开始着手调查。2日,SM娱乐创始人李秀满的母校——景福高中迎来了建校101周年庆典活动。当天,S...