找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 880|回复: 0

以指定弦长旋转复制实体程序

[复制链接]
发表于 2002-1-17 09:44:59 | 显示全部楼层 |阅读模式

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

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

×
;;本程序原为化工塔设备中的塔板固定卡子分布排列而编制。程序编写:  正航
(defun c:copyrt3 (/ p1 p2 ss s a c r ang);;以定弦长复制实体程序
  (setvar "cmdecho" 0)
  (setq bl (getvar "dimlfac"))
  (princ "\n      =========   以弦长旋转复制实体   =======    ")
  (setq s T)
  (setq p1 (getpoint "\n请选择旋转复制实体的形心:"))
  (princ "\n选择需要复制的实体:")
  (setq ss (ssget))
  (setq p2 (getpoint "\n旋转复制的圆心:"))
  (setq r (distance p1 p2))
  (setq c (dos_getreal "弦长输入" "请输入弦长(mm):"));;用DOSLIB的GUI输入界面,仅为美观而已
  (setq c (/ c bl))
  (setq a (* 2 (arcsin (/ c (* r 2)))))
  (setq ang (/ (* a 180.00000) pi))
  (command ".copy" ss "" p2 p2)
  (command ".rotate" ss "" p2 "r" "0" ang)
  (command ".redraw")
  (while s
    (setq c (dos_getreal "弦长输入" "请输入弦长(mm):"))
    (if        (or (= c nil) (= c 0))
      (setq s nil)
      (progn
        (setq c (/ c bl))
        (command ".copy" ss "" p2 p2)
        (command ".rotate" ss "" p2 "r" "0" ang)
        (command ".redraw")
      )
    )
  )
  (command ".redraw")
  (princ)
)

(defun arcsin (r / result)
  (if (and (/= 1 (abs r)) (/= 1.0 (abs r)))
    (setq result (atan (/ r (sqrt (- 1 (* r r))))))
    (cond ((< r 0) (setq result (/ pi -2.0)))
          ((> r 0) (setq result (/ pi 2.0)))
    )
  )
  result
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-4-20 10:49 , Processed in 0.226024 second(s), 31 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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