前言
随着云端化数字经济时代的到来,越来越多的用户需要在网页端对图纸进行查看和审批,今天给大家详细讲一下在线的方式打开CAD图纸的方法,示例项目地址: 在线CAD梦想画图
在示例项目中,可以直接打开CAD图纸,这依赖于mxcad这个前端库可以读取MxDraw云图开发包将CAD图纸转换成mxweb格式的文件。有了图纸转换和文件渲染之后, 就可以做到读取和编辑CAD图纸。
原理
首先上传CAD图纸到我们Node服务进行处理,它会调用MxDraw云图开发包将CAD图纸转换成mxweb文件,然后返回给前端对应的访问地址,该示例项目对应的Node服务, 参考具体的Node代码, 请查看该链接了解详情:MxDraw帮助。
我们可以直接在开发包找到对应的Node服务源码, 也可以直接使用对应接口, 但它可能并不能完全满足你的需求,需要自己修改甚至重写,为此我们详细讲解一下应该如何来实现图纸转换的接口。
后端具体实现
首先我们需要Node环境查看安装,如果你不是使用的Node作为后端开发语言, 那么只需要理解如何转换就好, 然后自行实现。
验证是否安装成功
node -v
下面我们可以直接通过Node child_process 使用子进程调用云图开发包中的mxcadassembly程序
mxcadassembly程序所在目录
windows目录: MxDrawCloudServer\Bin\MxCAD\Release\mxcadassembly.exe
linux目录: MxDrawCloudServer\Bin\Linux\BinMxCAD\mxcadassembly
const { exec } = require('child_process'); // 如果是要将mxweb格式文件转成服务器 那么 srcpath就是mxweb文件路径 而outname 的后缀名应该是对应图纸的后缀名,如: test.dwg const param = { srcpath: "要转换的文件在服务器上的路径", outpath: "转换后生成的文件在服务器上的目录路径", outname: "转换后的文件名称" } exec(`"mxcadassembly程序在服务器所在位置" "${JSON.stringify(param)}"`, ()=> {})
如上所知, 我们要将mxweb文件保存为dwg图纸只需要改变srcpath和outname就可以了,将CAD图纸上传到服务器上, 请自行实现。
这里建议查看:MxDraw帮助然后结合云图开发包MxDrawCloudServer\Bin\MxCAD\MxCADSaveFile\server.js文件查看到源码,可以非常清晰的知道如何上传CAD实现转换和保存dwg图纸,最后我们将转换的文件放在了服务器上,当然你也可以上传到oss或者其他云存储上,然后返回对应的访问地址就可以了。
前端具体实现
前端直接调用后端提供的接口上传CAD图纸,等成功转换成mxweb文件后在前端用mxcad打开, 打开mxweb文件查看参考,这里主要讲解一下如何将目前网页上打开渲染好并且编辑了的mxweb文件保存成CAD图纸。
首先我们需要得到现在修改后的mxweb文件数据,然后上传到服务器,后端将mxweb格式的数据写在一个mxweb格式的文件中,最后使用mxcadassembly程序将mxweb格式文件转换为CAD图纸的文件, 然后返回对应的访问地址。
默认情况下, 我们提供saveFileToUrl 来实现保存CAD图纸, 它实际上帮我们将当前的mxweb数据上传到了你指定的一个后端接口中,下面是它的使用方法:
import { MxCpp, MxTools } from "mxcad" MxCpp.getCurrentMxCAD().saveFileToUrl("http://localhost:3337/mxcad/savefiledwg", (iResult, sserverResult)=> { / 这个就是对应接口的返回数据结果 */ console.log(sserverResult) // 我们可以直接拿到请求结果中携带的CAD图纸的访问地址 下载对应的图纸 // 假设返回结果是filePath const filePath = JSON.parse(sserverResult).filePath fetch(filePath).then(async (res)=> { const blob = await res.blob() // 默认使用了一些新的特性,如果不支持则会自动降级使用a标签下载 MxTools.saveAsFileDialog({ blob, filename: "test.dwg", types: [{ description: "dwg图纸", accept: { "application/octet-stream": [".dwg"], }, }] }) }) })
http://localhost:3337/mxcad/savefiledwg 接口实际就是云图开发包中提供的对应的Node服务。
但是在实际使用时,这种常规的方法并不能完全满足你的需求, 这个时候我们可以自己来实现这个保存dwg的功能,请参考如下代码:
import { MxCpp } from "mxcad" const mxcad = MxCpp.getCurrentMxCAD() // 这里直接拿到mxweb数据 mxcad.saveFile(void 0, (data)=> { let blob: Blob const isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent); if (isSafari) { blob = new Blob([data.buffer], { type: "application/octet-stream" }); } else { blob = new Blob([data.buffer], { type: "application/octet-binary" }); } // 这里直接将blob转成file const file = new File([blob], 'test.mxweb', { type: isSafari ? "application/octet-stream" : "application/octet-binary" }) // 上传文件转CAD图纸 fetch('http://localhost:3337/mxcad/savefiledwg', { method:'POST', body: file }) }, false, true)
以上代码只是参考代码, 其核心是需要利用云图开发包, 下载好后,它能够最快让你看到实际效果,详情参考文档: MxDraw帮助,前端mxcad文档: mxcad | mxcad & 提供在线CAD编辑能力。
完整演示在网页打开保存CAD图纸的DEMO
如果下载了云图开发包且阅读了其中前后端源码,还是无法理解如何实现打开和保存图纸,在这里给你准备了一个最简完整DEMO,只需要js + html 就可以完整实现网页打开和保存CAD图纸的页面,方便你快速理解如何打开和保存CAD图纸。
首先该DEMO 是一个Node服务, 需要安装Node环境 查看是否安装完成
node -v
然后可以下载我们的demo源码:
https://gitee.com/mxcadx/mxdraw-article/blob/master/mxcad打开保存CAD图纸/demo.ziphttps://gitee.com/mxcadx/mxdraw-article/blob/master/mxcad%E6%89%93%E5%BC%80%E4%BF%9D%E5%AD%98CAD%E5%9B%BE%E7%BA%B8/demo.zip
下载好demo后 解压进入demo目录,执行如下命令:
node app.js
最后控制台会提示访问: http://localhost:3333/http://localhost:3333/
注意:DEMO中的mxcad和mxdraw库是通过CDN方式引入的,如果你发现打开页面后没有CAD图纸显示,可能是你无法访问CDN资源,这时可以选择通过npm安装下载mxcad和mxdraw库,然后引入其中对应的文件:
npm init npm install mxcad mxdraw
然后将CDN引入的改成本地引入就好。
今天的文章 在线CAD(网页编辑DWG)实现打开CAD图纸的方式分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/bian-cheng-ji-chu/96599.html