首页 论坛 3D云课 机械社区 3D云造

QQ登录

只需一步,快速开始

快捷登录

登录 或者 注册 请先
切换风格 快捷导航

UG爱好者

 
搜索
UG爱好者» 论坛 3D工业数字化 Auto CAD 在线CAD(H5网页CAD SDK)实现阵列功能
返回列表 发新帖
查看: 545|回复: 0
打印 上一主题 下一主题

[图文教程] 在线CAD(H5网页CAD SDK)实现阵列功能

[复制链接]
CAD画图

中尉

Rank: 5Rank: 5

297

主题

316

帖子

3940

积分

活跃会员

跳转到指定楼层
楼主
发表于 2023-9-12 14:13:55 | 只看该作者 | 只看大图 回帖奖励 | 倒序浏览 | 阅读模式
前言
在线CAD SDK的集成过程中,甲方客户可能有阵列功能的需求,作为开发者如何利用WEB CAD SDK展现此功能效果呢?本章节我们重点讲述一下。
首先看一下在线CAD的DEMO: https://demo.mxdraw3d.com:3000/mxcad/,阵列功能如下图:
环境搭建
首先按照 mxcad入门文档 创建环境,如下图:
基于mxcad库实现阵列功能
阵列功能是按一定规律对某个或多个图形组合进行复制偏移,生成出新的图形组合,在实现它之前我们要确保已经用mxcad库在页面中显示了一个cad图纸
然后我们用鼠标点击一个或者多个图形, 就可以选中它们选中后执行以下代码:
  1. <font size="3">const rowNum = Number(prompt("输入行数"))

  2. const colNum = Number(prompt("输入列数"))

  3. if (isNaN(rowNum) || isNaN(colNum)) return



  4. alert("点击画布两点之间的距离作为偏移量")

  5. let offset = await MxCADUtility.getCorner("输入偏移距离");

  6. if (!offset) return

  7. let dColOffset = offset.pt2.x - offset.pt1.x;

  8. let dRowOffset = offset.pt2.y - offset.pt1.y;



  9. // 得到选中的图形

  10. let aryId = await MxCADUtility.userSelect("选择陈列对象");

  11. // 得到这些图形的包围盒

  12. let ext = MxCADUtility.getMcDbEntitysBoundingBox(aryId);

  13. if (!ext) return;



  14. let cenPt = new McGePoint3d();



  15. if (dColOffset > 0)

  16.     cenPt.x = ext.minPt.x;

  17. else

  18.     cenPt.x = ext.maxPt.x;



  19. if (dRowOffset > 0)

  20.     cenPt.y = ext.minPt.y;

  21. else

  22.     cenPt.y = ext.maxPt.y;

  23. // 角度

  24. let dAng = Number(prompt("输入角度"));

  25. if (isNaN(dAng)) return

  26. let matRot = new McGeMatrix3d().setToRotation(dAng * Math.PI / 180.0, McGeVector3d.kZAxis, cenPt);



  27. // 循环渲染

  28. let iMaxNum = 50000;

  29. let iCount = 0;

  30. for (let i = 0; i < rowNum; i++) {

  31.     // 行 平移矩阵

  32.     let yOffsetVec = new McGeVector3d(0.0, dRowOffset * i, 0.0);

  33.     let offsetMatY = new McGeMatrix3d().setToTranslation(yOffsetVec);



  34.     for (let j = 0; j < colNum; j++) {

  35.         if (i == 0 && j == 0)

  36.             continue;

  37.         // 列 平移矩阵

  38.         let xOffsetVec = new McGeVector3d(dColOffset * j, 0.0, 0.0);

  39.         let ofssetMatX = new McGeMatrix3d().setToTranslation(xOffsetVec);



  40.         let vecOffset = new McGePoint3d(cenPt.x, cenPt.y, cenPt.z);

  41.         // 应用对应矩阵

  42.         vecOffset.transformBy(offsetMatY);

  43.         vecOffset.transformBy(ofssetMatX);

  44.         vecOffset.transformBy(matRot);



  45.         // 最终的变换矩阵

  46.         let tmpMat = new McGeMatrix3d().setToTranslation(new McGeVector3d(vecOffset.x - cenPt.x, vecOffset.y - cenPt.y, vecOffset.z - cenPt.z));

  47.         for (let m = 0; m < aryId.length; m++) {

  48.             let tmp = aryId[m].clone() as McDbEntity

  49.             if (!tmp) {

  50.                 continue;

  51.             }

  52.             // 将该变换矩阵应用在图形对象上

  53.             tmp.TransformBy(tmpMat);

  54.             MxCpp.GetCurrentMxCAD().DrawEntity(tmp);

  55.             iCount++;

  56.             if (iCount > iMaxNum) {

  57.                 alert("超出最大阵列对象个数" + iMaxNum + "限制. \n");

  58.                 return;

  59.             }

  60.         }

  61.     }

  62. }</font>
