设为首页收藏本站

晓东CAD家园-论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 623|回复: 13

[工具] 批量平行直线端点连接

[复制链接]

已领礼包: 40个

财富等级: 招财进宝

发表于 2020-5-13 03:18:32 | 显示全部楼层 |阅读模式
  • 插件名称 : 端点连线
  • 作  者 : newer
  • 运行环境 :XDRX API 晓东工具箱 
  • 发布时间 :2020-05-13
  • 命令名称 :xdtb_lnendconect
  • 插件介绍 :批量平行直线端点连接
  • 备  注 : (点击图片可以放大)
(点击图片可以放大)

晓东温馨提示 1、运行环境为 晓东工具箱XDRX API 的插件,请下载最新版本的 晓东工具箱XDRX API开发环境 一键安装
2、在ACAD中如何加载插件,请看 论坛插件使用方法
3、如果您有要求需要定制插件,请到 编程申请 论坛发帖求助

插件详细内容

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
本帖最后由 newer 于 2020-5-13 13:22 编辑

  1. (defun c:xdtb_lnendconect (/ g ents x xdir pts ents ln y lst)
  2.   (defun _keyword (keyword)
  3.     (cond ((= keyword "1") (setq #xd-var-global-left-right 0))
  4.           ((= keyword "2") (setq #xd-var-global-left-right 1))
  5.            ((= keyword "3") (setq #xd-var-global-left-right 2))
  6.    )
  7.     (_prompt)
  8.   )
  9.   (defun _prompt ()
  10.     (xdrx_prompt
  11.       "\n>>当前设置:"
  12.       (cond ((= 1 #xd-var-global-left-right) "连接左下端点.")
  13.             ((= 2 #xd-var-global-left-right) "连接右上端点.")
  14.             ((= 3 #xd-var-global-left-right) "两端都连.")
  15.       )
  16.     )
  17.   )
  18.   (defun _mkpline (pts)
  19.     (setq g (xdge::constructor "kcompositecrv3d" pts))
  20.     (xdrx-entity-make g)
  21.     (xdge::free g)
  22.   )
  23.   (if (not #xd-var-global-left-right)
  24.     (setq #xd-var-global-left-right 0)
  25.   )
  26.   (xdrx-begin)
  27.   (while
  28.     (and (_prompt)
  29.          (xdrx-initget "1 2 3")
  30.          (xdrx-initssget
  31.            "\n选择要连接端点的曲线[连接左下(1)/连接右上(2)/两端都连(3)]<退出>:"
  32.            "0 1 2"
  33.            ""
  34.            "_keyword"
  35.          )
  36.          (setq ss (xdrx-ssget '((0 . "line"))))
  37.     )
  38.      (setq lst (xd::list:groupbyindex
  39.                  (mapcar '(lambda (x)
  40.                             (setq ln (xdrx-getpropertyvalue x "vertices")
  41.                                   an (xdrx-getpropertyvalue x "angle")
  42.                                   an (xd::geom:angleformat an)
  43.                             )
  44.                             (list an x)
  45.                           )
  46.                          (xdrx-pickset->ents ss)
  47.                  )
  48.                  0.001
  49.                )
  50.      )
  51.      (setq lst (mapcar '(lambda        (x)
  52.                           (setq        ents (cdr x)
  53.                                 xdir (xdrx-vector-normalize
  54.                                        (mapcar '-
  55.                                                (polar '(0 0 0) (car x) 1.0)
  56.                                                '(0 0 0)
  57.                                        )
  58.                                      )
  59.                           )
  60.                           (setq box (xdrx-entity-box ents xdir))
  61.                           (setq        ents (mapcar '(lambda (y)
  62.                                                 (setq p1  (xdrx-getpropertyvalue y "startpoint")
  63.                                                       dis (abs (xdrx-point-dist2line
  64.                                                                  p1
  65.                                                                  (car box)
  66.                                                                  (cadr box)
  67.                                                                )
  68.                                                           )
  69.                                                 )
  70.                                                 (list dis y)
  71.                                               )
  72.                                              ents
  73.                                      )
  74.                           )
  75.                           (setq        ents
  76.                                  (vl-sort ents '(lambda (x y) (< (car x) (car y))))
  77.                           )
  78.                           (mapcar 'cadr ents)
  79.                         )
  80.                        lst
  81.                )
  82.      )
  83.      (setq lst (mapcar '(lambda        (x)
  84.                           (mapcar '(lambda (y)
  85.                                      (setq ln (xdrx-getpropertyvalue y "vertices")
  86.                                            an (xdrx-getpropertyvalue y "angle")
  87.                                            an (xd::geom:angleformat an)
  88.                                      )
  89.                                      (if (> an (/ pi 2))
  90.                                        (reverse ln)
  91.                                        ln
  92.                                      )
  93.                                    )
  94.                                   x
  95.                           )
  96.                         )
  97.                        lst
  98.                )
  99.      )
  100.     (xdrx_setmark)
  101.      (mapcar
  102.        '(lambda        (x)
  103.           (cond
  104.             ((= #xd-var-global-left-right 1) (_mkpline (mapcar 'car x)))
  105.             ((= #xd-var-global-left-right 2) (_mkpline (mapcar 'cadr x)))
  106.             (t (_mkpline (mapcar 'car x))(_mkpline (mapcar 'cadr x)))
  107.           )
  108.         )
  109.        lst
  110.      )          (xdrx-setpropertyvalue (xdrx_getss) "color" 6)

  111.   )
  112.   (xdrx-end)
  113.   (princ)
  114. )

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 6个

财富等级: 恭喜发财

发表于 2020-5-13 07:31:47 | 显示全部楼层
厉害了,我要保存一下666666666666666
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 102个

财富等级: 日进斗金

发表于 2020-5-13 08:01:05 | 显示全部楼层
厲害了,我要保存一下
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 408个

财富等级: 日进斗金

发表于 2020-5-13 08:01:27 | 显示全部楼层
好奇特的功能,下来看看
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2094个

财富等级: 金玉满堂

发表于 2020-5-13 08:45:07 | 显示全部楼层
谢谢楼主分享,不错的插件。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 138个

财富等级: 日进斗金

发表于 2020-5-13 09:03:07 | 显示全部楼层
每天到论坛来逛逛,都会有意想不到的收获。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 5071个

财富等级: 富甲天下

发表于 2020-5-13 09:16:16 | 显示全部楼层
这个代码的用处还是很多的。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2020-5-13 13:12:57 | 显示全部楼层
感谢楼主分享
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 3个

财富等级: 恭喜发财

发表于 2020-5-13 16:10:13 | 显示全部楼层
谢谢楼主分享
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2020-5-14 22:01:28 | 显示全部楼层
厉害了,我的哥
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 10个

财富等级: 恭喜发财

发表于 2020-5-15 08:33:09 | 显示全部楼层
只对平行线有用?????
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 7个

财富等级: 恭喜发财

发表于 2020-5-16 06:21:48 | 显示全部楼层
最终修改的,更牛逼!!!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2020-5-18 12:49:51 | 显示全部楼层
好先进的科技 收藏了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 7个

财富等级: 恭喜发财

发表于 2020-5-28 13:46:05 | 显示全部楼层
不错的,谢谢楼主分享。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|小黑屋|手机版|Archiver|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )  

GMT+8, 2021-9-23 01:58 , Processed in 0.927263 second(s), 57 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表