CAD交互绘制带周长面积的矩形框(com接口)

主要用到函数说明:

_DMxDrawX::DrawLine

绘制一个直线。详细说明如下:

参数 说明

DOUBLE dX1


直线的开始点x坐标


DOUBLE dY1


直线的开始点y坐标


DOUBLE dX2


直线的结束点x坐标


DOUBLE dY2


直线的结束点y坐标

_DMxDrawX::DrawText

绘制一个单行文字。详细说明如下:

参数 说明

DOUBLE dPosX


>文字的位置的X坐标


DOUBLE dPosY


文字的位置的Y坐标


BSTR pszText


文字内容字符串


DOUBLE dHeight


文字高度


DOUBLE dRotation


文字的旋转角度


SHORT horizontalMode


文字的水平对齐方式,0=kTextLeft,1=kTextCenter,2=kTextRight


SHORT verticalMode


文字的竖直对齐方式,1=kTextBottom,2=kTextVertMid,3=kTextTop

IMxDrawCustomEntity::Draw

把实体绘制到图上。一般用于动态拖放时,在拖放结束时,绘制到图上。

c#中实现代码说明:

动态拖放时的绘制事件:

private void DynDrawMatrix()
{
    // 创建一个与用户交互取点的对象。
    MxDrawPoint point1 = (MxDrawPoint)axMxDrawX1.GetPoint(false, 0, 0, "\n 点取开始点:");
    if (point1 == null)
    {
        return;
    }
    MxDrawUiPrPoint getSecondPt = new MxDrawUiPrPoint();
    getSecondPt.message = "第二点";
    getSecondPt.basePoint = point1;
    //调用
    MxDrawCustomEntity spDrawData = getSecondPt.InitUserDraw("TestDynDrawMatrix");
    // 设置动态绘制参数.
    spDrawData.SetPoint("BasePoint", point1);
    // 开始取第二个点。
    if (getSecondPt.go() != MCAD_McUiPrStatus.mcOk)
        return;
    spDrawData.Draw();
}

动态绘制矩形框:

private void axMxDrawX1_DynWorldDraw(object sender, AxMxDrawXLib._DMxDrawXEvents_DynWorldDrawEvent e)
{
    MxDrawCustomEntity pCustomEntity = (MxDrawCustomEntity)e.pData;
    MxDrawWorldDraw pWorldDraw = (MxDrawWorldDraw)e.pWorldDraw;
    string sGuid = pCustomEntity.Guid;
    MxDrawPoint curPoint = new MxDrawPoint();
    curPoint.x = e.dX;
curPoint.y = e.dY;
    if(sGuid == "TestDynDrawMatrix")
    {
        //与用户交互在图面上提取一个点
        MxDrawPoint vBasePt = pCustomEntity.GetPoint("BasePoint");
        //计算中心点位置
        MxDrawPoint centerPt = new MxDrawPoint();
        {
            centerPt.x = curPoint.x + (vBasePt.x - curPoint.x) / 2;
            centerPt.y = curPoint.y + (vBasePt.y - curPoint.y) / 2;
        }
        //计算面积(取绝对值)
        double arec = Math.Abs(vBasePt.x - curPoint.x) * Math.Abs(vBasePt.y - curPoint.y);
        //计算周长
        double girth = 2 * (Math.Abs(vBasePt.x - curPoint.x) + Math.Abs(vBasePt.y - curPoint.y));
        //变换视区长度
        double dHeigth = axMxDrawX1.ViewLongToDocCoord(15);
        //绘制一个单行文字
        //参数一为文字的位置的X坐标 ;参数二为文字的位置的Y坐标 ;参数三为文字内容字符串
        //参数四为文字高度;参数五为文字的旋转角度
        //参数六为文字的水平对齐方式,0=kTextLeft,1=kTextCenter,2=kTextRight
        //参数七文字的竖直对齐方式,1=kTextBottom,2=kTextVertMid,3=kTextTop
        pWorldDraw.DrawText(centerPt.x, centerPt.y, "面积:" + arec, dHeigth, 0, MCAD_McHorizontalAlignment.mcHorizontalAlignmentCenter, MCAD_McVerticalAlignment.mcVerticalAlignmentBottom);
        pWorldDraw.DrawText(centerPt.x, centerPt.y, "周长:" + girth, dHeigth, 0, MCAD_McHorizontalAlignment.mcHorizontalAlignmentCenter, MCAD_McVerticalAlignment.mcVerticalAlignmentTop);
        //绘制一个直线
        //参数一直线的开始点x坐标,参数二直线的开始点y坐标,参数三直线的结束点x坐标,参数四直线的结束点y坐标
        pWorldDraw.DrawLine(vBasePt.x, vBasePt.y, vBasePt.x, curPoint.y);
        pWorldDraw.DrawLine(vBasePt.x, curPoint.y, curPoint.x, curPoint.y);
        pWorldDraw.DrawLine(curPoint.x, curPoint.y, curPoint.x, vBasePt.y);
        pWorldDraw.DrawLine(curPoint.x, vBasePt.y, vBasePt.x, vBasePt.y);
    }
}

原文地址:https://www.cnblogs.com/yzy0224/p/11064821.html

