明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 891|回复: 2

H5云图后台读写CAD文件-网页CAD,webcad,H5CAD

[复制链接]
发表于 2022-7-15 15:00:08 | 显示全部楼层 |阅读模式
本帖最后由 MxDraw 于 2022-7-15 15:03 编辑


说明
后台提供MxFileConvert.exe程序,它可以将CAD图纸转换成前台能加载显示的格式,程序调用方法见: https://help.mxdraw.com/?pid=32中的“如何在自己系统中浏览dwg文件”章节,该程序还可以在转换过程中,使用JS编程,读写CAD文件,而读取的CAD图纸数据可以写成json文件,方便传给前台使用。

后台如何写JS程序
原理说明:MxFileConvert.exe启动Node.js,先加载我们提供的CAD模块,再加载js程序,然后提取CAD图纸数据。
开发步骤:
A.安装vs2019,node.js,TypeScript运行环境
B.打开安装目录下,Bin\MxDrawNode\MxDrawNode.sln工程
如下图:
例子中用DoGetEntityData得到图纸上对象数据,比如文本数据,然后写到json文件,该文件前台可以使用Get协议获取,然后使用。
得到指定层上的文字代码如下:
  1. export class TestGetEntityData {
  2.     private sDwgFileName: string;
  3.     private getDataFilePath(): string {
  4.         return mxConvert.getConvertPath() + this.sDwgFileName + ".json";
  5.     }

  6.     // 得到图层"飘檐"上的文本
  7.     private getText1() {
  8.         // 把得到数据,写到sDataFile.
  9.         let sDataFile = this.getDataFilePath();

  10.         let ss: Mx.MrxDbgSelSet = new Mx.MrxDbgSelSetClass();

  11.         // 创建一个选择过滤条件.
  12.         let filter: Mx.MrxDbgRbList = new Mx.MrxDbgRbListClass();

  13.         // 只选择文字对象.
  14.         filter.addString("TEXT", 5020)

  15.         // 图层过滤.
  16.         filter.addString("飘檐", 8);

  17.         // 得到图上所有文字对象.
  18.         ss.allSelect(filter);


  19.         let dataObject: any = {};

  20.         let iCount = ss.count;

  21.         for (let i = 0; i < iCount; i++) {
  22.             // 选择集不为空.
  23.             let txt: Mx.McDbText = Mx.MxType.MxCast<Mx.McDbText>(ss.item(i), Mx.MxType.TypeString.kMcDbText);

  24.             // 得到文字对象,文字内容.
  25.             if (txt) {

  26.                 if (!dataObject[txt.layer]) {
  27.                     dataObject[txt.layer] = [];
  28.                 }
  29.                 // 把文字对象数据返回.
  30.                 let txtData: any = {};
  31.                 txtData.txt = txt.textString;
  32.                 txtData.posx = txt.position.x;
  33.                 txtData.posy = txt.position.y;
  34.                 dataObject[txt.layer].push(txtData);
  35.             }
  36.         }

  37.         // 保存数据文件.
  38.         MxFun.writeFile(sDataFile, JSON.stringify(dataObject));
  39.     }


  40.     public Do(filename: string) {
  41.         this.sDwgFileName = filename;
  42.         this.getText1();
  43.     }
  44. }

C.编译程序,生成MxConvert.js
把dist\mxconvert目录下的所有js程序拷到Bin\Release\mxconvert目录下,覆盖原来的文件,如下图:
D.启动程序
命令行入MxDrawCloudServer\Bin\Release目录
执行代码:
  1. MxFileConvert.exe {"srcpath":"0008.dwg","nodejs":1,"nodeparam":"4"}
复制代码

运行提取程序,如下图:
成功执行..\Test目录,生成数据文件,如下图:
生成的 json文件内容:
E.错误查看,日志文件位置
在程序运行过程,出现错误信息,会自动写到日志文件中,日志文件,默认在如下目录:
C:\Users\MxDraw\AppData\Local\Temp\MxCloudDebug
如下截图:
日志文件内容:



发表于 2022-8-20 16:03:58 | 显示全部楼层
工具类cad转WebCAD是不是要学javascript和h5吗
 楼主| 发表于 2022-8-23 10:18:14 | 显示全部楼层
yonjay 发表于 2022-8-20 16:03
工具类cad转WebCAD是不是要学javascript和h5吗

会JS就行
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-25 05:32 , Processed in 0.147525 second(s), 22 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表