乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 124|回复: 6

请求不规则图形偏移外框BUG修复(已解決)

[复制链接]

6

主题

16

帖子

6

银币

初来乍到

Rank: 1

铜币
40
发表于 2020-3-11 10:15:00 | 显示全部楼层 |阅读模式
此源码是在任何不规则图形上做一个矩型外框
并且偏移15MM的外框只留15MM后的外框,原外框會删除
但现再有一个BUG是15MM外框做出来后,原外框会删除,但是只要移动图形或者旋转图形,原外框又会跑出来,有请高手能优化原码吗

fvjtfiy1ag1.jpg

fvjtfiy1ag1.jpg


本帖以下内容被隐藏保护;需要你回复后,才能看到!

游客,如果您要查看本帖隐藏内容请回复
回复

使用道具 举报

9

主题

357

帖子

13

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
392
发表于 2020-3-11 11:54:00 | 显示全部楼层
看一下
请点击此处下载

请先注册会员后在进行下载

已注册会员,请先登录后下载

文件名称:1kmyf2licci.lsp 
下载次数:0  文件大小:1.47 KB  售价:2银币 [记录]
下载权限: 不限 以上或 Vip会员   [开通Vip]   [签到领银币]  [免费赚银币]



回复

使用道具 举报

6

主题

16

帖子

6

银币

初来乍到

Rank: 1

铜币
40
发表于 2020-3-11 14:00:00 | 显示全部楼层

谢谢S大解决了我的困扰
回复

使用道具 举报

35

主题

311

帖子

14

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
447
发表于 2022-3-22 23:22:00 | 显示全部楼层

大神您好,这个插件很好用,请问您那边可以帮忙增加一个偏移距离可以自己输入吗?输入后,可以带记忆的
回复

使用道具 举报

0

主题

62

帖子

13

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
57
发表于 2022-7-18 17:26:00 | 显示全部楼层
謝謝謝謝謝謝
回复

使用道具 举报

61

主题

718

帖子

13

银币

中流砥柱

Rank: 25

铜币
960
发表于 2022-7-18 17:50:00 | 显示全部楼层
  1. (defun xBox(s / x p a b lx);;选择集、图元(对象)表、图元(对象)包容盒
  2.     (setq s(if(/=(type s)'pickset)(if(listp s)s(list s))(s2e s)))
  3.     (while s
  4.       (setq x(car s)s(cdr s)a nil b nil)
  5.       (cond((=(setq lx(type x))'ename)(vla-getboundingbox(vlax-ename->vla-object x)'a'b))
  6.            ((= lx'vla-object)(vla-getboundingbox x'a'b))
  7.            ((and(= lx 'list)(not(VL-CATCH-ALL-ERROR-P(VL-CATCH-ALL-APPLY'vlax-3d-point x))))x))
  8.       (if a(setq p(revappend(mapcar'vlax-safearray->list(list a b))p))
  9.         (setq p(cons x p))))
  10.     (boxofpts p))
  11. (defun BOXofPtS(pt)
  12.     (setq pt(mapcar'(lambda(x)(mapcar x pt))'(car cadr)))
  13.     (mapcar'(lambda(y)(mapcar'(lambda(x)(apply y x))pt))'(min max)))
  14. (defun s2e(s / n lst)(if(=(type s)'pickset)(repeat(setq n(sslength s))(setq n(1- n)lst(cons(ssname s n)lst)))))
  15. (defun c:tt(/ d s box)
  16.   (if(setq s(s2e(ssget '((0 . "circle,arc,ellipse,spline,line,*polyline")))))
  17.     (setq box(xBox s)d(getreal"偏移距离")
  18.           box(apply'command(cons"rectang"(mapcar'(lambda(X y)(mapcar'+ x y))box(list(list(- d)(- d))(list d d))))))))
回复

使用道具 举报

61

主题

718

帖子

13

银币

中流砥柱

Rank: 25

铜币
960
发表于 2022-7-18 17:52:00 | 显示全部楼层
得到box后,根据偏移量直接修改box角点坐标,然后再画矩形
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-5-25 00:57 , Processed in 3.520372 second(s), 72 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表