2016.03.11 13:37
안녕하세요.
제가 인터넷에서 지시선 정렬 LISP을 받았는데,
내용은 아래와 같습니다.
----------------------------------------------------------------------------------------------------------------------------------------------------------------
;;; aligns the landings of selected 3 point leaders to a picked point or selection of leader
;;; and makes landing horizontal (if not already)
(defun c:dd (/ c# crds doc e ins newpt obj ss txt x y sel)
(vl-load-com)
(setq doc (vla-get-activedocument (vlax-get-acad-object)))
(initget 0 "Leader PickPoint")
(if (= (cond ((getkword
(strcat "\n Align by [Leader/PickPoint] <Leader>: ")
)
)
("Leader")
)
"Leader"
)
(and (setq e (car (entsel "\nSelect leader for alignment: ")))
(setq x (cadr (assoc 10 (reverse (entget e)))))
)
(setq x (car (getpoint "\nSelect point for alignment: ")))
)
(if (and x (setq ss (ssget '((0 . "leader")))))
(progn (vla-endundomark doc)
(vla-startundomark doc)
(foreach l (vl-remove e
(vl-remove-if 'listp (mapcar 'cadr (ssnamex ss)))
)
(setq obj (vlax-ename->vla-object l)
crds (vlax-get obj 'coordinates)
c# (length crds)
)
(if (and (= c# 9) ;if leader has 3 points and /= x coord
(not (equal x (nth (- c# 3) crds) 0.0001))
)
(progn (setq y (nth (- c# 5) crds) ;new y coord to ensure flat landing
newpt (list x y (nth (1- c#) crds))
)
(vlax-put obj
'coordinates
(append (reverse (cdddr (reverse crds))) newpt)
)
(vla-update obj)
(and (setq txt (vl-catch-all-apply ;has text attached to leader
'vlax-ename->vla-object
(list (cdr (assoc 340 (entget l))))
)
)
(not (vl-catch-all-error-p txt)) ;check for invalid ename
(setq ins (vlax-get txt 'insertionpoint))
(vlax-put txt
'insertionpoint
(polar (list x (cadr ins) (caddr ins))
(if (> x (nth (- c# 3) crds))
0.
pi
)
(if (zerop (getvar 'tilemode))
(vla-get-textgap obj)
(* (getvar 'dimscale) (vla-get-textgap obj))
)
)
)
(vla-update txt)
)
)
)
)
(vla-endundomark doc)
)
)
(princ)
)
------------------------------------------------------------------------------------------------------------------------------------------------------------
이 리습이 3점인 지시선에는 적용이 되는데,
2점인 지시선에서는 적용이 안되더라구요.
어떻게 2점까지 쉽게 추가할 수 있는 방법은 없는 것입니까?!
부탁드립니다!
번호 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|
공지 | ★ 드림플러스 질문은 메일 또는 홈페이지에 부탁합니다 ★ | 아저씨 | 2017.05.16 | 2774 |
공지 | 제목이 엉망이면 답변달지 않습니다. [1] | 아저씨 | 2014.04.04 | 23853 |
공지 | 순수 캐드 질문은 고캐드로 | 아저씨 | 2013.05.28 | 68640 |
공지 | 질문 답변 게시판을 만들었습니다. | 아저씨 | 2013.02.09 | 74943 |
1369 | 캐드 아이피를 변경한후 드림플러스가 작동을 안합니다. [2] | 허양 | 2016.03.15 | 95 |
1368 | 종단면도 변경 [2] | 김연수` | 2016.03.15 | 285 |
1367 | 입금이름을다르게하였습니다. [1] | u | 2016.03.15 | 28 |
1366 | 드림이 실행이 안돼요 도움 부탁드립니다 [2] | 모리 | 2016.03.14 | 193 |
1365 | 드림플러스 구매에 관련하여 [2] | 왜때문에 | 2016.03.14 | 103 |
1364 | 문자열에서Boolean형식으로 변환할수 없습니다 [1] | 명경지수 | 2016.03.14 | 348 |
» | 지시선 정렬 LISP 관련 문의드립니다. [2] | asami486 | 2016.03.11 | 114 |
1362 | 선형에 측점쓰기 관련 문의사항입니다. [1] | 조직을위한안타 | 2016.03.11 | 158 |
1361 | 명령어 DIVD 관련 질문을 드립니다. [1] | 달하인 | 2016.03.10 | 87 |
1360 | 드림 관련 문의 드립니다. [1] | 울랄랄 | 2016.03.10 | 46 |
1359 | 구매시 호환문의 드립니다 [1] | ahn | 2016.03.10 | 27 |
1358 | 런타임오류 질문입니다. [1] | kimwonyoung | 2016.03.10 | 201 |
1357 | 좌표가져오기 오류질문입니다. [1] | 가르쳐주세요 | 2016.03.10 | 125 |
1356 | Z값 쓰기 리습 요청 [1] | 꼼지락 | 2016.03.09 | 187 |
1355 |
드림 자동출력 질문입니다.
[1] ![]() | aA | 2016.03.09 | 1 |
안녕하세요.
저는 리습 언어를 모릅니다.
제가 할 줄아는 언어는 VB 또는 .NET 뿐입니다.
질문은 고캐드 질문게시판에 올리는 것이 나을 것 같습니다.