首页 > 其他分享 >(web查看三维CAD图纸)在三维网页CAD中绘制一个窗户模型

(web查看三维CAD图纸)在三维网页CAD中绘制一个窗户模型

时间:2024-10-30 10:31:48浏览次数:7  
标签:web const mxcad3d MdGe 三维 Mx3dGePoint new pts CAD

前言

本文使用mxcad3d在网页中创建一个简单的三维窗户模型,mxcad3d提供了丰富的三维建模功能和便捷的API,使得创建各种三维模型变得简单方便,最终效果如下图:

 

环境搭建和入门

首先学习mxcad的基本使用方法,可通过官方的入门教程来搭建一个最基本的项目模板,依次查看教程:安装`Node.js`以及`VS Code`开发工具创建mxcad开发项目API文档接口使用说明

完整测试项目压缩包,下载解压后需要在项目目录下打开`cmd命令行`,然后在命令行中执行`npm install`来安装依赖,然后再按照本教程中的方式来运行项目查看效果。 

编写创建窗户模型的代码

1. 根据官方快速入门教程来创建一个名为`Test3dWindow`的项目,如下图:

 

2. 编写绘制窗户模型的代码

在index.html中插入一个按钮"绘制窗户模型", index.html的完整代码如下:

   <!DOCTYPE html>
   <html lang="en">
   <head>
       <meta charset="UTF-8">
       <meta http-equiv="X-UA-Compatible" content="IE=edge">
       <meta name="viewport" content="width=device-width, initial-scale=1.0">
       <title>vite use mxcad</title>
   </head>
   <body>
       <div style="height: 800px; overflow: hidden;"> <canvas id="myCanvas"></canvas></div>
       <button>绘制窗户模型</button>
       <script type="module" src="./src/index.ts"></script>
   </body>
   </html>

