forked from xplan001/AutoCad-App
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path可以生成XREF里面的选定的实体的拷贝(copyn).lsp
56 lines (56 loc) · 1.79 KB
/
可以生成XREF里面的选定的实体的拷贝(copyn).lsp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
(defun c:copyn (/ blk blks e i lst obj tm ss)
(setq blks (vla-get-blocks
(vla-get-activedocument (vlax-get-acad-object))
)
ss (ssadd)
)
(while (and (setq e (nentselp "Select nested object to copy: "))
(setq tm (caddr e))
(setq blk (car (cadddr e)))
(setq blk (vlax-ename->vla-object blk))
(setq i (vla-item blks (vla-get-name blk)))
)
(if (= (vla-get-isxref i) :vlax-false)
(vlax-for be i
(if (and (setq e (entget (vlax-vla-object->ename be)))
(not (cdr (assoc 102 e)))
(setq obj (entmakex e))
(setq obj (vlax-ename->vla-object obj))
)
(progn
(vla-transformby obj (vlax-tmatrix tm))
(setq lst (cons (list obj (vla-get-color obj)) lst))
(vla-put-color obj 1)
(vla-update obj)
)
(princ (strcat "\nComplex entity not created [ "
(cdr (assoc 0 e))
" ]"
)
)
)
)
(progn
(setq obj (vlax-ename->vla-object (entmakex (entget (car e)))))
(vla-transformby obj (vlax-tmatrix tm))
(setq lst (cons (list obj (vla-get-color obj)) lst))
(vla-put-color obj 1)
(vla-update obj)
)
)
)
(if lst
(progn (foreach o lst
;;(vla-put-color (car o) (cadr o))
(setq ss (ssadd (vlax-vla-object->ename (car o)) ss))
(command ".draworder"
(vlax-vla-object->ename (car o))
""
"front"
)
)
(sssetfirst nil ss)
)
)
(princ)
)