乐筑天下

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

[编程交流] 导出到C的直线中点

[复制链接]

66

主题

180

帖子

119

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
341
发表于 2022-7-5 15:54:01 | 显示全部楼层 |阅读模式
我这里有一个导出XYZ长度角度的列表
但是现在我只想导出每条线的中点,有人能帮我吗?
 
  1. (defun c:LINEEXTRACTION ( / d e f i s spt ept)
  2.    (if (and (setq s (ssget '((0 . "LINE"))))
  3.             (setq f (getfiled "" "" "CSV" 1))
  4.             (setq d (open f "w"))
  5.        )
  6.        (progn
  7.            (write-line "Start X,Start Y,Start Z,End X,End Y, End Z,Group,Length,Angle" d)
  8.            (repeat (setq i (sslength s))
  9.                (setq e (entget (ssname s (setq i (1- i))))
  10. spt (cdr (assoc 10 e))
  11. ept (cdr (assoc 11 e))
  12. )
  13.                (write-line
  14.                    (LM:lst->str
  15.                        (append
  16.                            (mapcar 'rtos (cdr (assoc 10 e)))
  17.                            (mapcar 'rtos (cdr (assoc 11 e)))
  18.                            (if (and (setq e (member '(102 . "{ACAD_REACTORS") e))
  19.                            (setq e (member '(102 . "{ACAD_REACTORS") (entget (setq x (cdr (assoc 330 e))))))
  20.                         (setq e (cdr (assoc 3 (member (cons 350 x) (reverse (entget (cdr (assoc 330 e))))))))
  21.                        )
  22.                            (list e)
  23.                    )
  24.                        )
  25.                        ","
  26.                    )
  27.                    d
  28.                )
  29.            )
  30.            (close d)
  31.        )
  32.    )
  33. (prompt "DONE!")
  34. (princ)
  35. )
  36. (defun LM:lst->str ( lst del )
  37.    (if (cdr lst)
  38.        (strcat (car lst) del (LM:lst->str (cdr lst) del)
  39.        ","
  40.    (rtos (distance spt ept)) ","
  41.        (angtos  (angle spt ept))
  42.        )                    
  43.        (car lst)
  44.    )
  45. )
  46.    (princ)
回复

使用道具 举报

106

主题

1万

帖子

101

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1299
发表于 2022-7-5 16:45:48 | 显示全部楼层
ktbjx无意冒犯,但是你面前有所有的答案,试着去做,你有pt1 xyz pt2 xzy,3d mid pt只是简单的数学MidX=(pt1x+pt2x)/2等等。
 
大提示
spt(cdr(assoc 10 e))
ept(cdr(assoc 11 e))
进一步研究
x=汽车y=cadr z=caddr
回复

使用道具 举报

5

主题

956

帖子

963

银币

初来乍到

Rank: 1

铜币
35
发表于 2022-7-5 17:06:12 | 显示全部楼层
*仅直线不包括圆弧、点等。。
  1. (defun foo (e)
  2. (vlax-curve-getPointAtParam e (/ (vlax-curve-getEndParam e) 2.)))

WCS
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-13 21:01 , Processed in 0.735683 second(s), 69 queries .

© 2020-2025 乐筑天下

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