明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2675|回复: 16

[提问] 封闭多段线智能修剪

[复制链接]
发表于 2024-1-15 20:54:00 | 显示全部楼层 |阅读模式
工作中经常碰到要对封闭多段线区域进行修剪,修剪后还是保持为封闭多段线,请各位高手多指教

本帖子中包含更多资源

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

x
发表于 2024-1-17 10:20:26 | 显示全部楼层
这样稳妥一点,但是有“无效的选项关键字”
  1. (defun c:tt  (/ md->3d a en1 en2 pt ss v)
  2.     (defun md->3d  (l) ;_by caoyin
  3.   (if (> (length l) 3)
  4.       (cons (list (car l) (cadr l) (caddr l))
  5.       (md->3d (cdddr l)))
  6.       (list l)))
  7.     (setq en1 (car (entsel "\n选择截断线:"))
  8.     en2 (car (entsel "\n选择被截断:"))
  9.     a   (md->3d (vlax-invoke (vlax-ename->vla-object en1)
  10.            "intersectwith"
  11.            (vlax-ename->vla-object en2)
  12.            acextendnone))
  13.     a   (* 0.5
  14.      (+ (vlax-curve-getparamatpoint en1 (car a))
  15.         (vlax-curve-getparamatpoint en1 (last a))))
  16.     pt  (vlax-curve-getpointatparam en1 a)
  17.     a   (fix a)
  18.     v   (mapcar '-
  19.           (vlax-curve-getpointatparam en1 a)
  20.           (vlax-curve-getpointatparam en1 (1+ a)))
  21.     v   (mapcar '(lambda (x) (/ x (distance '(0 0 0) v) 1.)) v)
  22.     v   (mapcar '(lambda (x) (* x 10))
  23.           (vl-list* (- (cadr v)) (car v) (cddr v)))
  24.     ss  (ssadd)
  25.     ss  (ssadd en1 ss)
  26.     ss  (ssadd en2 ss))
  27.     (if  (and (bpoly (mapcar '+ pt v) ss '(1 0))
  28.        (bpoly (mapcar '- pt v) ss '(1 0)))
  29.   (progn (entdel en1)
  30.          (entdel en2)
  31.          (entdel (car (entsel "\n选择需删除:")))))
  32.     (princ))


评分

参与人数 2明经币 +2 收起 理由
JUN1 + 1 很给力!
panliang9 + 1 很给力!

查看全部评分

回复 支持 1 反对 0

使用道具 举报

发表于 2024-1-16 07:25:03 | 显示全部楼层
boundary命令可以么?
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2024-1-15 20:55:16 | 显示全部楼层
选取红色多段线线对紫色封闭多段线进行修剪
发表于 2024-1-15 20:59:27 | 显示全部楼层
交点处相互打断  再生成两个面域即可
发表于 2024-1-15 21:37:31 | 显示全部楼层
bpoly

本帖子中包含更多资源

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

x
 楼主| 发表于 2024-1-15 22:41:24 | 显示全部楼层
院长厉害,可惜没有源码
发表于 2024-1-15 22:44:47 | 显示全部楼层
wanhongron 发表于 2024-1-15 22:41
院长厉害,可惜没有源码

院长说了 用 bpoly  红线两边各用一次 然后删除原多段线
发表于 2024-1-17 08:26:30 | 显示全部楼层

老大无所不能
发表于 2024-1-17 10:12:58 | 显示全部楼层
试试
  1. (defun c:tt  (/ md->3d a en1 en2 pt v x)
  2.     (defun md->3d  (l) ;_by caoyin
  3.   (if (> (length l) 3)
  4.       (cons (list (car l) (cadr l) (caddr l))
  5.       (md->3d (cdddr l)))
  6.       (list l)))
  7.     (setq en1 (vlax-ename->vla-object (car (entsel "\n选择截断线:")))
  8.     en2 (vlax-ename->vla-object (car (entsel "\n选择被截断:")))
  9.     a   (md->3d (vlax-invoke en1 "intersectwith" en2 acextendnone))
  10.     a   (* 0.5
  11.      (+ (vlax-curve-getparamatpoint en1 (car a))
  12.         (vlax-curve-getparamatpoint en1 (last a))))
  13.     pt  (vlax-curve-getpointatparam en1 a)
  14.     a   (fix a)
  15.     v   (mapcar '-
  16.           (vlax-curve-getpointatparam en1 a)
  17.           (vlax-curve-getpointatparam en1 (1+ a)))
  18.     v   (mapcar '(lambda (x) (/ x (distance '(0 0 0) v) 1.)) v)
  19.     v   (mapcar '(lambda (x) (* x 10))
  20.           (vl-list* (- (cadr v)) (car v) (cddr v))))
  21.     (if  (and (bpoly (mapcar '+ pt v))
  22.        (bpoly (mapcar '- pt v)))
  23.   (progn (entdel en1)
  24.          (entdel en2)
  25.          (entdel (car (entsel "\n选择需删除:"))))))



本帖子中包含更多资源

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

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

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-26 00:24 , Processed in 0.206104 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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