找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1041|回复: 7

[LISP程序]:如何用程序获得多义线圆弧段的半径?

[复制链接]
发表于 2006-9-10 07:46:53 | 显示全部楼层 |阅读模式

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

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

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

已领礼包: 7225个

财富等级: 富甲天下

发表于 2006-9-10 08:39:28 | 显示全部楼层
  1. ;;; SEG2CIR - converts a bulged segment (bulge pt1 pt2) of a polyline
  2. ;;;   to a circle (ctr rad), the start- and endpoints are known
  3. ;;;   therefore the angles too: (angle ctr pt1)(angle ctr pt2)
  4. ;;; returns nil on a straight segment!
  5. ;;; (bugfixed version. Thanks to Sergei Komarov)
  6. (defun seg2cir (seg / bulge p1 p2 cot x y rad dummy)
  7.   (if (zerop (car seg)) ;_straight line => invalid circle
  8.     nil
  9.     (setq bulge        (car seg)
  10.           p1        (cadr seg)
  11.           p2        (caddr seg)
  12.           cot        (* 0.5 (- (/ 1.0 bulge) bulge))
  13.           x        (/ (- (+ (car p1) (car p2))
  14.                       (* (- (cadr p2) (cadr p1)) cot)
  15.                    )
  16.                    2.0
  17.                 )
  18.           y        (/ (+ (+ (cadr p1) (cadr p2))
  19.                       (* (- (car p2) (car p1)) cot)
  20.                    )
  21.                    2.0
  22.                 )
  23.           rad        (distance (list (car p1) (cadr p1)) (list x y))
  24.           dummy        (list (list x y) rad)
  25.     )
  26.   )
  27. ) ;_return this, I hate progn's

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

使用道具 举报

已领礼包: 6个

财富等级: 恭喜发财

发表于 2006-9-10 08:43:25 | 显示全部楼层
供参考:
1法:nentsel
2法:标半径,取值,删标注
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 593个

财富等级: 财运亨通

发表于 2006-9-10 09:47:09 | 显示全部楼层
对 Bulge 非 0 的点求 vlax-curve-getsecondderiv ,'(0. 0.) 与其 Distance 即为 Rad
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-9-10 10:01:49 | 显示全部楼层
最初由 Underway 发布
[B][code];;; SEG2CIR - converts a bulged segment (bulge pt1 pt2) of a polyline
;;;   to a circle (ctr rad), the start- and endpoints are known
;;;   therefore the angles too: (angle ctr pt1)(angle ct... [/B]

请教 seg  是带入哪个值呢?
图元吗?还是其他...
烦请可以来各范例说明一下
谢谢
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2006-9-11 16:27:22 | 显示全部楼层
;10/09/06
(defun arcsofpline (pline / pts n dis r rs j)
  (setq pts (acet-geom-vertex-list pline))
  (setq n 0)
  (foreach j (vl-remove-if '(lambda (x)(/= (car x) 42))(entget pline))
    (if (and (= (car j) 42)(/= (cdr j) 0))
      (setq dis (distance (nth n pts)(nth (1+ n) pts))
              r (/ dis 2 (sin (* 2 (atan (cdr j)))))
             rs (append rs (list (rtos r 2 2))))
    );if
    (setq n (1+ n))
  );f
  rs
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 7225个

财富等级: 富甲天下

发表于 2006-9-11 17:32:06 | 显示全部楼层
(setq bulge        (car seg)
          p1        (cadr seg)
          p2        (caddr seg)
---snip

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

使用道具 举报

发表于 2007-4-27 00:25:34 | 显示全部楼层
最初由 eachy 发布
[B]对 Bulge 非 0 的点求 vlax-curve-getsecondderiv ,'(0. 0.) 与其 Distance 即为 Rad [/B]


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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-15 14:08 , Processed in 0.191870 second(s), 45 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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