找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 732|回复: 4

[LISP程序]:一个求实体(直线,圆弧,园,椭圆)关键点的小程序

[复制链接]
发表于 2003-4-2 07:48:25 | 显示全部楼层 |阅读模式

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

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

×
一个求实体(直线,圆弧,园,椭圆)关键点的小程序, 请大家试用!
(defun pt (ent / ss pp)     
  (if (= (dxf 0 ent) "LINE")
    (setq pt1 (dxf 10 ent) pt2 (dxf 11 ent))
    (progn
      (setq pc (dxf 10 ent) r (dxf 40 ent))
      (cond
        ((= (dxf 0 ent) "ARC")
          (setq pt1 (polar pc (dxf 50 ent) r)
                pt2 (polar pc (dxf 51 ent) r))
          (setq pp (polar pc pi r))
          (setq ss (ssget pp))
          (if (/= ss nil)(setq pt5 pp))
          (setq pp (polar pc 0 r))
          (setq ss (ssget pp))
          (if (/= ss nil)(setq pt6 pp))
            (setq pp (polar pc (* 1.5 pi) r))
          (setq ss (ssget pp))
          (if (/= ss nil)(setq pt3 pp))
          (setq pp (polar pc (/ pi 2) r))
          (setq ss (ssget pp))
          (if (/= ss nil)(setq pt4 pp))
        )
        ((= (dxf 0 ent) "CIRCLE")
          (setq pt1 (polar pc pi r)
                pt2 (polar pc 0 r)
                pt3 (polar pc (* 1.5 pi) r)
                pt4 (polar pc (/ pi 2) r)))
        ((= (dxf 0 ent) "ELLIPSE")
          (setq  px (dxf 11 ent)
                pt1 (polar pc pi (car px))
                pt2 (polar pc 0 (car px))
                pt3 (polar pc (* 1.5 pi)(* r (car px)))
                pt4 (polar pc (/ pi 2)(* r (car px)))))
      );c
    );P
  );i
  (if (or (< (car pt2)(car pt1))
          (and (equal (car pt1)(car pt2) 0.0001)
               (< (cadr pt2)(cadr pt1))))
    (setq pt0 pt1 pt1 pt2 pt2 pt0)
  );if
  (if (= (getvar "worlducs") 0)
    (progn
      (if pt1 (setq pt1 (trans pt1 0 1)))
      (if pt2 (setq pt2 (trans pt2 0 1)))
      (if pt3 (setq pt3 (trans pt3 0 1)))
      (if pt4 (setq pt4 (trans pt4 0 1)))
      (if pc (setq pc (trans pc 0 1)))
   ))
);defun
(defun dxf (code ename)(cdr (assoc code (entget ename))))
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2003-9-18 22:37:29 | 显示全部楼层
用来干什么?怎么用?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

已领礼包: 488个

财富等级: 日进斗金

发表于 2003-9-19 01:09:35 | 显示全部楼层
最初由 xzg_hello 发布
[B]能不能弄个求椭圆焦点的东东 [/B]


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

使用道具 举报

 楼主| 发表于 2003-9-19 08:29:53 | 显示全部楼层
3楼:
椭圆焦点 Try this code:
(defun c:test ()
  (setq ent (car (entsel "\nSelect Ellipse: ")))
  (setq pc (dxf 10 ent))
  (setq px (dxf 11 ent)
        px (list (+ (car pc)(car px))(+ (cadr pc)(cadr px)) 0)
         a  (distance pc px)
         b (* (dxf 40 ent) a)
         c (sqrt (- (* a a)(* b b))))
  (vl-cmdf "point" (polar pc (angle pc px) c)
           "point" (polar pc (angle px pc) c))
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-26 20:45 , Processed in 0.373204 second(s), 38 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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