Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >在线三维CAD中创建三维建筑墙体(在线建模CAD软件)

在线三维CAD中创建三维建筑墙体(在线建模CAD软件)

原创
作者头像
梦想云图网页CAD
发布于 2024-10-09 07:01:56
发布于 2024-10-09 07:01:56
2270
举报
文章被收录于专栏:网页CAD网页CAD

一、前言

1.本文将介绍如何使用mxcad3d来创建建筑墙体模型。该工具提供了丰富的三维建模功能和便捷的API,首先通过npm包管理器来新建测试项目并引入mxcad包,所以需要先安装Node.js,里面自带了npm包管理器 以及包含在npm包管理器中的npx工具 (用于启动运行我们的测试项目),Node.js下载和安装教程

更多详细的教程公Z号:梦想云图网页CAD。

二、新建测试项目

1.在合适的位置创建本次教程的测试项目文件夹Test3dWall ,并在Test3dWall 文件夹中打开cmd命令行工具 ,依次输入以下指令来初始化项目并引入mxcad包。新建项目的方法,依次输入以下操作命令,如下图:

npm init -y npm install vite -D npm install mxcad@latest

2. 使用VS CODE打开新建的测试项目文件夹(VS CODE是一款好用的集成开发工具,如何安装这里不再赘述,下载地址:https://code.visualstudio.com/Download

3.打开项目后,在项目目录下新建一个index.html文件以及一个src目录,然后在src目录下新建一个index.ts文件 并编写最基本的代码:

index.html

代码语言:txt
AI代码解释
复制
<!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>
    <script type="module" src="./src/index.ts"></script>
</body>
</html>

src/index.ts

代码语言:txt
AI代码解释
复制
import { 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("初始化完成");
});

三、运行测试

1.新建终端

2.开启服务

3.打开网页,查看效果

四、编写绘制建筑墙体的代码

1.墙体的二维平面设计图:

2.index.html中添加一个按钮(以下是index.html完整代码)

代码语言:txt
AI代码解释
复制
<!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>
    <script type="module" src="./src/index.ts"></script>
    <button>绘制建筑墙体</button>
</body>
</html>

3.src/index.ts中添加绘制墙体的代码,给按钮添加点击事件来触发绘制墙体的代码执行,以下是src/index.ts完整代码:

