找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1336|回复: 2

[每日一码] 面域的操作

[复制链接]

已领礼包: 568个

财富等级: 财运亨通

发表于 2018-8-21 11:37:07 | 显示全部楼层 |阅读模式

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

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

×
;;;面域的操作
(vl-load-com)
(setq AcadObject   (vlax-get-acad-object)

      AcadDocument (vla-get-ActiveDocument AcadObject)

      mSpace           (vla-get-ModelSpace AcadDocument)

)
;;;建面域
(defun c:scmy (/ os od ii ss1 ss11 xobj1 xobj1color xobj1layer p0)
  (setq os (getvar "osmode"))
  (setq od (getvar "cmdecho"))
  (setvar "osmode" 0)                        ;15359
  (setvar "cmdecho" 0)
  (setq ii 0)
  (setq ss1 (ssget))
  (if ss1
    (progn
      (repeat (sslength ss1)
        (setq ss11 (ssname ss1 ii))
        (setq xobj1 (vlax-ename->vla-object ss11))
        (setq xobj1color (vla-get-color xobj1)
              xobj1layer (vla-get-layer xobj1)
        )
        (vl-cmdf "region" ss11 "")
        (vl-cmdf "chprop"
                 (entlast)
                 ""
                 "p"
                 "c"
                 xobj1color
                 "la"
                 xobj1layer
                 ""
        )
        (setq ii (1+ ii))
      )
    )
    (progn
;;;      (vl-cmdf "pline")
;;;      (setq pt1 (getpoint "\n屏幕上选择点:"))
;;;      (vl-cmdf pt1)
;;;      (while (setq pt2 (getpoint pt1 "\n屏幕上选择点:"))
;;;        (vl-cmdf pt2)
;;;        (setq pt1 pt2)
;;;      )
;;;      (vl-cmdf "c")
;;;      (vl-cmdf)
;;;      (vl-cmdf "region" (entlast) "")
      (setq p0 (getpoint "\n请指定闭合区域内一点:"))
      (vl-cmdf "_.bpoly" "a" "o" "r" "" p0 "") ;boundary跟bpoly功能一样
      (setq ii 1)
    )
  )
  (alert (strcat "共" (itoa ii) "个面域建成功."))
  (setvar "osmode" os)
  (setvar "cmdecho" od)
  (princ "\n OK!")
  (princ)
)
;;;面域的三种方法
(defun c:mianyu        (/ xobj1 xobj2 xobj3 pt1 pt2 area1)
  (setq xobj1 (vlax-ename->vla-object (car (entsel "\n第一个面域:"))))
  (setq xobj2 (vlax-ename->vla-object (car (entsel "\n第二个面域:"))))
;;;  (setq objent (vlax-dump-object obj))
  (setq        xobj1-name (vla-get-objectname xobj1)
        xobj2-name (vla-get-objectname xobj2)
  )
  (if (and (equal (strcase xobj1-name) "ACDBREGION")
           (equal (strcase xobj2-name) "ACDBREGION")
      )
    (progn
      (setq xuanxian (getint "\n并集<1>/差集<2>/交集<3>:"))
      (cond
        ((= xuanxian 1)
         (progn
           (vla-boolean xobj1 acunion xobj2)
           (setq xobj3 (vlax-ename->vla-object (entlast)))
           (setq pt1 (vla-get-Centroid xobj3)
                 pt2 (vlax-safearray->list (vlax-variant-value pt1))
           )
           (setq area1 (vla-get-area xobj3))
         )
        )
        ((= xuanxian 2)
         (progn
           (vla-boolean xobj1 acsubtraction xobj2)
           (setq xobj3 (vlax-ename->vla-object (entlast)))
           (setq pt1 (vla-get-Centroid xobj3)
                 pt2 (vlax-safearray->list (vlax-variant-value pt1))
           )
           (setq area1 (vla-get-area xobj3))
         )
        )
        ((= xuanxian 3)
         (progn
           (vla-boolean xobj1 acintersection xobj2)
           (setq xobj3 (vlax-ename->vla-object (entlast)))
           (setq pt1 (vla-get-Centroid xobj3)
                 pt2 (vlax-safearray->list (vlax-variant-value pt1))
           )
           (setq area1 (vla-get-area xobj3))
         )
        )
      )
    )
    (alert "选择的物体不是面域:")
  )
  (princ "\n")
  (if area1
    (princ area1)
  )
  (princ "\nOK!")
  (princ)
)

评分

参与人数 1D豆 +5 收起 理由
/db_自贡黄明儒_ + 5 很给力!经验;技术要点;资料分享奖!

查看全部评分

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

已领礼包: 568个

财富等级: 财运亨通

 楼主| 发表于 2018-8-21 15:02:59 | 显示全部楼层
试着编的,大家批评改正。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 158个

财富等级: 日进斗金

发表于 2018-12-14 11:11:22 | 显示全部楼层
很给力!经验
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-14 20:18 , Processed in 0.358064 second(s), 36 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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