在src/index.ts中编写绘制窗户模型的函数,src/index.ts的完整代码如下:

   import { MdGe, Mx3dGeAxis, Mx3dGeColor, Mx3dGeDir, Mx3dGeMaterial, Mx3dGeomPlane, Mx3dGePoint, Mx3dGeVec, Mx3dMkBox, Mx3dMkFace, Mx3dMkPolygon, Mx3dMkPrism, MxCAD3DObject } from "mxcad"
   // 创建mxcad3d对象
   const mxcad3d = new MxCAD3DObject()
   // 初始化mxcad3d对象
   mxcad3d.create({
       // canvas元素的css选择器字符串(示例中是id选择器),或canvas元素对象
       canvas: "#myCanvas",
       // 获取加载wasm相关文件(wasm/js/worker.js)路径位置
       locateFile: (fileName)=> new URL(`/node_modules/mxcad/dist/wasm/3d/${fileName}`, import.meta.url).href,
   })
   // 初始化完成
   mxcad3d.on("init", ()=>{
       console.log("初始化完成");
       // 修改背景颜色
       const color1 = new Mx3dGeColor(61/255, 139/255, 221/255, MdGe.MxTypeOfColor.Color_TOC_sRGB);
       const color2 = new Mx3dGeColor(203/255, 223/255, 247/255, MdGe.MxTypeOfColor.Color_TOC_sRGB);
       mxcad3d.setGradientBgColor(color1, color2, MdGe.MxGradientFillMethod.GFM_VER);
       // 设置透视投影
       mxcad3d.setProjectionType(MdGe.MxCameraProjection.CProjection_Perspective);
       // 打开光照阴影
       mxcad3d.enableDirLightSrc(true);
   });
   function drawWindow(){
     // 窗户边框横截面轮廓点
     const pts: Mx3dGePoint[] = [];
     pts.push(new Mx3dGePoint(0, 0, 0));
     pts.push(new Mx3dGePoint(1, 0, 0));
     pts.push(new Mx3dGePoint(1, 0, 2));
     pts.push(new Mx3dGePoint(4, 0, 2));
     pts.push(new Mx3dGePoint(4, 0, 0));
     pts.push(new Mx3dGePoint(5, 0, 0));
     pts.push(new Mx3dGePoint(5, 0, 10));
     pts.push(new Mx3dGePoint(3, 0, 10));
     pts.push(new Mx3dGePoint(3, 0, 8));
     pts.push(new Mx3dGePoint(2, 0, 8));
     pts.push(new Mx3dGePoint(2, 0, 10));
     pts.push(new Mx3dGePoint(0, 0, 10));
     // 窗户边框横截面轮廓多段线
     const polygon = new Mx3dMkPolygon();
     pts.forEach((pt) => polygon.Add(pt));
     polygon.Close();
     // 窗户边框横截面轮廓线
     const wire = polygon.Wire();
     // 窗户边框横截面轮廓线生成窗框横截面
     const makeface = new Mx3dMkFace(wire);
     const face = makeface.Face();
     const vec = new Mx3dGeVec(0, 100, 0);
     // 横截面拉伸出窗框体形状
     const frame = new Mx3dMkPrism(face, vec);
     let frameShape = frame.Shape();
     // 构造两个平面用于分割窗户边框(边框两端的斜45度角)
     const pt = new Mx3dGePoint(0, 0, 0);
     const dir = new Mx3dGeDir(0, -1, 1);
     const plane = new Mx3dGeomPlane(pt, dir);
     // 平面1
     const planeFace = plane.Face(1e-5);
     pt.setXYZ(0, 50, 0);
     dir.SetXYZ(0, 0, 1);
     const axis = new Mx3dGeAxis(pt, dir);;
     // 平面2
     const planeFace2 = planeFace.MirroredByAxis(axis);
     // 分割窗户边框(分割成了两个斜45度的小三角形部分和中间的一个梯形部分)
     const parts = frameShape.spliter([planeFace, planeFace2]);
     // 筛选出中间那个梯形的部分(这里是通过质心的位置来判断的)
     parts.forEach((shape)=>{
       // 这里Centroid的参数添填的MdGe.MxQuantAspect.Quant_Volume这个枚举,是因为shape是实体,它的质心是体质心,所以这里填MdGe.MxQuantAspect.Quant_Volume
       // 如果shape是面,它的质心是面质心,所以要填MdGe.MxQuantAspect.Quant_Area
       // 如果shape是线,它的质心是线质心,所以要填MdGe.MxQuantAspect.Quant_Length
       const centroid = shape.Centroid(MdGe.MxQuantAspect.Quant_Volume);
       if (centroid.Y() > 45 && centroid.Y() < 55) {
         frameShape = shape;
       }
     });
     // 通过旋转得到另外三个边的边框
     const frameShape2 = frameShape.Rotated(new Mx3dGeAxis([0, 50, 50], [1, 0, 0]), Math.PI / 2);
     const frameShape3 = frameShape.Rotated(new Mx3dGeAxis([0, 50, 50], [1, 0, 0]), Math.PI);
     const frameShape4 = frameShape2.Rotated(new Mx3dGeAxis([0, 50, 50], [1, 0, 0]), Math.PI);
     // 合并四个边框,获得边框整体形状
     frameShape = frameShape.fuse(frameShape2).fuse(frameShape3).fuse(frameShape4);
     // 窗框颜色
     const frameColor = new Mx3dGeColor(0.5, 0.5, 0.5, MdGe.MxTypeOfColor.Color_TOC_RGB);
     // 窗框材质
     const frameMaterial = new Mx3dGeMaterial(MdGe.MxNameOfMaterial.Material_NOM_ShinyPlastified);
     // 玻璃
     const glass = new Mx3dMkBox([2, 8, 8], [3, 92, 92]);
     // 玻璃形状
     const glassShape = glass.Shape();
     // 玻璃颜色
     const glassColor = new Mx3dGeColor(0, 0.9, 0.549, MdGe.MxTypeOfColor.Color_TOC_RGB);
     // 玻璃材质,看起来是透明的
     const glassMaterial = new Mx3dGeMaterial(MdGe.MxNameOfMaterial.Material_NOM_Glass);
     // 获取模型文档
     const doc = mxcad3d.getDocument();
     // 新增一个形状标签用于保存边框形状
     const frameLabel = doc.addShapeLabel();
     frameLabel.setShape(frameShape);
     frameLabel.setColor(frameColor)
     frameLabel.setMaterial(frameMaterial);
     // 新增一个形状标签用于保存玻璃形状
     const glassLabel = doc.addShapeLabel();
     glassLabel.setShape(glassShape);
     glassLabel.setColor(glassColor)
     glassLabel.setMaterial(glassMaterial);
     // 更新视图显示
     mxcad3d.update();
   }
   // 给button添加点击事件,点击后调用drawWindow函数,进行窗户模型的绘制
   // 立即执行函数
   (function addEventToButton(){
     const btn = document.querySelector("button");
     if (btn) {
       btn.addEventListener("click", () => {
         drawWindow();
       });
     }
   })()

