乐筑天下

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

[编程交流] 多段线长度

[复制链接]

145

主题

590

帖子

446

银币

中流砥柱

Rank: 25

铜币
725
发表于 2022-7-6 11:47:48 | 显示全部楼层 |阅读模式
有人有lisp只显示或输出多段线的长度而不给出总长度吗。我需要按顺序给出每条线的长度,我甚至可以通过交叉窗口来选择这些线。
 
谢谢
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 12:04:46 | 显示全部楼层
这将使你朝着正确的方向前进:
 
  1. (defun c:PolyLen (/ ss)
  2. (vl-load-com)
  3. (if (ssget '((0 . "*POLYLINE")))
  4.    (progn
  5.      (vlax-for obj (setq ss (vla-get-ActiveSelectionSet
  6.                               (vla-get-ActiveDocument
  7.                                 (vlax-get-acad-object))))
  8.        (print (vla-get-length obj)))
  9.      (vla-delete ss)))
  10. (princ))

 
为什么不尝试学习相关的过程?
回复

使用道具 举报

16

主题

36

帖子

20

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
80
发表于 2022-7-6 12:13:50 | 显示全部楼层
有人有VBA宏来获取多段线的总长度吗?
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 12:25:56 | 显示全部楼层
 
例子:
 
  1. Sub Example_Length ()
  2.    Dim lineObj As AcadLWPolyline
  3.    Dim Points(0 To 9) As Double
  4.    points(0) = 1: points(1) = 1
  5.    points(2) = 1: points(3) = 2
  6.    points(4) = 2: points(5) = 2
  7.    points(6) = 3: points(7) = 2
  8.    points( = 4: points(9) = 4
  9.    ' Create the line in model space
  10.    Set lineObj = ThisDrawing.ModelSpace.AddLightWeightPolyline(points)
  11.    ThisDrawing.Application.ZoomAll
  12.    
  13.    MsgBox "The length of the new Line is: " & lineObj.length
  14. End Sub
回复

使用道具 举报

145

主题

590

帖子

446

银币

中流砥柱

Rank: 25

铜币
725
发表于 2022-7-6 12:35:44 | 显示全部楼层
我希望能够很容易地编码。我已经花了很多时间,但这并不容易,目前我有点时间不足,在可预见的未来,我看不到自己有更多的时间花在这方面。
 
谢谢你的帮助,李。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 12:44:36 | 显示全部楼层
这可能更有用(适用于圆、圆弧、直线、多段线、样条曲线…)
 
  1. (defun c:PLen (/ ent Len)
  2. (vl-load-com)
  3. (while
  4.    (progn
  5.      (setq ent (car (nentsel "\nSelect Object: ")))
  6.      (cond (  (eq 'ENAME (type ent))
  7.               (if (vl-catch-all-error-p
  8.                     (setq Len
  9.                       (vl-catch-all-apply (function vlax-curve-getDistatParam)
  10.                         (list ent (vlax-curve-getEndParam ent)))))
  11.                 (princ "\n** Invalid Object **")
  12.                 (princ (strcat "\n-->>  Length = " (rtos Len)  "  <<--")))))))
  13. (princ))
  14.      

 
~'J'~
回复

使用道具 举报

1

主题

1069

帖子

1050

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
69
发表于 2022-7-6 12:48:34 | 显示全部楼层
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-5 10:54 , Processed in 0.676315 second(s), 66 queries .

© 2020-2025 乐筑天下

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