找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 624|回复: 5

[求助] [求助]:跪求各位大侠帮帮小弟???

[复制链接]
发表于 2004-12-14 19:16:06 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
各位大侠能否帮小弟编一个lisp:
1,可以一下提取n个圆的中心点坐标
2,可以计算这些坐标到一条直线的垂直距离
尽快传给我 不胜感激!!!
顺便问一下选取时只能是方型吗?如何不规则的选取?
再次谢谢大家 辛苦了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 6530个

财富等级: 富甲天下

发表于 2004-12-14 20:33:56 | 显示全部楼层
不知需要什么输出形式,就写到图上吧。
[php]defun mktext (:str :pt10 / :sty)        ;写文字
  (entmake
    (list
      '(0 . "TEXT")
      (cons 1 :str)
      (cons 10 :pt10)
      (cons 11 :pt10)
      (cons 7 (setq :sty (getvar "textstyle")))
      (cons 40 (getvar "textsize"))
      (cons 41 (cdr (assoc 41 (tblsearch "style" :sty))))
      (cons 51 (cdr (assoc 50 (tblsearch "style" :sty))))
      '(71 . 0)
      '(72 . 0)
    )
  )
)

(defun c:test (/ ss li pt10 pt11 ang len i en pt pt1 dis)
  (princ "\n选择需要计算的圆")
  (setq ss (ssget '((0 . "circle"))))
  (if ss
    (setq li (entsel "\n计算目标直线:"))
  )
  (if (and ss
           (= (cdr (assoc 0 (setq li (entget (car li))))) "LINE")
      )
    (progn
      (setq pt10 (cdr (assoc 10 li))
            pt11 (cdr (assoc 11 li))
            ang         (angle pt10 pt11)
            len         (sslength ss)
      )
      (setq i -1)
      (repeat len
        (setq i          (1+ i)
              en  (entget (ssname ss i)) ;圆心
              pt  (cdr (assoc 10 en))
              pt1 (inters pt10 pt11 pt (polar pt (+ ang (/ pi 2)) 1) nil)
              dis (distance pt pt1)        ;距离
        )
        (mktext        (strcat        "圆心:"
                        (rtos (car pt))
                        ","
                        (rtos (cadr pt))
                        ";距离:"
                        (rtos dis)
                )
                pt
        )
      )
    )
  )
  (princ)
)[/php]

另:
多边形选取可以使用“wp”、“cp”选项,栅栏选取可以使用“f”选项。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-12-14 20:45:11 | 显示全部楼层
太感谢了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-12-14 20:55:14 | 显示全部楼层
黄金长老太厉害了,不到一个小时就写好了,无比佩服!!!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-12-14 21:04:20 | 显示全部楼层
试试:
[php]
(defun c:test ()
  (princ "\n选圆 : ")
  (setq        ss (ssget '((0 . "CIRCLE")))
        s2 (entsel "\n选线 : ")
        n  -1
  )
  (setq        pt01 (dxf 10 (entget (car s2)))
        pt02 (dxf 11 (entget (car s2)))
        ang  (+ (angle pt01 pt02) (/ pi 2))
  )
  (while (setq s1 (ssname ss (setq n (+ 1 n))))
    (setq pt1 (dxf 10 (entget s1)))
    (princ "\nR")
    (princ (+ n 1))
    (princ " = ")
    (princ pt1)
    (setq pt2  (polar pt1 ang 100)
          pt3  (inters pt01 pt02 pt1 pt2 nil)
          dist (distance pt1 pt3)
    )
    (grvecs (list 2 pt1 pt3))
    (princ "\n距离")
    (princ (+ n 1))
    (princ " = ")
    (princ dist)
    (princ "\n")
  )
  (princ)
)
(defun dxf (code elist) (cdr (assoc code elist)))
[/php]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-12-14 23:11:34 | 显示全部楼层
2 楼太厉害了,不胜佩服。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-9-21 19:34 , Processed in 0.301436 second(s), 42 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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