乐筑天下

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

[编程交流] 需要lisp到polyedi的帮助

[复制链接]

5

主题

22

帖子

17

银币

初来乍到

Rank: 1

铜币
25
发表于 2022-7-6 15:53:37 | 显示全部楼层
效果好多了。我真的很感激这一切。但当setq ss时,它看起来只是选择直线,没有曲线。所以它仍然没有对整条线进行多边形编辑(例如,如果你沿着一些墙看,这些墙是红色的,大多数是直线,但有一些区域是曲线。它将对所有部分进行多边形编辑,但这些部分除外)。谢谢
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 15:56:21 | 显示全部楼层
很抱歉,当我现在读到你的帖子时,它确实说要编辑每一层上的所有内容,而不仅仅是线条。
 
我将相应地更新LISP。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 16:00:06 | 显示全部楼层
试试这个:
 
  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,ARC,LWPOLYLINE,POLYLINE")
  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
回复

使用道具 举报

5

主题

22

帖子

17

银币

初来乍到

Rank: 1

铜币
25
发表于 2022-7-6 16:01:55 | 显示全部楼层
没问题。我真的很感激这一切。
回复

使用道具 举报

5

主题

22

帖子

17

银币

初来乍到

Rank: 1

铜币
25
发表于 2022-7-6 16:04:25 | 显示全部楼层
效果完美。我认为你所做的更改实际上可能需要更改,但我不想在你的代码中乱搞。再次感谢。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 16:08:42 | 显示全部楼层
太好了,很高兴你能正常工作。
回复

使用道具 举报

1

主题

17

帖子

16

银币

初来乍到

Rank: 1

铜币
5
发表于 2022-7-6 16:12:07 | 显示全部楼层
先生
 
目前为止我现在知道如何在cad中使用lisp。。但还不知道如何创建一个。。。。我试了一下你发布的代码。。。。
 
首先拾取直线,然后第二次,然后2条直线自动成为多段线。。。
 
有没有可能不选2个点或2条线。。。
您可以使用窗口选择?
 
例如,如果我要转换多行。。插入多段线而不是拾取。。我要用窗户。。。。
我的意思是,不是选择第一行和第二行。。。promt是否可能用于拾取窗口?
 
提前感谢。。。。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 16:14:42 | 显示全部楼层
像这样的?
 
  1. (defun c:pljoin    ()
  2.    (if    (zerop (getvar "PEDITACCEPT"))
  3.    (command "._PEDIT" "_M" (ssget) "" "_Y" "J" "0.0" "")
  4.    (command "._PEDIT" "_M" (ssget) "" "J" "0.0" "")
  5.    ) ;_  end if
  6.    (princ)
  7. ) ;_  end defun
回复

使用道具 举报

1

主题

17

帖子

16

银币

初来乍到

Rank: 1

铜币
5
发表于 2022-7-6 16:17:43 | 显示全部楼层
我已经尝试了代码,它真的很有效。。。而不是挑选
 
现在是窗口。。。
 
每次我把一条线转换成多段线的时候。。。。
 
谢谢很多李先生。。。。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 16:20:01 | 显示全部楼层
没问题,希望从长远来看能为你节省一些时间
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-4 19:19 , Processed in 0.581148 second(s), 70 queries .

© 2020-2025 乐筑天下

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