找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1434|回复: 4

[有奖答题] 大家写下从多段线的弧段信息获得圆弧的参数

[复制链接]

已领礼包: 145个

财富等级: 日进斗金

发表于 2013-6-10 20:23:39 | 显示全部楼层 |阅读模式

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

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

×
XDRX_API有个函数

QQ截图20130610202219.png

大家试试用LISP写写。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2013-6-11 01:56:46 | 显示全部楼层
简单测试了一下是对的,是否满足所有条件请大家测试
[pcode=lisp,true](defun xdrx_polytoarc (start_pt bulge end_pt / mid_pt v dis h d m cen start_ang end_ang)
  (setq mid_pt (mapcar
                 '(lambda (x)
                    (/ x 2)
                  )
                 (mapcar
                   '+
                   start_pt
                   end_pt
                 )
               )                       ; 弦中心
        v (mapcar
            '-
            end_pt
            start_pt
          )
  )
  (if (< bulge 0)
    (setq v v)
    (setq v (mapcar
              '-
              v
            )
    )
  )
  (setq dis (sqrt (apply
                    '+
                    (mapcar
                      '(lambda (x)
                         (* x x)
                       )
                      v
                    )
                  )
            )                               ; 弦长
        h (/ (* (abs bulge) dis) 2)    ; 矢高
        d (/ (+ h (/ (* dis dis) 4 h)) 2) ; 半径
        m (mapcar
            '(lambda (x)
               (* (/ (- d h) dis) x)
             )
            v
          )
        cen (list (+ (car mid_pt) (cadr m)) (- (cadr mid_pt) (car m)))
        v (mapcar
            '-
            start_pt
            cen
          )
        start_ang (atan (cadr v) (car v))
        v (mapcar
            '-
            end_pt
            cen
          )
        end_ang (atan (cadr v) (car v))
  )
  (if (< bulge 0)
    (list nil cen d end_ang start_ang)
    (list t cen d start_ang end_ang)
  )
)
[/pcode]

评分

参与人数 1D豆 +10 收起 理由
XDSoft + 10 很给力!

查看全部评分

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

使用道具 举报

发表于 2013-6-11 11:17:43 | 显示全部楼层
  1. (defun xdrx_polytoarc ( p1  bulg  p2 / ang cen rad )
  2.   (setq ang (* 2.0 (atan bulg))
  3.         rad (/ (distance p1 p2) (* 2.0 (sin ang)))
  4.         cen (polar p1 (+ (- (/ pi 2.) ang) (angle p1 p2)) rad)
  5.   )
  6.   (if (minusp bulg)
  7.     (list nil cen (abs rad) (angle cen p2) (angle cen p1) )
  8.     (list t cen (abs rad) (angle cen p1) (angle cen p2) )
  9.   )
  10. )

点评

楼上朋友,如果测试没问题,用函数发布 发布下吧。谢谢! 贴内做个图片说明下最好了。  详情 回复 发表于 2013-6-11 11:26

评分

参与人数 1D豆 +10 收起 理由
XDSoft + 10 很给力!经验;技术要点;资料分享奖!

查看全部评分

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

使用道具 举报

已领礼包: 145个

财富等级: 日进斗金

 楼主| 发表于 2013-6-11 11:26:15 | 显示全部楼层

楼上朋友,如果测试没问题,用函数发布 发布下吧。谢谢! 贴内做个图片说明下最好了。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 3884个

财富等级: 富可敌国

发表于 2013-6-11 12:09:24 | 显示全部楼层
  1. (defun xdex_PolyToArc (sPt Bg ePt / L H R sePt cPt)
  2.   (if
  3.     (cond
  4.       ((equal Bg 0 0.00001) nil)
  5.       ((< Bg 0)
  6.        (setq Tor nil
  7.              Bg         (abs Bg)
  8.        )
  9.       )
  10.       ((> Bg 0) (setq Tor t))
  11.       (t nil)
  12.     )
  13.     (progn
  14.       (if (> Bg 1)
  15.         (setq Bg (/ 1.0 Bg))
  16.       )
  17.       (setq L    (* (distance sPt ePt) 0.5)
  18.             H    (* L Bg)
  19.             R    (* (+ (/ L Bg) H) 0.5)
  20.             sePt (mapcar '* (mapcar '+ sPt ePt) '(0.5 0.5 0.5))
  21.       )
  22.       (if Tor
  23.         (setq cPt (polar sePt (+ (angle sPt ePt) (* pi 0.5)) (- R H)))
  24.         (setq cPt (polar sePt (- (angle sPt ePt) (* pi 0.5)) (- R H)))
  25.       )
  26.       (list Tor cPt R (angle cPt sPt) (angle cPt ePt))
  27.     )
  28.   )
  29. )

评分

参与人数 1D豆 +10 收起 理由
XDSoft + 10 很给力!经验;技术要点;资料分享奖!

查看全部评分

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-15 18:44 , Processed in 0.260218 second(s), 42 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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