首页 > 其他分享 >在线CAD(H5网页CAD SDK)实现阵列功能

在线CAD(H5网页CAD SDK)实现阵列功能

时间:2023-09-12 14:22:20浏览次数:46  
标签:vecOffset H5 mxcad CAD let new cenPt SDK

前言

在线CAD SDK的集成过程中,甲方客户可能有阵列功能的需求,作为开发者如何利用WEB CAD SDK展现此功能效果呢?本章节我们重点讲述一下。

首先看一下在线CAD的DEMO:https://demo.mxdraw3d.com:3000/mxcad/,阵列功能如下图:

 

环境搭建

首先按照mxcad入门文档(https://mxcadx.gitee.io/mxcad_docs/zh/1.%E6%8C%87%E5%8D%97/1.%E5%BF%AB%E9%80%9F%E5%85%A5%E9%97%A8.html)创建环境,如下图:

 

基于mxcad库实现阵列功能

阵列功能是按一定规律对某个或多个图形组合进行复制偏移,生成出新的图形组合,在实现它之前我们要确保已经用mxcad库在页面中显示了一个cad图纸,然后我们用鼠标点击一个或者多个图形, 就可以选中它们,选中后执行以下代码:

const rowNum = Number(prompt("输入行数"))

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

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

 

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

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

if (!offset) return

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

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

 

// 得到选中的图形

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

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

let ext = MxCADUtility.getMcDbEntitysBoundingBox(aryId);

if (!ext) return;

 

let cenPt = new McGePoint3d();

 

if (dColOffset > 0)

    cenPt.x = ext.minPt.x;

else

    cenPt.x = ext.maxPt.x;

 

if (dRowOffset > 0)

    cenPt.y = ext.minPt.y;

else

    cenPt.y = ext.maxPt.y;

// 角度

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

if (isNaN(dAng)) return

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

 

// 循环渲染

let iMaxNum = 50000;

let iCount = 0;

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

    // 行 平移矩阵

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

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

 

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

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

            continue;

        // 列 平移矩阵

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

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

 

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

        // 应用对应矩阵

        vecOffset.transformBy(offsetMatY);

        vecOffset.transformBy(ofssetMatX);

        vecOffset.transformBy(matRot);

 

        // 最终的变换矩阵

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

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

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

            if (!tmp) {

                continue;

            }

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

            tmp.TransformBy(tmpMat);

            MxCpp.GetCurrentMxCAD().DrawEntity(tmp);

            iCount++;

            if (iCount > iMaxNum) {

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

                return;

            }

        }

    }

}

代码中主要让用户输入一些行列数和偏移距离以及角度值, 然后得到选中图形, 得到其包围盒,并计算出变换矩阵, 复制这些对象然后绘制在画布,效果如下图: 

 

 

对于需要自己二次开发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

 

标签:vecOffset,H5,mxcad,CAD,let,new,cenPt,SDK
From: https://www.cnblogs.com/yzy0224/p/17696067.html

相关文章

  • ubuntu22.04在线安装.net6SDK
    运行以下命令,查找下载对应包文件sudoaptupdate&&sudoaptinstalldotnet6如果只想安装部分组件,命令如下://仅安装特定组件sudoaptinstalldotnet-sdk-6.0sudoaptinstalldotnet-runtime-6.Osudoaptinstallaspnetcore-runtime-6.0 但是运行命令后......
  • Android平台GB28181接入SDK
     华脉智联推出的Android平台GB28181接入SDK,可实现不具备国标音视频能力的Android终端,通过平台注册接入到现有的GB/T28181—2016服务,可用于如执法记录仪、智能安全帽、智能监控、智慧零售、智慧教育、远程办公、明厨亮灶、智慧交通、智慧工地、雪亮工程、平安乡村、生产运输、......
  • Android平台GB28181接入SDK
    华脉智联推出的Android平台GB28181接入SDK,可实现不具备国标音视频能力的Android终端,通过平台注册接入到现有的GB/T28181—2016服务,可用于如执法记录仪、智能安全帽、智能监控、智慧零售、智慧教育、远程办公、明厨亮灶、智慧交通、智慧工地、雪亮工程、平安乡村、生产运输、车载终......
  • 直播美颜工具的工程实现:集成人像美颜sdk的步骤与方法
    时下,无论是个人直播、游戏直播还是专业直播,人像美颜技术都可以提高画面质量,吸引更多观众。本文将深入探讨如何实现一个直播美颜工具,着重介绍了集成人像美颜sdk的步骤与方法。一、选择合适的人像美颜sdk要实现一个高效的直播美颜工具,首先需要选择一个适合的人像美颜sdk。市场上有许......
  • 飞桨AI Studio(星河社区)推出文心大模型SDK功能
    随着大模型的涌现,我们喜悦于其远远超越小模型的性能,但又不得不面临大模型开发难的困境,训练难、微调难、部署难,开发者难以将其投入实际生产,不仅面临资源的限制,更面临高精数据难寻、时间成本过高等问题。为了让平台更多开发者可以进行大模型开发,体验并使用大模型的真正能力,飞桨AIStu......
  • HTML5(H5)新特性
    HTML5(H5)是HTML标准的第五个版本,引入了许多新特性和改进,以下是一些H5的新特性:语义化标签:H5引入了一系列新的语义化标签,如<header>、<footer>、<nav>、<article>等,有助于更清晰地描述页面结构和内容。视频和音频支持:H5提供了<video>和<audio>标签,可以直接在网页中嵌入视频和音......
  • 初识Caddeine
         ......
  • H5接入飞书
    开发流程文档https://open.feishu.cn/document/client-docs/h5/introduction创建并配置企业自建应用。(可选)鉴权调用JSAPI。(可选)配置应用的免登流程。发布并使用应用。开放接口(H5JSAPI)开放平台提供了网页应用可以调用的H5JSAPI。调用JSAPI依赖开放平台提供的工具......
  • 华脉智联发布国标28181 Android SDK和DEMO
    在目前很多行业项目中,客户使用的是海康、大华等监控平台的GB/28181平台,或者是其他的第三方的GB/28181平台。但是对于那些不具备GB/28181协议的单兵终端,如何接入GB/28181平台网络中呢?首先,我们了解下GB/T28181:国标GB/T28181协议全称《安全防范视频监控联网系统信息传输、交换、控制技......
  • nodejs采集淘宝、天猫网商品详情数据以及解决_m_h5_tk令牌及sign签名验证(2023-09-09)
    一、淘宝、天猫sign加密算法淘宝、天猫对于h5的访问采用了和APP客户端不同的方式,由于在h5的js代码中保存appsercret具有较高的风险,mtop采用了随机分配令牌的方式,为每个访问端分配一个token,保存在用户的cookie中,通过cookie带回服务端分配的token,客户端利用分配的token对请求的URL......