代码语言:txt
AI代码解释
复制
import { MxCAD3DObject, Mx3dGePoint, Mx3dMkPolygon, Mx3dMkFace, Mx3dMkPrism, Mx3dGeVec, Mx3dGeColor, MdGe } 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("初始化完成");
});
function funDrawWall(){
  // 外墙轮廓
  const wallOutterPts: Mx3dGePoint[] = [];
  wallOutterPts.push(new Mx3dGePoint(0, 0, 0));
  wallOutterPts.push(new Mx3dGePoint(0, 4480, 0));
  wallOutterPts.push(new Mx3dGePoint(5480, 4480, 0));
  wallOutterPts.push(new Mx3dGePoint(5480, 0, 0));
  const wallOutterPolygon = new Mx3dMkPolygon();
  wallOutterPts.forEach((pt) => {
    wallOutterPolygon.Add(pt);
  });
  wallOutterPolygon.Close();
  const wallOutterWire = wallOutterPolygon.Wire();
  const wallOutterMkFace = new Mx3dMkFace(wallOutterWire);
  const wallOutterFace = wallOutterMkFace.Face();
  // 内墙轮廓
  const wallInnerPts: Mx3dGePoint[] = [];
  wallInnerPts.push(new Mx3dGePoint(240, 240, 0));
  wallInnerPts.push(new Mx3dGePoint(240, 4240, 0));
  wallInnerPts.push(new Mx3dGePoint(5240, 4240, 0));
  wallInnerPts.push(new Mx3dGePoint(5240, 240, 0));
  const wallInnerPolygon = new Mx3dMkPolygon();
  wallInnerPts.forEach((pt) => {
    wallInnerPolygon.Add(pt);
  });
  wallInnerPolygon.Close();
  const wallInnerWire = wallInnerPolygon.Wire();
  const wallInnerMkFace = new Mx3dMkFace(wallInnerWire);
  const wallInnerFace = wallInnerMkFace.Face();
  // 墙体截面
  const wallFace = wallOutterFace.cut(wallInnerFace);
  // 拉伸墙体
  const wallMkPrism = new Mx3dMkPrism(wallFace, new Mx3dGeVec(0, 0, 3000));
  let wall = wallMkPrism.Shape();
  // 开窗洞
  const winPts: Mx3dGePoint[] = [];
  winPts.push(new Mx3dGePoint(1990, 4240, 1000));
  winPts.push(new Mx3dGePoint(1990, 4240, 2200));
  winPts.push(new Mx3dGePoint(3490, 4240, 2200));
  winPts.push(new Mx3dGePoint(3490, 4240, 1000));
  const winPolygon = new Mx3dMkPolygon();
  winPts.forEach((pt) => {
    winPolygon.Add(pt);
  });
  winPolygon.Close();
  const winWire = winPolygon.Wire();
  const winMkFace = new Mx3dMkFace(winWire);
  const winFace = winMkFace.Face();
  const winMkPrism = new Mx3dMkPrism(winFace, new Mx3dGeVec(0, 240, 0));
  const win = winMkPrism.Shape();
  // 开门洞
  const doorPts: Mx3dGePoint[] = [];
  doorPts.push(new Mx3dGePoint(5240, 1160, 0));
  doorPts.push(new Mx3dGePoint(5240, 1160, 2000));
  doorPts.push(new Mx3dGePoint(5240, 360, 2000));
  doorPts.push(new Mx3dGePoint(5240, 360, 0));
  const doorPolygon = new Mx3dMkPolygon();
  doorPts.forEach((pt) => {
    doorPolygon.Add(pt);
  });
  doorPolygon.Close();
  const doorWire = doorPolygon.Wire();
  const doorMkFace = new Mx3dMkFace(doorWire);
  const doorFace = doorMkFace.Face();
  const doorMkPrism = new Mx3dMkPrism(doorFace, new Mx3dGeVec(240, 0, 0));
  const door = doorMkPrism.Shape();
  wall = wall.cut(win).cut(door);
  // 准备一个棕色
  const brownColor = new Mx3dGeColor(MdGe.MxNameOfColor.Color_NOC_BROWN);
  // 先清除视图中的模型
  mxcad3d.removeAll();
  // 获取视图文档
  const doc = mxcad3d.getDocument();
  // 文档中创建一个标签用于存储墙体形状
  const wallLabel = doc.addShapeLabel();
  // 墙体形状放入文档标签中
  wallLabel.setShape(wall);
  // 给墙体设置为棕色
  wallLabel.setColor(brownColor);
  // 更新显示视图
  mxcad3d.update();
}
// 给button添加点击事件,点击后调用drawRoundRectPipe函数,进行圆角方管的绘制
// 立即执行函数
(function addEventToButton(){
  const btn = document.querySelector("button");
  if (btn) {
    btn.addEventListener("click", () => {
      funDrawWall();
    });
  }
})() 

4. 重新查看运行效果