复制代码
代码中主要让用户输入一些行列数和偏移距离以及角度值, 然后得到选中图形, 得到其包围盒,并计算出变换矩阵, 复制这些对象然后绘制在画布,效果如下:
对于需要自己二次开发cad相关功能, 可以参考:
mxcad入门: https://mxcadx.gitee.io/mxcad_docs/zh/
mxcad API文档 : https://mxcadx.gitee.io/mxcad_docs/api/README.html
DEMO源码: https://gitee.com/mxcadx/mxdraw-article/tree/master/%E5%AE%9E%E7%8E%B0%E9%98%B5%E5%88%97%E5%8A%9F%E8%83%BD


CAD, SDK

有奖推广贴子: 

收藏收藏 支持支持 反对反对

相关帖子

  • • CAD不能复制到其他CAD图内,且画的直线为 直线
  • • WEB预览CAD(手机小程序浏览DWG)二次开发图层表的方法
  • • CAD导入pdf后竖直的尺寸全乱了,其他尺寸都是对的
  • • AutoCAD2024布局加载不了模型
  • • 三维CAD习题集(清华大学出版社)
  • • 老师们麻烦看看这个怎么画
  • • 能不能帮忙将工程图导出CAD
  • • CAD导入UG里面箭头删不掉
  • • AutoCAD贱人工具箱 6.3
  • • UG转换CAD坐标不对
回复

使用道具 举报

返回列表 发新帖
高级模式
B Color Image Link Quote Code Smilies
您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

 
 
QQ:1359218528
工作时间:
9:00-17:00
 
微信公众号
手机APP
机械社区
微信小程序

手机版| UG爱好者论坛 ( 京ICP备10217105号-2 )    论坛管理员QQ:1359218528

本站信息均由会员发表,不代表本网站立场,如侵犯了您的权利请联系管理员,邮箱:1359218528@qq.com  

Powered by UG爱好者 X3.2  © 2001-2014 Comsenz Inc. GMT+8, 2024-6-5 00:03

返回顶部

聚圣源武汉天鹅恋情侣酒店无常声名鹊起什么意思用名字起网名送给姓杨的宝宝起名小胖妞峰回路转的意思红通人员姚锦旗一审获刑6年为宝宝免费起名软件宝宝取名起名大全杨新冠病毒传播能力未出现变化庄姓男孩起名单字华强北招聘笔仙1魏姓魏起名wowrpg2018李姓宝宝起名大全官场小说推荐汤粉店的起名元宵节作文100字忍者村大战3.20无cd给小孩子起名字工程有限公司起名字郑姓的女宝宝起名机械团队起名英特集团股票宝宝起名网免费取名免费宝宝免费起名测名生辰八字名字父亲姓李母亲姓孟起名关于阿狸的qq网名淀粉肠小王子日销售额涨超10倍罗斯否认插足凯特王妃婚姻让美丽中国“从细节出发”清明节放假3天调休1天男孩疑遭霸凌 家长讨说法被踢出群国产伟哥去年销售近13亿网友建议重庆地铁不准乘客携带菜筐雅江山火三名扑火人员牺牲系谣言代拍被何赛飞拿着魔杖追着打月嫂回应掌掴婴儿是在赶虫子山西高速一大巴发生事故 已致13死高中生被打伤下体休学 邯郸通报李梦为奥运任务婉拒WNBA邀请19岁小伙救下5人后溺亡 多方发声王树国3次鞠躬告别西交大师生单亲妈妈陷入热恋 14岁儿子报警315晚会后胖东来又人满为患了倪萍分享减重40斤方法王楚钦登顶三项第一今日春分两大学生合买彩票中奖一人不认账张家界的山上“长”满了韩国人?周杰伦一审败诉网易房客欠租失踪 房东直发愁男子持台球杆殴打2名女店员被抓男子被猫抓伤后确诊“猫抓病”“重生之我在北大当嫡校长”槽头肉企业被曝光前生意红火男孩8年未见母亲被告知被遗忘恒大被罚41.75亿到底怎么缴网友洛杉矶偶遇贾玲杨倩无缘巴黎奥运张立群任西安交通大学校长黑马情侣提车了西双版纳热带植物园回应蜉蝣大爆发妈妈回应孩子在校撞护栏坠楼考生莫言也上北大硕士复试名单了韩国首次吊销离岗医生执照奥巴马现身唐宁街 黑色着装引猜测沈阳一轿车冲入人行道致3死2伤阿根廷将发行1万与2万面值的纸币外国人感慨凌晨的中国很安全男子被流浪猫绊倒 投喂者赔24万手机成瘾是影响睡眠质量重要因素春分“立蛋”成功率更高?胖东来员工每周单休无小长假“开封王婆”爆火:促成四五十对专家建议不必谈骨泥色变浙江一高校内汽车冲撞行人 多人受伤许家印被限制高消费

聚圣源 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化