本帖最后由 wkq004 于 2019-3-15 20:38 编辑
只是将原代码格式化了一下,着色方便阅读
- (vl-load-com)
- ;; 条目名称 SOUTHDIJI
- ;; 选择宗地界址线
- (defun c:bak ()
- ;; 获得JZD层上的闭合线选择集,必须带有扩展数据("SOUTH" (1000 . "300000"))。
- (setq ss (ssget "x" '((0 . "*LINE") (8 . "JZD") (-4 . "&=") (70 . 1) (-3 ("SOUTH" (1000 . "300000"))))) Index 0)
- (repeat (if ss (sslength ss) 0)
- (setq Ename (ssname ss Index)
- Index (1+ Index)
- Edata (entget Ename '("SOUTH"))
- ;; 找出对象所指向的词典。
- ;;“{ACAD_XDICTIONARY”表示扩展词典组的起点。
- Edata360 (cdr (member '(102 . "{ACAD_XDICTIONARY") Edata))
- XrEnameSouth nil )
- (if Edata360
- (progn
- ;; 360 所有者词典的硬所有者 ID/句柄。
- ;; 在此不考虑出现多个360的情况,感觉这种情况不应该存在。
- (setq DEname (cdr (assoc '360 Edata360)) ;_词典对象。
- DEdata (entget DEname) ;_词典数据。
- ;;条目名称SOUTHDIJI所对应的XRECORD对象
- XrEnameSouth (cdr (assoc '360 (cdr (member '(3 . "SOUTHDIJI") DEdata)))))))
- (if XrEnameSouth
- (progn
- (setq XrObj (vlax-ename->vla-object XrEnameSouth))
- (vla-getxrecorddata XrObj 'Ty 'Data)
- (vlax-safearray-put-element Data 0 "区号100")
- (vlax-safearray-put-element Data 1 "区号100")
- (vlax-safearray-put-element Data 2 "区号100")
- (vla-setxrecorddata XrObj (vlax-make-variant Ty) (vlax-make-variant Data))
- (vlax-release-object XrObj)
- )
- (progn
- ;; 没有对应的词典,找不到宗地属。
- (princ (strcat "\\n句柄:[" (cdr (assoc '5 Edata)) "]所指的对象没有宗地属性。"))
- )
- )
- )
- (princ)
- )
- (princ)
|