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

2016.03.11 13:37

asami486 조회 수:115

안녕하세요.

제가 인터넷에서 지시선 정렬 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
1324 64비트에서 32비트 변환하는 과정에서 문제가있습니다. [1] 아프리카파푸리카 2015.03.06 114
1323 명령어 AVE 정점을 삽입할 폴리선 선택 [2] 위시 2015.04.02 114
1322 6월 드림 깔때 시리얼 묻는 창이 안뜹니다. [1] 건축인 2015.06.01 114
1321 드림플러스는 개인 사용자도 유료로 구입해야 하는건가요?? [1] 마권동 2016.10.19 114
1320 VBA관련 문제 [1] 도라이바 2018.11.30 114
1319 zwcad+ dream 호환 [1] 몰라요 2015.03.04 115
1318 런타임 오류 질문 드립니다. [1] 문코 2015.03.18 115
» 지시선 정렬 LISP 관련 문의드립니다. [2] asami486 2016.03.11 115
1316 다중플룻(MPL) 오류 확인좀 해주세요. [1] sktth2 2016.07.15 115
1315 윈도1032비트 cad2016 기존드림설치문의 [1] 케론 2017.02.08 115
1314 auto cad2011사용중입니다. 드림설치하고 사용하려고 원하는 메뉴 클릭 하면 경고창이 뜹니다. [2] 김태진 2015.06.12 116
1313 길이 측정 [2] 항만설계 2015.10.07 116
1312 다중플롯(CTB관련) 문의드립니다. [1] 닉네임 2016.11.08 116
1311 기존(드림) 라이센스 문의드립니다 [1] 이광호 2021.09.17 116
1310 기존사용자 재설치해도 사용기간만료라고 나와요 [1] 플강 2015.09.11 117