3. 新建终端,运行`npx vite`命令来运行项目,效果如下图:

 

标签:web,const,mxcad3d,MdGe,三维,Mx3dGePoint,new,pts,CAD
From: https://www.cnblogs.com/yzy0224/p/18515312

相关文章

  • 【SpringMVC】web服务器,访问失败的问题,SpringMVC,建立连接,请求
    【web服务器】web服务器可以对http协议进行封装,程序员不需要直接对http协议进行操作(不需要去写复杂的网络编程代码),让web开发更加便捷,所以它也有「WWW服务器」的称呼常见的web服务器:Tomcat,Jboss,IIS等SpringBoot内置了Tomcat服务器,无需配置即可使用Tomcat默认端口是「8080」......
  • webstorm 项目如何配置支持 nodejs
    WebStorm是JetBrAIns推出的一款强大的JavaScript开发IDE,支持Node.js是其内置的功能。要配置WebStorm以支持Node.js项目,您需要进行几个步骤:确保已安装Node.js、在WebStorm中配置Node.js解释器、设置语言版本及库、调整运行/调试配置。下面,我们将详细介绍如何进行这些设......
  • 2007版cad安装不上缺少net3.5怎么办
    浏览器地址栏输入www.dnz9.com远程解决netframework问题如果在安装2007版CAD(如AutoCAD2007)时遇到缺少.NET组件的问题,可以按照以下步骤进行解决:一、检查并安装.NETFramework打开控制面板:点击“开始”按钮,选择“控制面板”。进入程序和功能:在控......
  • 未安装net无法安装cad2007安装不上怎么解决?
    未安装net无法安装cad2007安装不上怎么解决?若要顺利安装CAD2007,您首先需要确保您的计算机上已正确安装了.NETFramework。这一关键组件为软件提供了必要的运行环境,从而保证CAD2007能够顺畅运作。在开始安装CAD之前,请检查并安装所需的.NETFramework版本,以避免出现兼容性问题......
  • 关于自己写阿里云OSS相关工具类的自动配置(黑马web开发day14)
    阿里云OSS的自动配置主要分为:驱动类:aliyun-oss-spring-boot-autoconfigure自动配置类:aliyun-oss-spring-boot-starter文章目录aliyun-oss-spring-boot-starter创建aliyun-oss-spring-boot-starteraliyun-oss-spring-boot-autoconfigure创建aliyun-oss-spring-boot-aut......
  • Webstorm 2024 安装使用 (附加永久激活码、补丁)
    下载安装第二步,安装完成之后,下载补丁下载地址(里面包含激活码)完成,之后输入激活码免责声明:本文中的资源均来自互联网,仅供个人学习和交流使用,严禁用于商业行为,下载后请在24小时内从电脑中彻底删除。对于因非法使用而引起的版权争议,与作者无关。所有资源仅供学习、参考......
  • springmvc-servlet.xml和web.xml文件的存放路径是哪里?项目添加到Tomcat上运行后就报错
        用eclipse写了一个简单的web项目,springmvc-servlet.xml文件和web.xml文件都配置好了,运行起来能看见hello的web页面,但是有一堆报错,不知道是什么原因                                     ......
  • javascript-Web APLs (三)
     事件流指的是事件完整执行过程中的流动路径 说明:假设页面里有个div,当触发事件时,会经历两个阶段,分别是捕获阶段、冒泡阶段 简单来说:捕获阶段是从父到子冒泡阶段是从子到父 实际工作都是使用事件冒泡为主事件捕获DOM.addEventListener(事件类型,事件处......
  • ctfshow-web入门-爆破(24)
    1.根据题目提示:参考PHP随机数的伪随机数mt_srand(seed);函数播种MersenneTwister随机数生成器。seed,可选。从PHP4.2.0开始,随机数生成器自动播种,因此没有必要使用该函数因此不需要播种,并且如果设置了seed参数生成的随机数就是伪随机数,意思就是每次生成的随机数是一......
  • 2024网鼎杯初赛-青龙组-WEB gxngxngxn
    WEB01开局随便随便输入都可以登录,登上去以后生成了一个token和一个session,一个是jwt一个是flask框架的这边先伪造jwt,是国外的原题CTFtime.org/DownUnderCTF2021(线上)/JWT/Writeup先生成两个token,然后利用rsa_sign2n工具来生成公钥python3jwt_forgery.pyeyJhbGciOi......