明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 756|回复: 2

点表双侧偏移(类似OFFSET)

[复制链接]
发表于 2024-5-10 08:21:03 | 显示全部楼层 |阅读模式
点表双侧偏移,类似Offest的方法,不过不支持弧线。用于我的云线插件http://bbs.mjtd.com/forum.php?mod=viewthread&tid=186837&page=1&extra=#pid934925
在论坛找了半天只找到了这个帖子,于是只好自己写了:
http://bbs.mjtd.com/forum.php?mod=viewthread&tid=108141&fromuid=7329538




  1. ;根据UCS折线点表生成两侧偏移的折线
  2. (defun K:GetOFFPL (UCSLst RvCol / K:DynOffUCSLst StaPt Code TmpLst i Key EntNam)
  3.   ;点表偏移多段线
  4.   (defun K:DynOffUCSLst (UCSLst Dst / i StaPT NxtPT Ang FstLst SecLst TmpLst K:INPLst)
  5.         ;求偏移后的UCS每段的交点成UCS点表
  6.         (defun K:INPLst (TmpLst / i SL EL RtnLst)
  7.             (setq i 0)
  8.             (while (< i (1- (length TmpLst)))
  9.                 (setq SL (nth i TmpLst)
  10.                       EL (nth (setq i (1+ i)) TmpLst)
  11.                 )
  12.                 (if (setq InP (inters (car SL) (cadr SL) (car EL) (cadr EL) nil));无限长求交点
  13.                     (setq RtnLst (cons InP RtnLst))
  14.                 )
  15.             )
  16.             (setq RtnLst (append (list (car (car TmpLst))) (reverse RtnLst) (list (cadr (Last TmpLst)))))
  17.         )
  18.         (setq FstLst Nil SecLst Nil)
  19.         (setq i 0);初始化
  20.         (while (< i (1- (length UCSLst)))
  21.             (progn
  22.                 (setq StaPT (nth i UCSLst);UCS
  23.                       NxtPT (nth (setq i (1+ i)) UCSLst);UCS
  24.                 )
  25.                 (setq Ang (- (angle StaPT NxtPT) (* 0.5 pi)))
  26.                 (while (minusp Ang)(setq Ang (+ Ang (* 2 pi))))
  27.                 (setq FstLst (cons (list (polar StaPT Ang (+ 0 Dst)) (polar NxtPT Ang (+ 0 Dst))) FstLst)
  28.                       SecLst (cons (list (polar StaPT Ang (- 0 Dst)) (polar NxtPT Ang (- 0 Dst))) SecLst)
  29.                 )
  30.             )
  31.         );分段两侧偏移
  32.         (setq TmpLst (append (K:INPLst (reverse FstLst)) (reverse (K:INPLst (reverse SecLst)))))
  33.         TmpLst
  34.   )
  35.   ;点表生成多段线
  36.   (defun K:MakeLWPOLYLINE (WCS Clsd PTLst / PT)
  37.     (entmakeX
  38.       (append
  39.         (list
  40.           (cons 0 "LWPOLYLINE")
  41.           (cons 100 "AcDbEntity")
  42.           (cons 100 "AcDbPolyline")
  43.           (cons 90 (length PTLst))
  44.         )
  45.         (if Clsd (list (cons 70 1)))
  46.         (mapcar '(lambda (PT)
  47.                   (cons 10
  48.                     (if WCS PT (trans PT 1 0))
  49.                   )
  50.                 )
  51.           PTLst
  52.         )
  53.       )
  54.     )
  55.   )
  56.   (if (and UCSLst (>= (length UCSLst) 2))
  57.         (progn
  58.             (setq StaPt (Last UCSLst));UCS
  59.             (while
  60.               (progn
  61.                 (princ "\n→请指定偏移距离<或空格>: ")
  62.                 (while (and (setq Code (grread T (+ 1 4 8))) (eq (car Code) 5))
  63.                     (redraw)
  64.                     (grdraw StaPt (cadr Code) RvCol);长度线
  65.                     (setq TmpLst (K:DynOffUCSLst UCSLst (distance StaPt (cadr Code))))
  66.                     (setq i 0);初始化
  67.                     (while (< i (length TmpLst))
  68.                         (if (= (setq i (1+ i)) (length TmpLst));最后一个
  69.                             (grdraw (Last TmpLst) (car TmpLst) RvCol)
  70.                             (grdraw (nth (1- i) TmpLst) (nth i TmpLst) RvCol)
  71.                         )
  72.                     );显示线
  73.                 );显示预览
  74.                 (setq Key (cadr Code))
  75.                 (cond
  76.                   ((and (eq (car Code) 3) (eq (type Key) 'LIST));点选
  77.                       (redraw)
  78.                       (setq EntNam (K:MakeLWPOLYLINE Nil T (K:DynOffUCSLst UCSLst (distance StaPt (cadr Code)))))
  79.                       Nil ;退出循环
  80.                   )
  81.                   ((equal Code '(2 32));空格
  82.                     (redraw)
  83.                     (setq EntNam (K:MakeLWPOLYLINE Nil T  (K:DynOffUCSLst UCSLst (distance StaPt (cadr (grread '(2 32)))))))
  84.                     Nil ;退出循环
  85.                   )
  86.                   (T Nil)
  87.                 )
  88.               )
  89.             )
  90.             EntNam
  91.         )
  92.   )
  93. )




补充一个基础函数:
  1. ;选取多个UCS点用于生成多段线
  2. (defun K:GetUCSPTLst (StaPT BGCol / UCSLst TgtPT)
  3.     (setq UCSLst Nil)
  4.     (if (car (setq UCSLst (list StaPT)))
  5.         (while
  6.           (setq TgtPT (if (>= (length UCSLst) 2)  ;至少两个点
  7.                         (progn
  8.                           (initget "U")
  9.                           (getpoint (car UCSLst) "\n→请指定下一点或空格结束[撤回(U)]: ")
  10.                         )
  11.                         (getpoint (car UCSLst) "\n→请指定下一点或空格结束:")
  12.                       )
  13.           )
  14.           (redraw)
  15.           (mapcar
  16.             '(lambda (a b) (grdraw a b BGCol 1))
  17.             (setq UCSLst (if (eq TgtPT "U")
  18.                           (cdr UCSLst)
  19.                           (cons TgtPT UCSLst)
  20.                         )
  21.             )
  22.             (cdr UCSLst)
  23.           )
  24.         )
  25.     )
  26.     (princ)(redraw)
  27.     (cond ((>= (length UCSLst) 2) (reverse UCSLst)))
  28. )


用法:
  1. (if (and
  2.         (setq StaPT (getpoint))
  3.         (setq UCSLst (K:GetUCSPTLst StaPT 1))
  4.     )
  5.     (K:GetOFFPL UCSLst 1)
  6. )




本帖子中包含更多资源

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

x

评分

参与人数 5明经币 +5 收起 理由
hubeiwdlue + 1 很给力!
飞雪神光 + 1 赞一个!
USER2128 + 1 赞一个!
scut-wtl + 1 赞一个!
ssyfeng + 1 赞一个!

查看全部评分

发表于 2024-5-10 11:16:28 来自手机 | 显示全部楼层
这个真牛逼,谢谢分享。
发表于 2024-5-12 17:33:16 来自手机 | 显示全部楼层
看起很不错。不过打开这个页面电脑浏览器就卡爆了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-25 04:53 , Processed in 0.146593 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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