找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1222|回复: 6

[求助] 多段线修剪问题并得到线与多段线的交点表

[复制链接]

已领礼包: 79个

财富等级: 招财进宝

发表于 2014-2-16 21:27:46 | 显示全部楼层 |阅读模式

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

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

×
多段线修剪问题
并得到直线与多段线的交点表

(6[Q~NKWFBV6C7@QSXNFPXL.jpg


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

已领礼包: 1268个

财富等级: 财源广进

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

使用道具 举报

已领礼包: 685个

财富等级: 财运亨通

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

使用道具 举报

已领礼包: 2226个

财富等级: 金玉满堂

发表于 2014-2-16 23:14:13 | 显示全部楼层
(defun c:tt (/ a b boxs ed ints ss sss x y)
  (vl-load-com)
  (setq ss (ssget '((0 . "LWPOLYLINE"))))
  (if ss
    (foreach a (vl-remove-if 'listp (mapcar
                                      'cadr
                                      (ssnamex ss)
                                    )
               )
      (setq boxs (m-objbox (vlax-ename->vla-object a)))
      (setq sss (ssget "_C" (car boxs) (last boxs)))
      (if sss
        (foreach b (vl-remove-if 'listp (mapcar
                                          'cadr
                                          (ssnamex sss)
                                        )
                   )
          (setq ed (entget b)
                ints nil
          )
          (if (= "LINE" (cdr (assoc 0 ed)))
            (if (setq ints (lm:intersections (vlax-ename->vla-object a)
                                             (vlax-ename->vla-object b) acextendnone
                           )
                )
              (progn
                (mapcar' (lambda (x y)
                           (setq ed (subst
                                      (cons x y)
                                      (assoc x ed)
                                      ed
                                    )
                           )
                         ) (list 10 11) ints
                )
                (entmod ed)
              )
            )
          )
        )
      )
    )
  )
  (princ)
)
(defun lm:intersections (obj1 obj2 mode / l r)
  (setq l (vlax-invoke obj1 'intersectwith obj2 mode))
  (repeat (/ (length l) 3)
    (setq r (cons (list (car l) (cadr l) (caddr l)) r)
          l (cdddr l)
    )
  )
  (reverse r)
)
(defun m-objbox (obj / minp maxp)
  (vla-getboundingbox obj 'minp 'maxp)
  (mapcar
    'vlax-safearray->list
    (list minp maxp)
  )
)

点评

我测试了下, 修剪上完全符合题意, 有个问题 当直线一头在外一头在内的情况,不能实现  详情 回复 发表于 2014-2-17 09:31

评分

参与人数 1D豆 +5 收起 理由
炫翔 + 5 技术引导讨论和指点奖!

查看全部评分

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

使用道具 举报

已领礼包: 1742个

财富等级: 堆金积玉

发表于 2014-2-17 09:31:36 | 显示全部楼层
cable2004 发表于 2014-2-16 23:14
(defun c:tt (/ a b boxs ed ints ss sss x y)
  (vl-load-com)
  (setq ss (ssget '((0 . "LWPOLYLINE") ...

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

使用道具 举报

已领礼包: 79个

财富等级: 招财进宝

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

使用道具 举报

已领礼包: 2226个

财富等级: 金玉满堂

发表于 2014-2-17 23:41:28 | 显示全部楼层
(defun c:tt (/ a b boxs ed ints ss sss x y)
  (vl-load-com)
  (setq ss (ssget '((0 . "LWPOLYLINE"))))
  (if ss
    (foreach a (vl-remove-if 'listp (mapcar
                                      'cadr
                                      (ssnamex ss)
                                    )
               )
      (setq boxs (m-objbox (vlax-ename->vla-object a)))
      (setq sss (ssget "_C" (car boxs) (last boxs)))
      (if sss
        (foreach b (vl-remove-if 'listp (mapcar
                                          'cadr
                                          (ssnamex sss)
                                        )
                   )
          (setq ed (entget b)
                ints nil
          )
          (if (= "LINE" (cdr (assoc 0 ed)))
            (if (setq ints (lm:intersections (vlax-ename->vla-object a)
                                             (vlax-ename->vla-object b) acextendboth
                           )
                )
              (progn
                (mapcar' (lambda (x y)
                           (setq ed (subst
                                      (cons x y)
                                      (assoc x ed)
                                      ed
                                    )
                           )
                         ) (list 10 11) ints
                )
                (entmod ed)
              )
            )
          )
        )
      )
    )
  )
  (princ)
)

评分

参与人数 1D豆 +5 收起 理由
zhuizhu + 5 很给力!经验;技术要点;资料分享奖!

查看全部评分

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-25 00:32 , Processed in 0.425119 second(s), 45 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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