请求不规则图形偏移外框BUG修复(已解決)
此源码是在任何不规则图形上做一个矩型外框并且偏移15MM的外框只留15MM后的外框,原外框會删除
但现再有一个BUG是15MM外框做出来后,原外框会删除,但是只要移动图形或者旋转图形,原外框又会跑出来,有请高手能优化原码吗
**** Hidden Message ***** 看一下
谢谢S大解决了我的困扰
大神您好,这个插件很好用,请问您那边可以帮忙增加一个偏移距离可以自己输入吗?输入后,可以带记忆的 謝謝謝謝謝謝 (defun xBox(s / x p a b lx);;选择集、图元(对象)表、图元(对象)包容盒
(setq s(if(/=(type s)'pickset)(if(listp s)s(list s))(s2e s)))
(while s
(setq x(car s)s(cdr s)a nil b nil)
(cond((=(setq lx(type x))'ename)(vla-getboundingbox(vlax-ename->vla-object x)'a'b))
((= lx'vla-object)(vla-getboundingbox x'a'b))
((and(= lx 'list)(not(VL-CATCH-ALL-ERROR-P(VL-CATCH-ALL-APPLY'vlax-3d-point x))))x))
(if a(setq p(revappend(mapcar'vlax-safearray->list(list a b))p))
(setq p(cons x p))))
(boxofpts p))
(defun BOXofPtS(pt)
(setq pt(mapcar'(lambda(x)(mapcar x pt))'(car cadr)))
(mapcar'(lambda(y)(mapcar'(lambda(x)(apply y x))pt))'(min max)))
(defun s2e(s / n lst)(if(=(type s)'pickset)(repeat(setq n(sslength s))(setq n(1- n)lst(cons(ssname s n)lst)))))
(defun c:tt(/ d s box)
(if(setq s(s2e(ssget '((0 . "circle,arc,ellipse,spline,line,*polyline")))))
(setq box(xBox s)d(getreal"偏移距离")
box(apply'command(cons"rectang"(mapcar'(lambda(X y)(mapcar'+ x y))box(list(list(- d)(- d))(list d d)))))))) 得到box后,根据偏移量直接修改box角点坐标,然后再画矩形
页:
[1]