5. 本次教程最后完成的完整测试项目压缩包下载地址为:https://gitee.com/mxcadx/mxcad_docs/tree/master/examples3D/Test3dWall.7z

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

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
SkeyeExPlayer(Windows)开发之框架讲解
SkeyeExPlayer for Windows是基于ffmpeg进行开发的全功能播放器,开发过程中参考了很多开源的播放器,诸如vlc和ffplay等,其中最强大的莫过于vlc,但是鉴于vlc框架过于庞大而其中仍存在诸多问题而舍弃了,而其他的更倾向于演示demo,只能提供部分借鉴意义;故而,SkeyeExPlayer 一贯秉承Skeye系列小而精,接口简单功能强大的宗旨从新设计了一套框架,该套框架能适应多线程调用以及多个播放实例同时运行,和SkeyePlayer一样Skeye; 当然,在此也郑重的感谢各大开源播放器以及ffmpeg的作者的无私奉献。
Openskeye
2023/04/17
3730
ffmpeg+sdl播放类
前段时间一直捣鼓ffmpeg,觉得还是VLC比较亲切,虽然我现在都不知道VLC怎么用了。 除了雷神的博客,主要参考的还是这个博客:http://blog.yundiantech.com/?log=in
_gongluck
2018/03/08
1.2K0
Ffplay源码之read_thread解析(二)
大家好,我是小涂,本周继续给大家分享ffplay中的read_thread这个线程源码的解读,这算是自己的一个学习记录过程吧。
用户6280468
2022/03/21
6930
Ffplay源码之read_thread解析(二)
​FFmpeg 开发(15):学习如何使用 FFmpeg 打造一个自己的通用播放器?
前面 FFmpeg 系列的文章中,已经实现了 FFmpeg 的编译和集成,基于 FFmpeg 实现音视频的播放、录制,并结合 OpenGL 添加丰富的滤镜等功能,这些 demo 基本上将 FFmpeg 使用涉及到的知识点基本上覆盖了。
字节流动
2022/01/21
1.3K0
​FFmpeg 开发(15):学习如何使用 FFmpeg 打造一个自己的通用播放器?
FFmpeg4.0笔记:封装ffmpeg的解码功能类CDecode
https://github.com/gongluck/FFmpeg4.0-study/tree/master/Cff
gongluck
2019/06/15
1.2K0
C++ ffmpeg+dxva2实现硬解码「建议收藏」
0.前言 参考博客:ffmpeg实现dxva2硬件加速 下载源码:GitHub:https://github.com/Yacov-lu/ffmpeg-DXVA-decode
全栈程序员站长
2022/11/16
2.3K0
C++ ffmpeg+dxva2实现硬解码「建议收藏」
ffmpeg实战实现音视频解封装!
大家好,很长一段时间没有继续更新ffmpeg的相关技术文章了,最近更多的时间和精力主要集中在给自己不断灌入新的知识,所以接下来只要有时间就会疯狂输出所学习到的技术干货!
用户6280468
2022/03/21
1.2K0
ffmpeg实战实现音视频解封装!
ffmpeg中av_seek_frame使用样例(代码实现)
av_seek_frame使用时需要使用四个参数 av_seek_frame(fmt_ctx, -1 , 20 * AV_TIME_BASE, AVSEEK_FLAG_ANY); 参数一: fmt_ctx为容器内容; 参数二: 流索引, stream_index 参数三: 将要定位处的时间戳 参数四: seek功能flag 容器即AVFormatContext, 其中包含了一些视频标准格式中对应的封装信息,例如stream个数,stream类型,AVCodec,字幕信息等; stream_index,容器中包含了stream,有音频stream,视频stream,3D的电影有多个视频stream,subtitle stream等stream信息。 那么如果需要seek到对应的时间戳处需要考虑几个问题: 1. 得到AVFormatContext信息 2. 需要得到stream_index信息 3. 需要设定将要定位的时间戳信息 4. seek功能需要根据需求设置 结合上述四点,可以实现代码步骤如下: av_register_all(); avformat_open_input avformat_find_stream_info open_codec_context av_seek_frame 以上为简单的seek步骤,当然细节部分,还要有一些操作,例如avpackets相关的操作等 下面测试用例编译命令为
用户3765803
2019/03/05
3.8K0
ffmpeg中av_seek_frame使用样例(代码实现)
SkeyeExPlayer(Windows)开发系列之采用ffmpeg进行录像
这篇和ffmpeg进行截图类似,不过省略掉编码的过程,从网络上或者文件读取的数据为编码后的数据,直接进行写文件即可,本文以写MP4文件为例进行讲解。
Openskeye
2023/04/14
2560
ffmpeg直播项目
一个描述数字音视频传输和播放流程的简单步骤:录制 -> 编码 -> 网络传输 -> 解码 -> 播放
Gnep@97
2023/12/30
3680
ffmpeg直播项目
FFmpeg封装格式处理4-转封装例程
源码修改自 FFmpeg 4.1 自带的例程 remuxing.c。代码非常简短:
叶余
2019/04/02
1.1K0
FFmpeg封装格式处理4-转封装例程
11.QT-ffmpeg+QAudioOutput实现音频播放器
由于QAudioOutput支持的输入数据必须是原始数据,所以播放mp3,WAV,AAC等格式文件,需要解封装后才能支持播放.
诺谦
2020/09/14
2.9K0
【Android 音视频开发:FFmpeg音视频编解码篇】三、Android FFmpeg视频解码播放
本文很长,因为可能有比较多的小伙伴对 JNI C/C++ 不是很熟悉,所以本文比较详细的对 FFmpeg 用到的代码进行讲解,完整的演示了一遍 FFmpeg 的解码和渲染过程,并且对解码过程进行了封装。
开发的猫
2020/04/01
3.4K0
原创:学习如何使用 FFmpeg 打造自己的播放器
前面 FFmpeg 系列的文章中,已经实现了 FFmpeg 的编译和集成,基于 FFmpeg 实现音视频的播放、录制,并结合 OpenGL 添加丰富的滤镜等功能,这些 demo 基本上将 FFmpeg 使用涉及到的知识点基本上覆盖了。
字节流动
2022/02/09
2.4K0
原创:学习如何使用 FFmpeg 打造自己的播放器
AVFormatContext封装层:理论与实战
AVFormatContext 是一个贯穿始终的数据结构,很多函数都用到它作为参数,是输入输出相关信息的一个容器,本文讲解 AVFormatContext 的封装层,主要包括两大数据结构:AVInputFormat,AVOutputFormat。
Gnep@97
2023/12/06
6030
AVFormatContext封装层:理论与实战
基于FFmpeg进行RTMP推流(一)简介
这里的bin、include、lib就是我们刚才在FFmpeg下载的相关文件。 src是我们的项目源码目录。 新建Win32控制台应用程序、选择位置、项目名称。注意:去掉“为结局方案创建目录”的勾选
用户2929716
2018/08/23
14.3K0
基于FFmpeg进行RTMP推流(一)简介
FFMPEG硬件编解码器使用
     在前文《视频编解码硬件方案漫谈》中我们介绍硬件视频编解码的一般方案,本文我们进一步介绍音视频编解码如何在ffmpeg使用显卡硬件进行加速。
