明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
楼主: menger_8

[已解答] 怎样实现多义线的随意拉伸

  [复制链接]
 楼主| 发表于 2011-11-15 12:55:59 | 显示全部楼层
感谢大家的回复,xshrimp的代码存在一点儿小瑕疵,加入是梯形,拉伸梯形的上边,随着拉伸这条变越来越短,最后变成0,再继续拉伸梯形的两条斜边就交叉了,如果能达到类似于cad中stretch的效果是最好的,我的思路点击这条边后可以得到这条变的多边形上的2个端点,然后调用cad的stretch命令,然后通过“F栏选”将这条边包含进去,然后拉伸?
发表于 2011-11-15 20:03:24 | 显示全部楼层
本帖最后由 vormittag 于 2011-11-15 20:08 编辑

我简单写了一个,代码不一定健壮。楼主可以试试看是不是这个效果,只对lwpolyline有效。
  1. (defun c:te(/ ell pename pt obj n ptlist ellpre ellpost pts pte pt1 p linename lineell)
  2. (while (or (not (setq pename (entsel))) (/= (cdr (assoc 0 (setq ell (entget (car pename))))) "LWPOLYLINE"))
  3. );while
  4. (setq pt      (cadr pename)
  5.        obj     (vlax-ename->vla-object (car pename))
  6.     n       (fix (vlax-curve-getParamAtPoint obj (vlax-curve-getClosestPointTo obj (trans pt 1 0))))
  7.     pts     (nth n (apply 'append (mapcar '(lambda(x) (if (= 10 (car x)) (list (cdr x)))) ell)))
  8.     ellpre  (member (cons 10 pts) (reverse ell))
  9.     ellpost (cdr (member (cons 10 pts) ell))
  10.     pte     (cdr (assoc 10 ellpost))
  11.     p       (grread t 4 0)
  12.     pt1     (cadr p)
  13. );setq
  14. (entmake (list '(0 . "LINE") (cons 10 (trans pt 1 0)) (cons 11 (trans pt1 1 0))))
  15. (setq linename (entlast)
  16.     lineell  (entget linename)
  17. );setq
  18. (while (= 5 (car p))
  19.   (setq p       (grread t 4 0)
  20.         pt1     (cadr p)
  21.      vec     (mapcar '- (trans pt1 1 0) (trans pt 1 0))
  22.      ellpre  (subst (cons 10 (mapcar '+ vec pts)) (assoc 10 ellpre) ellpre)
  23.      ellpost (subst (cons 10 (mapcar '+ vec pte)) (assoc 10 ellpost) ellpost)
  24.      ell     (append (reverse ellpre) ellpost)
  25.      lineell (subst (cons 11 (trans pt1 1 0)) (assoc 11 lineell) lineell)
  26.   );setq
  27.   (entmod ell)
  28.   (entmod lineell)
  29. );while
  30. (entdel linename)
  31. (princ)
  32. )


本帖子中包含更多资源

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

x
发表于 2011-11-16 13:20:58 | 显示全部楼层
menger_8 发表于 2011-11-15 12:55
感谢大家的回复,xshrimp的代码存在一点儿小瑕疵,加入是梯形,拉伸梯形的上边,随着拉伸这条变越来越短,最 ...

再写了一个,针对"POLYLINE"的
  1. (defun c:te(/ ell1 ell2 pename ename pt pts pte p pt1 lineename lineell)
  2.         (while (or (not (setq pename (nentsel))) (/= (cdr (assoc 0 (setq ell1 (entget (car pename))))) "VERTEX")))
  3.         (setq pt     (cadr pename)
  4.                   ename  (cdr (assoc 330 ell1))
  5.                   pts    (cdr (assoc 10 ell1))
  6.                   ell2   (entget (entnext (car pename)))
  7.                   pte    (cdr (assoc 10 ell2))
  8.                   p      (grread t 4 0)
  9.                   pt1    (cadr p)
  10.         );setq
  11.         (entmake (list '(0 . "LINE") (cons 10 (trans pt 1 0)) (cons 11 (trans pt1 1 0))))
  12.         (setq linename (entlast)
  13.                   lineell  (entget linename)
  14.         );setq
  15.         (while (= 5 (car p))
  16.                 (setq p       (grread t 4 0)
  17.                           pt1     (cadr p)
  18.                           vec     (mapcar '- (trans pt1 1 0) (trans pt 1 0))
  19.                           ell1    (subst (cons 10 (mapcar '+ vec pts)) (assoc 10 ell1) ell1)
  20.                           ell2    (subst (cons 10 (mapcar '+ vec pte)) (assoc 10 ell2) ell2)
  21.                           lineell (subst (cons 11 (trans pt1 1 0)) (assoc 11 lineell) lineell)
  22.                 );setq
  23.                 (entmod ell1)
  24.                 (entmod ell2)
  25.                 (entupd ename)
  26.                 (entmod lineell)
  27.         );while
  28.         (entdel linename)
  29.         (princ)
  30. )
图就不贴了,和上面没啥区别。
发表于 2012-2-18 16:18:02 | 显示全部楼层
xshrimp 发表于 2011-11-9 15:22
参考

确实可以。真的可以。太好了
发表于 2012-2-18 18:50:55 | 显示全部楼层
每次拉伸能提示输入数值就好
发表于 2012-2-18 18:56:24 | 显示全部楼层
一个矩形然后倒C角,拉伸倒角那边时想把C角一起拉伸,要是有这样程序就好了
发表于 2013-5-13 20:11:18 | 显示全部楼层
xshrimp 发表于 2011-11-9 15:22
参考

这个不错,如果能开启捕捉就好了,拉抻到捕捉点
发表于 2013-5-13 20:38:55 | 显示全部楼层
大虾的程序,很好用啊!
发表于 2013-5-16 13:27:17 | 显示全部楼层
8#楼主的 那个要是有捕捉功能就完美。
发表于 2013-6-6 15:02:08 | 显示全部楼层
先收藏了~~~~~~~~~~~~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-5-23 09:42 , Processed in 0.168238 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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