时间: 2024-07-29 18:40:22

CAD交互绘制带周长面积的矩形框(com接口)的相关文章

CAD交互绘制矩形框(com接口)

主要用到函数说明: _DMxDrawX::DrawLine 绘制一个直线.详细说明如下: 参数 说明 DOUBLE dX1 直线的开始点x坐标 DOUBLE dY1 直线的开始点y坐标 DOUBLE dX2 直线的结束点x坐标 DOUBLE dY2 直线的结束点y坐标 IMxDrawCustomEntity::Draw 把实体绘制到图上.一般用于动态拖放时,在拖放结束时,绘制到图上. c#中实现代码说明: 动态拖放时的绘制事件: private void DrawPathToPolyline()

CAD交互绘制文字(com接口)

在cad设计时,需要绘制文字,用户可以设置设置绘制文字的高度等属性. 主要用到函数说明: _DMxDrawX::DrawText 绘制一个单行文字.详细说明如下: 参数 说明 DOUBLE dPosX >文字的位置的X坐标 DOUBLE dPosY 文字的位置的Y坐标 BSTR pszText 文字内容字符串 DOUBLE dHeight 文字高度 DOUBLE dRotation 文字的旋转角度 SHORT horizontalMode 文字的水平对齐方式,0=kTextLeft,1=kTex

CAD参数绘制多段线(网页版)

多段线又被称为多义线,表示一起画的都是连在一起的一个复合对象,可以是直线也可以是圆弧并且它们还可以加不同的宽度. 主要用到函数说明: _DMxDrawX::PathLineTo 把路径下一个点移到指定位置.详细说明如下: 参数 说明 DOUBLE dX 点的X坐标 DOUBLE dY 点的Y坐标 _DMxDrawX::DrawPathToPolyline 把路径变成一个Polyline. js中实现代码说明: function DrawPolyline() { //Polyline 又称多义线,

HDU 3265 Posters(线段树扫描线·矩形框面积并)

题意  把一些矩形海报挖去一部分小矩形贴在指定位置  问最后海报覆盖的面积 一个矩形框可以分割成4个独立的小矩形  然后就能用扫描线求面积并了 #include <cstdio> #include <algorithm> using namespace std; const int N = 100005, M = N << 2; typedef long long ll; struct SLine { int x, y1, y2, flag; SLine() {}; S

用CSS3实现带小三角形的div框(不用图片)

用CSS3实现带小三角形的div框(不用图片) 现在看到了很多带小三角形的方框,如微信.Mac版的QQ.QQ空间的时间轴等等,在聊天或者是发表的状态的内容外面都有一个带小三角形的矩形框包围着,感觉看着很不错,于是决定亲自动手写一个,我上次用的是偏移背景图片法,那么今天就不用图片,用CSS3实现一下,下面我们来看一下实现代码. 首先我们来看一下CSS3实现三角形原理:其实就是对于transparent的应用 假如html代码是这样的 <div class="arrow-up">

PHP图形计算器(计算三角形矩形周长面积)

运用PHP面向对象的知识设计一个图形计算器,同时也运用到了抽象类知识,这个计算器可以计算三角形的周长和面积以及矩形的周长和面积.本图形计算器有4个页面:1.PHP图形计算器主页index.php;    2.形状的抽象类shape.class.php;    3三角形计算类triangle.class.php;    4.矩形计算类rect.class.php. PHP图形计算器代码点击下载:   php图形计算器.zip 代码分别如下: PHP图形计算器主页: 1 2 3 4 5 6 7 8

Android自定义ViewGroup(一)——带箭头的圆角矩形菜单

今天要做一个带箭头的圆角矩形菜单,大概长下面这个样子: 要求顶上的箭头要对准菜单锚点,菜单项按压反色,菜单背景色和按压色可配置. 最简单的做法就是让UX给个三角形的图片往上一贴,但是转念一想这样是不是太low了点,而且不同分辨率也不太好适配,干脆自定义一个ViewGroup吧! 自定义ViewGroup其实很简单,基本都是按一定的套路来的. 一.定义一个attrs.xml 就是声明一下你的这个自定义View有哪些可配置的属性,将来使用的时候可以自由配置.这里声明了7个属性,分别是:箭头宽度.箭头

Android 使用Universal Image Loader绘制带圆角的图片(一)

Android 使用Universal Image Loader绘制带圆角的图片(一) 绘制带圆角的控件难吗?貌似不难.对于一个普通layout或者widget,要绘制圆角,只要把 background设置成下面这样的drawable就行了. <?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/and

【转】Android使用XML Shape绘制带阴影效果的圆形按钮

众所周知,在Android开发里,为了优化在各种分辨率设备上的显示效果,同一份图片素材往往要提供mdpi.hdpi.xhdpi三种(以前还有ldpi), 尤其是按钮类的素材,考虑到normal.pressed.focused更是需要至少3×3=9张图片.NinePatch技术虽然可以解决一部分尺寸灵活性的问题, 但大部分修改和适配还是要再次制作一批图片的. 根据交互设计的需要,可以考虑用Drawable的XML绘制按钮,好处有:* 矢量绘制,易于缩放:* 字节数更少(一般而言):* 基于XML文