乐筑天下

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

[编程交流] 将2条线/线连接成一个sin

[复制链接]

0

主题

1

帖子

1

银币

初来乍到

Rank: 1

铜币
0
发表于 2022-7-6 16:18:40 | 显示全部楼层
我有一个类似的问题。。。我使用的是激光数控机床,为了正确进行切割,必须将多段线连接在一起,并且尽可能长。
 
 
  1. (defun c:jln(/ l1 l2 fz)
  2. (setvar "PEDITACCEPT" 1)
  3.   (if
  4.    (and
  5.      (setq l1(entsel "\nSelect first line > "))
  6.      (setq l2(entsel "\nSelect second line > "))
  7.      (setq fz(distance(cadr l1)(cadr l2)))
  8.      (vl-cmdf "_.pedit" "_m" (car l1)(car l2) "" "_j" "_j" "_a" fz "")
  9.    ); end and
  10.    (c:jln)
  11.    ); end if
  12. (princ)
  13. ); end c:jln

 
我的画上有很多线条,有时候线条有些重叠。该程序当前在顶点之间绘制线。我想稍微改变一下节目。你能帮忙吗?
 
1) 我想在窗口中选择多行或多次单击,而不是先选择第一行,然后选择第二行。
 
2) 不要在顶点之间绘制一条线,而是提示“要连接的顶点之间的最大距离”。如果较小,顶点将移动并捕捉在一起,如果较大,则不会移动顶点以将其捕捉在一起。(如果顶点有点偏离,请将其连接起来)
 
3) 提示“要绘制线的顶点之间的最大距离”如果较小,程序将在顶点之间绘制线,如果较大,程序将不连接顶点。(如果顶点太远,请绘制一条线并将其连接起来)
 
4) 如果顶点距离小于一定距离,并且在它们之间已经绘制了线,则先将它们连接起来并删除额外的顶点。
 
我想这里可能有两个节目。
 
谢谢
 
阿斯米,你以前的节目很有帮助!!
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 16:23:56 | 显示全部楼层
这可能会帮助你-我写的另一个人在这里使用数控机床。
 
  1. (defun c:pljoin    (/ *error* varLst oldVars oLst plnum ss)
  2.    ;;     --- Error Trap ---
  3.    (defun *error* (msg)
  4.    (mapcar 'setvar varLst oldVars)
  5.    (if (= msg "")
  6.        (princ "\nFunction Complete.")
  7.        (princ (strcat "\n" (strcase msg)))
  8.    ) ;_  end if
  9.    (princ)
  10.    ) ; end of *error*
  11.    (setq varLst  (list "CMDECHO" "PEDITACCEPT")
  12.      oldVars (mapcar 'getvar varLst)
  13.    ) ; end setq
  14.    ;;     --- Error Trap ---
  15.    (vl-load-com)
  16.    (vlax-for l
  17.        (vla-get-Layers
  18.            (vla-get-ActiveDocument
  19.            (vlax-get-acad-object)
  20.            ) ;_  end vla-get-ActiveDocument
  21.        ) ;_  end vla-get-Layers
  22.    (setq oLst
  23.         (cons (vla-get-Name l) oLst)
  24.    ) ; end setq
  25.    ) ; end vlax-for
  26.    (setq oLst (reverse oLst))
  27.    (setvar "cmdecho" 0)
  28.    (setvar "PEDITACCEPT" 0)
  29.    (setq plnum 0)
  30.    (foreach lay oLst
  31.    (if
  32.        (setq ss (ssget "X"
  33.                (list (cons 0 "LINE")
  34.                  (cons 410 (getvar "ctab"))
  35.                  (cons 8 lay)
  36.                ) ;_  end list
  37.             ) ;_  end ssget
  38.        ) ;_  end setq
  39.           (progn
  40.           (command "_pedit" "M" ss "" "Y" "J" "0.0" "")
  41.           (setq plnum (+ (sslength ss) plnum))
  42.           ) ;_  end progn
  43.    ) ;_  end if
  44.    ) ;_  end foreach
  45.    (*error* "")
  46.    (alert (strcat (rtos plnum 2 0) " Polylines Created/Joined."))
  47.    (princ)
  48. ) ;_  end defun
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-4 19:39 , Processed in 0.380511 second(s), 55 queries .

© 2020-2025 乐筑天下

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