找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 792|回复: 0

[他山之石] Field Expressions in Lisp

[复制链接]
发表于 2013-8-22 08:16:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
本帖最后由 Free-Lancer 于 2013-8-22 08:23 编辑

  1. (defun c:chp_aire (/ AcDoc Space obj ins)
  2.   (vl-load-com)
  3.   (setq AcDoc (vla-get-ActiveDocument (vlax-get-acad-object))
  4. Space (if (= 1 (getvar "CVPORT"))
  5.   (vla-get-PaperSpace AcDoc)
  6.   (vla-get-ModelSpace AcDoc)
  7.        )
  8.   )
  9.   (if
  10.     (and
  11.       (setq obj (car (entsel)))
  12.       (member (cdr (assoc 0 (entget obj)))
  13.        '("ARC" "CIRCLE" "ELLIPSE" "LWPOLYLINE" "REGION" "SPLINE")
  14.       )
  15.       (setq ins (getpoint "\nSpecify insertion point: "))
  16.     )
  17.      (vla-addMtext
  18.        Space
  19.        (vlax-3d-point ins)
  20.        0.0
  21.        (strcat
  22.   "%<\\AcObjProp.16.2 Object(%<\\_ObjId "
  23.   (itoa (vla-get-ObjectID (vlax-ename->vla-object obj)))
  24.   ">%).Area \\f "%lu2%pr2%ps[,m2]%ct8[1e-006]">%"
  25.        )
  26.      )
  27.   )
  28.   (princ)
  29. )

Another

  1. (defun C:Centroid (/ ent obj os pt area)
  2.   ;; Select the region
  3.   (setq ent (entsel "\nSelect region: "))
  4.   ;; Is an object selected?
  5.   (if ent
  6.     (progn
  7.       (setq ent_name (car ent))
  8.       ;; Is it a region
  9.       (if (= (cdr (assoc 0 (entget ent_name))) "REGION")
  10. (progn
  11.    ;; Determine the centroid
  12.    (setq obj (vlax-ename->vla-object ent_name))
  13.    (setq pt (vlax-get obj "Centroid"))
  14.    ;; Determine the area
  15.    (setq area (vlax-get obj "Area"))
  16.    (setq area (if (> area 144)
  17.          (strcat (rtos (/ area 144) 2 2) " ft%%202")
  18.          (strcat (rtos (/ area 1) 2 2) " in%%202")
  19.        )
  20.    )
  21.    (setq scale (/ (getvar "DIMSCALE") 40.0))
  22.    (setq os (getvar "osmode"))
  23.    (setvar "osmode" 0)
  24.    ;; Display coordinates
  25.    (princ "\nCentroid found at: ")
  26.    (princ (car pt))
  27.    (princ ",")
  28.    (princ (cadr pt))
  29.    ;; Write the area
  30.    (setq oid (vla-get-objectid obj))
  31.    (if (vlax-property-available-p obj 'Area)
  32.      (progn
  33.        (setq
  34.   txt (strcat "%<\\AcObjProp Object(%<\\_ObjId "
  35.        (itoa oid)
  36.        ">%).Area \\f "%pr2%lu2%ct4%qf1 sq ft>%"
  37.       )
  38.        )
  39.        (command "text"
  40.          "middle"
  41.          pt
  42.          (* (getvar "DIMSCALE") 0.09375)
  43.          ""
  44.          txt
  45.        )
  46.      )
  47.    )
  48. )
  49.       )
  50.     )
  51.   )
  52.   (princ)
  53. )

评分

参与人数 1D豆 +5 收起 理由
xshrimp + 5

查看全部评分

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-9-25 08:31 , Processed in 0.180473 second(s), 29 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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