지시선 정렬 LISP 관련 문의드립니다.

2016.03.11 13:37

asami486 조회 수:114

안녕하세요.

제가 인터넷에서 지시선 정렬 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] secret aA 2016.03.09 1