找回密码
 立即注册

QQ登录

只需一步,快速开始

微信扫码登录

搜索
查看: 473|回复: 0

[图文教程] 网页CAD视区显示的设置和二次开发的详细教程

[复制链接]

299

主题

20

回帖

3984

积分

中尉

积分
3984

活跃会员

发表于 2024-7-24 08:59:40 | 显示全部楼层 |阅读模式
前言

网页CAD在绘制图形的过程中,常常会遇到视区显示不合适的情况,这时需要改变视区的显示范围、角度等去适应图形显示,为了解决上述需求,mxcad 在实例对象 McObject() 中提供了视区图形的重绘和更新、视区范围自定义、视区旋转等一系列方法,利用这些方法用户可以很方便地观看和绘制图形。点击[McObject()]查看详细属性和方法说明。

视区设置

视区背景色

我们可以调用 mxcad 实例对象中的 setViewBackgroundColor方法直接设置视区的背景色,参考代码如下:
  1. import { McApp } from "mxcad"
  2. // 将视区设置为灰色
  3. MxCpp.getCurrentMxCAD().setViewBackgroundColor(128, 128, 128);
复制代码

设置效果如下:
1.png

视区图形更新、重绘

用户绘图过程中,每个命令结束时都会产生一些无用的定位点,可以通过重绘操作删除这些定位点,从而方便看图和绘图。

我们可以调用 mxcad 实例对象中的 updateDisplay 方法更新视区显示;调用updateLayerDisplayStatus方法局部更新图层显示;调用regen方法重绘图上所有对象,参考代码如下:
  1. import { MxCpp } from "mxcad"
  2. const mxcad = MxCpp.getCurrentMxCAD()
  3. mxcad.regen()
  4. mxcad.updateDisplay()
  5. // mxcad.updateLayerDisplayStatus()
  6. 此外,当图纸体积较大内容较多时,重绘可能会花费一定时间,从而影响显示速率。因此,我们可以调用[McDbObject.assertObjectModification()]([url]https://www.mxdraw3d.com/mxcad_docs/api/classes/2d.McDbObject.html#assertobjectmodification[/url]) 局部更新图纸中发生变化的实体,代码如下:
  7. import { MxCADUiPrEntity } from "mxcad";
  8. // 选择对象
  9. let selEntity = new MxCADUiPrEntity();
  10. selEntity.setMessage("选择对象");
  11. let id = await selEntity.go();
  12. if (!id.isValid()) return;
  13. // 获取对象
  14. let ent = id.getMcDbEntity();
  15. if (ent === null) return;
  16. //...修改编辑对象
  17. ent.assertObjectModification();
复制代码

视区显示范围

1.缩放显示范围:我们可以调用 mxcad 实例对象的zoomScale方法缩放当前显示范围,该方法中的参数为scale缩放比例,代码如下:
  1. import { MxCpp } from "mxcad"
  2.    // 0.5:缩放比例
  3.    MxCpp.getCurrentMxCAD().zoomScale(0.5);
复制代码

设置效果如下:
2.png

3.png

2.自定义显示中心:我们可以调用 mxcad 实例对象的 zoomCenter方法把当前显示范围移到指定的位置,该方法中的两个参数dCenX,dCenY是DWG图纸坐标即为视区显示范围的中心点,代码如下:
  1. import {MxCpp, McDbCircle , McCmColor, McGePoint3d} from "mxcad"
  2.    //画圆
  3.    function drawCircle() {
  4.      const mxcad = MxCpp.getCurrentMxCAD();
  5.      // 创建新画布
  6.      mxcad.newFile();
  7.      //绘制圆
  8.      const circle_1 = new McDbCircle(-100, 300, 0, 20)
  9.      circle_1.trueColor = new McCmColor(255, 0, 0)
  10.      mxcad.drawEntity(circle_1)
  11.      const circle_2 = new McDbCircle()
  12.      circle_2.center = new McGePoint3d(-100, 300, 0)
  13.      circle_2.radius = 10
  14.      circle_2.trueColor = new McCmColor(0, 255, 0)
  15.      mxcad.drawEntity(circle_2)
  16.      mxcad.drawCircle(-100, 300, 30)
  17.      // 设置视区中心点(圆心)
  18.      mxcad.zoomCenter(-100, 300);
  19.      mxcad.zoomAll();
  20.    };
  21.    // 调用画圆方法
  22.    drawCircle();
复制代码

设置效果如下:
4.png

1.自定义显示范围:我们可以调用 mxcad 实例对象的 zoomW方法把当前显示范围移到指定的显示范围,该方法中的两个参数minPt,maxPt是显示范围的最小点和最大点,代码如下:
  1.    import { MxCpp, McGePoint3d } from "mxcad"
  2.    const mxcad = MxCpp.getCurrentMxCAD();
  3.    //minPt:new McGePoint3d(1000, 1460),maxPt:new McGePoint3d(1640, 940)
  4.    mxcad.zoomW(new McGePoint3d(1000, 1460), new McGePoint3d(1640, 940))
复制代码

设置效果如下:
5.png

6.png

2.显示全部:我们可以调用 mxcad 实例对象的zoomAll方法把视区范围设为显示图纸的全部内容,代码如下:
  1.    import { MxCpp } from "mxcad"
  2.    MxCpp.getCurrentMxCAD().zoomAll()
复制代码

3.获取当前视区显示范围:我们可以调用 mxcad 实例对象的 getViewCADCoord方法返回当前图纸的视区范围,代码如下:
  1.    import { MxCpp } from "mxcad"
  2.    /** 获取当前视区范围
  3.      * pt1, pt2, pt3, pt4:当前视区的四个角点位置
  4.      */
  5.    const {pt1, pt2, pt3, pt4} = MxCpp.getCurrentMxCAD().getViewCADCoord();
  6.    console.log(pt1, pt2, pt3, pt4);
复制代码

视区旋转

我们可以调用mxcad实例对象的zoomAngle方法来设置显示视区的角度,单位是PI,从而实现视区旋转,代码如下:
  1. import { MxCpp, McGePoint3d } from "mxcad"
  2. const mxcad = MxCpp.getCurrentMxCAD();
  3. // 视区旋转90度
  4. const lAng += Math.PI * 0.5;
  5. mxcad.zoomAngle(lAng);
复制代码

设置效果如下:
7.png

视区平移

我们可以结合[命令行]执行 `Mx_Pan` 命令实现视区平移功能。
  1. import { MxFun } from "mxdraw"
  2. //执行命令
  3. MxFun.sendStringToExecute("Mx_Pan");
  4. // 停止运行当前命令
  5. // MxFun.stopRunCommand()
复制代码

在线示例

示例项目地址: [在线CAD梦想画图]。

我们的在线示例demo中提供了代码编辑模块,用户可以在该模块内编写mxcad相关代码并运行实时查看和测试,效果如下图:
8.png



您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

咨询QQ:1359218528|发帖须知!|Archiver|手机版|小黑屋|UG爱好者论坛 ( 京ICP备10217105号-2 )

GMT+8, 2024-12-25 14:51

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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