乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 37|回复: 7

[编程交流] 倒角-仅修剪1行

[复制链接]

2

主题

8

帖子

6

银币

初来乍到

Rank: 1

铜币
10
发表于 2022-7-6 09:03:57 | 显示全部楼层 |阅读模式
我经常用6“x6”乘以45度的倒角绘制连接到干管的单线支管。如果“修剪”选项处于启用状态,则将修剪主线和支线。我不想修剪主管道。我关闭了修剪选项,然后必须使用圆角来清理带有支线的倒角。有人知道或有人知道修改过的倒角命令,该命令只会修剪两条线中的一条谢谢
回复

使用道具 举报

63

主题

6297

帖子

6283

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
358
发表于 2022-7-6 09:20:23 | 显示全部楼层
试试这段代码,我为你的情况编写了这段代码,你必须选择要修剪的线的端点,并指定
要修剪所选直线以添加具有角度45指定长度的新线的距离长度。
 
  1. (defun c:test (/ *error* acdoc e d len p1 ent p2 lst clse first second ang)
  2. ;; Tharwat 05. 08. 2011
  3.   (vl-load-com)
  4. (defun *error* ( msg )
  5.    (or (wcmatch (strcase msg) "*BREAK,*CANCEL*,*EXIT*")
  6.        (princ (strcat "\n** Error: " msg " **")))
  7.    (princ)
  8. )
  9. (setq acdoc (vla-get-ActiveDocument (vlax-get-acad-object)))
  10. (if
  11.    (and
  12.      (setq e (entsel "\n Select line :"))
  13.      (eq (cdr (assoc 0 (setq ent (entget (car e))))) "LINE")
  14.      (setq d (getdist "\n Specify the distance :"))
  15.    )
  16.     (progn
  17.       (vla-StartUndoMark acdoc)
  18.       (setq len (sqrt (+ (* d d) (* d d))))
  19.       (setq p1 (cdr (assoc 10 ent )))
  20.       (setq p2 (cdr (assoc 11 ent)))
  21.       (setq lst (vl-remove-if-not
  22.                   (function (lambda (x)
  23.                               (member (car x) '(0 67 410 8 62 210))
  24.                             )
  25.                   )
  26.                   ent
  27.                 )
  28.       )
  29.       (setq clse
  30.              (vlax-curve-getclosestpointto (car e) (trans (cadr e) 1 0))
  31.       )
  32.       (if (< (distance p1 clse) (distance p2 clse))
  33.         (progn
  34.           (setq first p2)
  35.           (setq second (polar first
  36.                               (setq ang (angle p2 p1))
  37.                               (- (distance p2 p1) d)
  38.                        )
  39.           )
  40.         )
  41.         (progn
  42.           (setq first p1)
  43.           (setq second (polar first
  44.                               (setq ang (angle p1 p2))
  45.                               (- (distance p1 p2) d)
  46.                        )
  47.           )
  48.         )
  49.       )
  50.       (entmakex
  51.         (append lst
  52.                 (list (cons 10 (trans first 1 0))
  53.                       (cons 11 (setq x (trans second 1 0)))
  54.                 )
  55.         )
  56.       )
  57.       (entmakex
  58.         (append
  59.           lst
  60.           (list (cons 10 x) (cons 11 (polar x (+ ang 0.785398) len)))
  61.         )
  62.       )
  63.       (entdel (car e))
  64.     )
  65.     (princ "\n Select a line only !! ")
  66. )
  67.    (vla-EndUndoMark acdoc)
  68. (princ)
  69. )
Tharwat
回复

使用道具 举报

pBe

32

主题

2722

帖子

2666

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
211
发表于 2022-7-6 09:27:01 | 显示全部楼层
另一个:
 
  1. (defun c:Test (/ Line1 Line2 PtOfInters ascnum minDist)
  2. (vl-load-com)      
  3. (setq Chad (cond (
  4.      (getdist (strcat "\nEnter Distance: <"
  5.          (rtos (setq Chad (cond ( Chad ) (72))) 2 2) ">: "
  6.        )
  7.      )
  8.    )
  9.    ( Chad )
  10. )
  11. )      
  12. (setvar 'Trimmode 0)
  13. (setvar 'ChamferA (setvar 'ChamferB chad))     
  14. (cond
  15.    ((and
  16.       (setq line1 (car (entsel "\nSelect Main Pipe line: ")))
  17.       (setq line2 (car (entsel "\nSelect second line: ")))
  18.       )
  19. (vl-cmdf "_Chamfer" line1 line2)
  20.        (setq PtOfInters
  21.                   (vlax-invoke
  22.                         (vlax-ename->vla-object Line2)
  23.                         'intersectwith
  24.                         (vlax-ename->vla-object (entlast))
  25.                         acExtendBoth))
  26. (setq minDist (mapcar
  27.      '(lambda (y)
  28.              (distance PtOfInters (cdr y)))
  29.      (list (assoc 10 (entget line2))
  30.              (assoc 11 (entget line2)))))
  31.      (entmod (subst (cons
  32. (setq ascnum                             
  33.      (if (= (length (member (apply 'min minDist) mindist)) 1)
  34.              11
  35.              10)) PtOfInters)(assoc ascnum (entget Line2))(entget Line2))
  36.     )
  37.     )
  38.    )
  39.      (princ)
  40. )

 
没有错误处理程序。无setvar重置。。。。。
 
希望这能有所帮助
回复

使用道具 举报

2

主题

8

帖子

6

银币

初来乍到

Rank: 1

铜币
10
发表于 2022-7-6 09:31:01 | 显示全部楼层
非常感谢你写的例行公事。它工作得很好,但我想知道如果改变它来控制45度倒角绘制的方向,你会考虑作为一种增强吗?
 
-----
请使用代码标签!
 
回复

使用道具 举报

2

主题

8

帖子

6

银币

初来乍到

Rank: 1

铜币
10
发表于 2022-7-6 09:42:33 | 显示全部楼层
再次感谢Tharwat。我试过这个,但当我选择支线时它崩溃了。
回复

使用道具 举报

63

主题

6297

帖子

6283

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
358
发表于 2022-7-6 09:47:14 | 显示全部楼层
也许薄的可以适用于所有角度。
 
  1. (defun c:test (/ *error* acdoc e d a len p1 ent p2 lst clse first second ang)
  2. ;; == Tharwat 09. 08. 2011 == ;;
  3.   (vl-load-com)
  4. (defun *error* ( msg )
  5.    (or (wcmatch (strcase msg) "*BREAK,*CANCEL*,*EXIT*")
  6.        (princ (strcat "\n** Error: " msg " **")))
  7.    (princ)
  8. )
  9. (setq acdoc (vla-get-ActiveDocument (vlax-get-acad-object)))
  10. (if
  11.    (and
  12.      (setq e (entsel "\n Select line :"))
  13.      (eq (cdr (assoc 0 (setq ent (entget (car e))))) "LINE")
  14.      (setq d (getdist "\n Specify the distance :"))
  15.      (setq a (getangle "\n Specify the angle :"))
  16.    )
  17.     (progn
  18.       (vla-StartUndoMark acdoc)
  19.       (setq len (sqrt (+ (* d d) (* d d))))
  20.       (setq p1 (cdr (assoc 10 ent )))
  21.       (setq p2 (cdr (assoc 11 ent)))
  22.       (setq lst (vl-remove-if-not
  23.                   (function (lambda (x)
  24.                               (member (car x) '(0 67 410 8 62 210))
  25.                             )
  26.                   )
  27.                   ent
  28.                 )
  29.       )
  30.       (setq clse
  31.              (vlax-curve-getclosestpointto (car e) (trans (cadr e) 1 0))
  32.       )
  33.       (if (< (distance p1 clse) (distance p2 clse))
  34.         (progn
  35.           (setq first p2)
  36.           (setq second (polar first
  37.                               (setq ang (angle p2 p1))
  38.                               (- (distance p2 p1) d)
  39.                        )
  40.           )
  41.         )
  42.         (progn
  43.           (setq first p1)
  44.           (setq second (polar first
  45.                               (setq ang (angle p1 p2))
  46.                               (- (distance p1 p2) d)
  47.                        )
  48.           )
  49.         )
  50.       )
  51.       (entmakex
  52.         (append lst
  53.                 (list (cons 10 (trans first 1 0))
  54.                       (cons 11 (setq x (trans second 1 0)))
  55.                 )
  56.         )
  57.       )
  58.       (entmakex
  59.         (append
  60.           lst
  61.           (list (cons 10 x) (cons 11 (polar x (+ ang a) len)))
  62.         )
  63.       )
  64.       (entdel (car e))
  65.     )
  66.     (princ "\n Select a line only !! ")
  67. )
  68.    (vla-EndUndoMark acdoc)
  69. (princ)
  70. )

 
塔瓦特
回复

使用道具 举报

2

主题

8

帖子

6

银币

初来乍到

Rank: 1

铜币
10
发表于 2022-7-6 10:00:40 | 显示全部楼层
感谢您修改单行倒角例程!它很好用,你能帮我完成我的请求真是太慷慨了。
 
-布鲁斯
回复

使用道具 举报

63

主题

6297

帖子

6283

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
358
发表于 2022-7-6 10:04:06 | 显示全部楼层
 
不客气,布鲁斯。
 
我很高兴能帮助你。
 
塔瓦特
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-7 06:07 , Processed in 0.449024 second(s), 68 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表