用户4148957
2022/06/14
4.2K0
FFMPEG硬件编解码器使用
FFmpeg简单转码程序--视频剪辑
学习了雷神的文章,慕斯人分享精神,感其英年而逝,不胜唏嘘。他有分享一个转码程序《最简单的基于FFMPEG的转码程序》其中使用了filter(参考了ffmpeg.c中的流程),他曾说想再编写一个不需要filter的版本,可惜未有机会。恰好工作中有相关ffmpeg处理内容,故狗尾续貂,撰写本文。
jacker
2018/09/01
8.7K0
FFmpeg简单转码程序--视频剪辑
FFmpeg 播放 RTSP/Webcam 流
本文将介绍 FFmpeg 如何播放 RTSP/Webcam/File 流。流程如下:
GoCoding
2021/09/09
1.7K0
SkeyeExPlayer(Windows)开发系列之采用ffmpeg进行截图
下面我们讲解下SkeyeExPlayer的截图功能,截图原理就是将YUV/RGB原始数据压缩成jpg或者png等格式(当然bmp格式是不需要压缩的),然后存储成文件的过程;我们以jpg格式为例进行讲解;一般情况下可以使用libjpeg库进行jpeg格式压缩,在不使用libjpeg的情况下,可以使用ffmpeg(内部也集成了libjpeg库)提供的接口进行压缩并写文件,这个方式也普遍适用于写MP4或者其他文件,下面我们讲解下ffmpeg进行截图的流程。
Openskeye
2023/04/14
3220
推荐阅读
相关推荐
SkeyeExPlayer(Windows)开发之框架讲解
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档