明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 334|回复: 3

按线型统计长度并输出总长度

[复制链接]
发表于 2023-12-10 13:29 | 显示全部楼层 |阅读模式
50明经币
本帖最后由 刘大叔 于 2023-12-10 22:43 编辑

之前在“源码共享”版块看到的一个帖子,原帖如下:按线型统计长度,求助 - 源码共享 - AutoCAD论坛 - 明经CAD社区 - Powered by Discuz! (mjtd.com)
原帖的问题说是已解决,由“飞雪神光”修改的lsp代码如下:
  1. <blockquote>(defun c:mm4(/ bf-curve-length jg lm-entmake-text n num1 num2 pt ss ss2 ty xx zc)


我只是修改了输出的字体高度和行距,修改后的代码如下:
  1. (defun c:mm4(/ bf-curve-length jg lm-entmake-text n num1 num2 pt ss ss2 ty xx zc)
  2.   (defun BF-curve-Length (curve)
  3.                 (vlax-curve-getDistAtParam
  4.                         curve
  5.                         (vlax-curve-getEndParam curve)
  6.                 )
  7.         )
  8.         (defun lm-entmake-text(tdata / pt wz gd co tc)
  9.                 (mapcar'set '(pt wz gd co tc) tdata)
  10.                 (or co (setq co 256))
  11.                 (or tc (setq tc (getvar "clayer")))
  12.                 (entmake(list '(0 . "text")(cons 8 tc)(cons 62 co)'(50 . 0.0) (cons 10 pt)(cons 11 pt)(cons 1 wz)'(7 . "Standard")(cons 40 gd)'(6 . "Continuous")'(41 . 0.8)'(72 . 1)'(210 0.0 0.0 1.0)'(100 . "AcDbText")'(73 . 2)))
  13.                 (entlast)
  14.         )
  15.         (setq ss (ssget '((0 . "*LINE,CIRCLE,ARC") (-4 . "<NOT") (6 . "bylayer") (-4 . "NOT>") (-4 . "<NOT") ( 6 . "byblock") (-4 . "NOT>"))))
  16.   (setq pt (getpoint "指定统计结果写入位置:"))
  17.   (setq num1 (sslength ss) num2 0)
  18.   (while (/= num1 num2)
  19.     (setq
  20.                         ty (ssname ss 0)
  21.                         xx (cdr (assoc 6 (entget ty)))
  22.                         ss2 (ssget "p" (list (cons 6 xx)))
  23.                         zc 0
  24.                         n 0
  25.                 )
  26.                 (repeat (sslength ss2)
  27.                         (setq ty (ssname ss2 n))
  28.                         (setq zc (+ zc (BF-curve-Length ty)))
  29.                         (setq n (+ n 1))
  30.                 )
  31.                 (setq jg (strcat xx "=" (rtos (/ zc 1000) 2 2) "米"))
  32.                 (lm-entmake-text (list pt jg 350))  ;字体高度
  33.                 (setq pt (polar pt (* pi 1.5) 500)) ;行距
  34.                 (setq num2 (+ num2 (sslength ss2)))
  35.                 (command "Select" ss "R" ss2 "")
  36.                 (setq ss (ssget "_P"))
  37.         )
  38. )
在cad2023中运行,显示“错误,参数太多”。请大神帮助修改代码,谢谢!
如能达成以下要求最好:
输出的时候能否以表格形式呈现,譬如:


希望能有大神解决问题,第一次发悬赏贴,悬赏的明经币不够的话留言哈。
附件如下:





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

最佳答案

查看完整内容

玩玩看,是这个意思不

评分

参与人数 1明经币 +1 收起 理由
xj6019 + 1 淡定

查看全部评分

发表于 2023-12-10 13:29 | 显示全部楼层
玩玩看,是这个意思不

本帖子中包含更多资源

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

x
回复

使用道具 举报

 楼主| 发表于 2023-12-10 22:42 | 显示全部楼层
xj6019 发表于 2023-12-10 14:24
玩玩看,是这个意思不

就是这个!大神果然厉害!已设置最佳答案,感谢!
回复

使用道具 举报

发表于 2023-12-28 13:42 | 显示全部楼层
xj6019 发表于 2023-12-10 13:29
玩玩看,是这个意思不

可以改个按颜色的吗
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-30 17:00 , Processed in 0.405808 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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