明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
12
返回列表 发新帖
楼主: gwpgc

点选标注,显示计算过程并列出文本

  [复制链接]
发表于 2012-11-20 12:52 | 显示全部楼层
;;; 面积运算  by:langjs
(defun c:aa (/ m2 name obj pt pt1 pt2 ss textH)
     (setq textH (getreal "\n输入新的文字高度<400>:"))
    (setq textH (if (= textH nil)
                400
                textH
              )
  )
  (setq ss (ssadd))
  (setq pt1 (getpoint "\n按顺序选择封闭区域顶点:"))
  (while (setq pt2 (getpoint pt1 "\n按顺序选择封闭区域顶点:"))
    (entmake (list '(0 . "LWPOLYLINE")
     '(100 . "AcDbEntity")
     '(100 . "AcDbPolyline")
     '(62 . 1)
     (cons 90 2)
     (cons 10 pt1)
     (cons 10 pt2)
      )
    )
    (setq ss  (ssadd (entlast) ss)
   pt1 pt2
    )
  )
  
  (command ".region" ss "")
  (setq obj (vlax-ename->vla-object (setq name (entlast))))
  (if (= (cdr (assoc 0 (entget name))) "REGION")
    (progn
      (setq pt (vlax-safearray->list
   (vlax-variant-value (vla-get-centroid obj))
        )
     m2 (strcat "S=" (rtos (/(vla-get-area obj) 1000000.0) 2 2) "平方米")
      )
      (entmake (list '(0 . "TEXT")
       (cons 62 3)
       (cons 10 pt)
       (cons 40 textH)
       (cons 1 m2)
       '(41 . 0.8)
       '(72 . 1)
       (cons 11 pt)
       '(73 . 0)
        )
      )
      (entdel name)
    )
  )
  (command "erase" ss "")
  (princ)
)
从论坛里资料,学着改了一下,感觉面积加改成平方米能用了

 楼主| 发表于 2012-11-22 20:42 | 显示全部楼层
面积计算很好,谢谢zhongzilei 兄,要是还能框选就ok了
发表于 2012-12-13 15:50 | 显示全部楼层
正需要这方面的
发表于 2016-4-29 13:53 | 显示全部楼层
非常好用!谢谢!
发表于 2017-11-6 14:17 | 显示全部楼层
非常好的代码, 谢谢分享啊。
发表于 2018-3-11 20:52 | 显示全部楼层
这个编的真的太好了,不知道能不能把标注改成文本数字计算出表达方式呢
;;尺寸运算  by:langjs
(defun c:qq ( / fuh i num obj ss str str1 tt)
  (setq ss (ssget '((0 . "DIMENSION"))))
  (setq fuh "+")
  (while (not (member (setq tt (getstring (strcat "\n请输入运算符号[加(+)/乘(*)] <" fuh ">:")))'("*" "+" ""))))
  (if (/= tt "") (setq fuh tt))
  (if (= fuh "+")(setq num 0) (setq num 1))
  (setq str ""        i 0 )
  (repeat (sslength ss)
    (setq obj (vlax-ename->vla-object (ssname ss i))
          str1 (vla-get-measurement obj)
          i (1+ i)
    )
    (if (= fuh "+")
      (setq num (+ num str1)
            str (strcat str (if (= i 1) "" "+") (rtos str1 2 3))
      )
      (setq num (* num str1)
            str (strcat str (if (= i 1) "" "*") (rtos str1 2 3))
      )
    )
  )
  (entmake (list '(0 . "TEXT") (cons 1 (strcat str "=" (rtos num 2 3))) (cons 10 (getpoint "选择插入点"))
                  (cons 40 (*  (vla-get-textheight obj)(vla-get-scalefactor obj)))
           )
  )
  (princ)
)
发表于 2018-8-14 19:37 | 显示全部楼层
langjs 发表于 2012-11-7 13:03
;;尺寸运算  by:langjs
(defun c:qq ( / fuh i num obj ss str str1 tt)
  (setq ss (ssget '((0 . "DIME ...

你好能不能改成以m为单位
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-4-20 02:23 , Processed in 0.200448 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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