找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2213|回复: 11

[求助] 如何让圆内直线从中点断开

[复制链接]
发表于 2013-11-24 20:41:35 | 显示全部楼层 |阅读模式

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

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

×
批量打断圆内直线,打断点为园内直线的中点,如图
听说这里高手比较多,谁能帮解决下,衷心感谢!
QQ图片20131124202122.jpg
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-11-24 21:55:28 | 显示全部楼层
给你个思路,用API没有几句话
  1. (defun c:tt (/ lss box)
  2.   (if (and (setq lss (ssget '((0 . "line")))) ;_直线选择集
  3.            (setq box (xdrx_entity_box lss))
  4.            (progn
  5.              (if (apply 'xdrx_document_isptoutscreen box) ;_不能在屏幕外
  6.                (xdrx_document_zoomw (car box) (nth 2 box))
  7.              )
  8.              t
  9.            )
  10.       )
  11.     (mapcar
  12.       '(lambda (x / sp ep ss pts)
  13.          (setq sp (xdrx_curve_getstartpoint x)
  14.                ep (xdrx_curve_getendpoint x)
  15.          )
  16.          (if (setq ss (ssget "F" (list sp ep) '((0 . "circle")))) ;_构造每个通过直线的圆选集
  17.            (progn
  18.              (setq
  19.                pts (vl-remove-if
  20.                      '(lambda (l) (= (length l) 1))
  21.                      (mapcar '(lambda (a) (mapcar 'cadr (cdddr a)))
  22.                              (ssnamex ss)
  23.                      )
  24.                    )
  25.                pts (mapcar '(lambda (a) (apply 'xdrx_line_midp a))
  26.                            pts
  27.                    )
  28.              )
  29.              (apply 'xdrx_curve_getsplitcurves
  30.                     (cons x pts)
  31.              )
  32.            )
  33.          )
  34.        )
  35.       (xdrx_pickset->ents lss)
  36.     )
  37.   )
  38.   (princ)
  39. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-11-24 22:47:10 | 显示全部楼层
其实Lisp也很简单

  1. (defun c:tt (/ lss sl i e sp ep ss)
  2.   (if (setq lss (ssget '((0 . "line")))) ;_直线选择集
  3.     (progn
  4.       (setq sl (sslength lss)
  5.             i  -1
  6.       )
  7.       (repeat sl
  8.         (setq e         (ssname lss (setq i (1+ i)))
  9.               sp (vlax-curve-getstartpoint e)
  10.               ep (vlax-curve-getendpoint e)
  11.         )
  12.         (if (setq ss (ssget "F" (list sp ep) '((0 . "circle")))) ;_构造每个通过直线的圆选集
  13.           (progn
  14.             (setq
  15.               pts (vl-remove-if
  16.                     '(lambda (l) (= (length l) 1))
  17.                     (mapcar '(lambda (a) (mapcar 'cadr (cdddr a)))
  18.                             (ssnamex ss)
  19.                     )
  20.                   )
  21.               pts (mapcar '(lambda (a)
  22.                              (mapcar '*
  23.                                      '(0.5 0.5 0.5)
  24.                                      (apply 'mapcar (cons '+ a))
  25.                              )
  26.                            )
  27.                           pts
  28.                   )
  29.             )
  30.             (mapcar '(lambda (a /)
  31.                        (vl-cmdf ".break" (list e a) "f" "_none" a "@")
  32.                        ;;(command-s ".break" e "F" "Non" a "@");_2012+
  33.                      )
  34.                     (reverse pts)
  35.             )
  36.           )
  37.         )
  38.       )
  39.     )
  40.   )
  41.   (princ)
  42. )

点评

程序中需注意先将SP和EP转换到UCS坐标系,否则在UCS坐标系下程序则不能正确运行!  详情 回复 发表于 2013-11-25 11:28
API有思路了,对应的VL函数能换的一换就行了。  详情 回复 发表于 2013-11-24 23:12

