关于提取交点坐标遇到问题
以下代码(来自本论坛提取点坐标 - AutoLISP/Visual LISP 编程技术 - CAD论坛 - 明经CAD社区 - Powered by Discuz! (mjtd.com))第一个疑问:我使用时候有些T字交点坐标提取不了。只能提取十字交点坐标。如下图每根纵先总共7个交点,现在只提取了5个交点坐标。第二个,交点坐标不需要小数点,怎么调整?
(vl-load-com)
(defun c:tt (/ ss lst lst1 m n x y f)
(defun x_ssn (ss / n lst)
(repeat (setq N (sslength ss))
(setq LST (cons (ssname SS (setq N (1- N))) LST))
)
)
(defun deldup (ptLst alw / pt1)
(cond ((<= (length ptLst) 1) ptLst)
(t
(setq pt1 (car ptLst))
(cons pt1
(vl-remove-if
'(lambda (x) (equal pt1 x alw))
(deldup (cdr ptLst) alw)
)
)
)
)
)
(defun get_dxf (en num /) (cdr (assoc num (entget en))))
(setq f (open (getfiled "坐标输出为:" "d:/" "txt" 1) "w"))
(prompt "\n仅选择纵向线:")
(setq ss(ssget)
lst (x_ssn ss)
lst (vl-sort
lst
'(lambda (x y) (< (car (get_dxf x 10)) (car (get_dxf y 10))))
)
)
(foreach n lst
(setq ss (ssget "f" (list (get_dxf n 10) (get_dxf n 11))))
(setq lst1 (x_ssn ss))
(setq lst1 (deldup (vl-remove nil
(mapcar '(lambda (x)
(vlax-invoke
(vlax-ename->vla-object n)
'IntersectWith
(vlax-ename->vla-object x)
acExtendNone
)
)
lst1
)
)
1e-6
)
lst1 (vl-sort lst1 '(lambda (x y) (< (cadr x) (cadr y))))
)
(foreach m lst1
(write-line
(strcat (rtos (car m) 2 3) "," (rtos (cadr m) 2 3))
f
)
)
(write-line "下一个" f)
)
(close f)
(princ)
)
本帖最后由 夏生生 于 2021-9-16 16:14 编辑
上图,这段程序不一定适合您的需求。可能制图精度的问题,ssget "f"没有选到某个图元
夏生生 发表于 2021-9-16 16:10
上图,这段程序不一定适合您的需求。可能制图精度的问题,ssget "f"没有选到某个图元
可能精度问题。把线修延长一点就可以了。基本上能用了。就是有点麻烦
页:
[1]