评分

参与人数 1D豆 +5 收起 理由
牢固 + 5 热心帮忙奖!

查看全部评分

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

使用道具 举报

已领礼包: 40个

财富等级: 招财进宝

发表于 2013-11-24 23:12:35 | 显示全部楼层

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

使用道具 举报

已领礼包: 344个

财富等级: 日进斗金

发表于 2013-11-25 11:28:32 | 显示全部楼层

程序中需注意先将SP和EP转换到UCS坐标系,否则在UCS坐标系下程序则不能正确运行!

点评

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

使用道具 举报

 楼主| 发表于 2013-11-25 11:30:25 | 显示全部楼层
本帖最后由 rose1 于 2013-11-25 11:32 编辑

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

使用道具 举报

 楼主| 发表于 2013-11-25 11:53:11 | 显示全部楼层
牢固 发表于 2013-11-25 11:28
程序中需注意先将SP和EP转换到UCS坐标系,否则在UCS坐标系下程序则不能正确运行!

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

使用道具 举报

 楼主| 发表于 2013-11-25 11:57:36 | 显示全部楼层
水平 正好通过圆心时候 没法断开
怎么解决一下?

点评

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

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-11-25 12:54:07 来自手机 | 显示全部楼层
rose1 发表于 2013-11-25 11:57
水平 正好通过圆心时候 没法断开
怎么解决一下?

你用的是上面代码?

点评

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

使用道具 举报

 楼主| 发表于 2013-11-25 13:05:01 | 显示全部楼层
st788796 发表于 2013-11-25 12:54
你用的是上面代码?

用的是第二个

点评

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

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-11-25 14:19:52 | 显示全部楼层

换一种方法

  1. (defun c:tt (/ lss sl i e sp ep ss el)
  2.   (if (setq lss (ssget '((0 . "line")))) ;_直线选择集
  3.     (progn
  4.       (setq sl (sslength lss)
  5.             i  -1
  6.       )
  7.       (repeat sl
  8.         (setq e         (ssname lss (setq i (1+ i)))
  9.               sp (trans (vlax-curve-getstartpoint e) 0 1)
  10.               ep (trans (vlax-curve-getendpoint e) 0 1)
  11.         )
  12.         (if (setq ss (ssget "F" (list sp ep) '((0 . "circle")))) ;_构造每个通过直线的圆选集
  13.           (progn
  14.             (setq
  15.               pts (vl-remove-if
  16.                     '(lambda (l) (= (length l) 1))
  17.                     (mapcar '(lambda (a) (mapcar 'cadr (cdddr a)))
  18.                             (ssnamex ss)
  19.                     )
  20.                   )
  21.               pts (mapcar '(lambda (a)
  22.                              (mapcar '*
  23.                                      '(0.5 0.5 0.5)
  24.                                      (apply 'mapcar (cons '+ a))
  25.                              )
  26.                            )
  27.                           pts
  28.                   )
  29.               el  (entget e)
  30.               el  (subst (cons 11 (car pts))
  31.                          (assoc 11 el)
  32.                          el
  33.                   )
  34.             )
  35.             (entmod el)
  36.             (mapcar '(lambda (a b /)
  37.                        (setq el        (subst (cons 10 a)
  38.                                        (assoc 10 el)
  39.                                        el
  40.                                 )
  41.                              el        (subst (cons 11 b)
  42.                                        (assoc 11 el)
  43.                                        el
  44.                                 )
  45.                        )
  46.                        (entmake el)
  47.                      )
  48.                     (cdr pts)
  49.                     (cddr pts)
  50.             )
  51.           )
  52.         )
  53.       )
  54.     )
  55.   )
  56.   (princ)
  57. )

点评

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

使用道具 举报

已领礼包: 6468个

财富等级: 富甲天下

发表于 2014-1-23 22:54:46 | 显示全部楼层

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-25 02:28 , Processed in 0.503596 second(s), 57 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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