几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量  


返回   几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量 » 仿射空间:CAX软件开发(三)二次开发与程序设计 » CAD二次开发 » AutoCAD二次开发 » ObjectARX(AutoLISP)
用户名
密码
注册 帮助 会员 日历 银行 搜索 今日新帖 标记论坛为已读


回复
 
主题工具 搜索本主题 显示模式
旧 2009-04-27, 01:27 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 请问,椭球程序错在哪里?

请问,椭球程序错在哪里?
www.dimcax.com
请问,椭球程序错在哪里?
图片:

;椭球
(defun c:tq()
(setq pt0 (getpoint "请输入基点: "))
(setq a (getreal "请输入长轴半径a: "))
(setq b (getreal "请输入短轴半径b: "))
(setq c (getreal "请输入纵轴半径c: "))
(setq ang -90)
(while (<= ang 90)
(setq ang1(/ (* pi ang) 180))
(setq a1 (+ (car pt0) (* a (cos ang1) )) )
(setq pt0y (cadr pt0))
(setq c0 (+ (caddr pt0)(* c (sin ang1) )) )
(setq b1 (* b (cos ang1)) )
(setq ang (+ 1 ang))
(setq pt1 (list -a1 pt0y c0))
(setq pt2 (list a1 pt0y c0))
(command "ellipse" pt1 pt2 b1)
)
)

看看标点符号之类的

图片:

错在ang改成-89就对了.
(defun c:tq()
(setq pt0 (getpoint "请输入基点: "))
(setq a (getreal "请输入长轴半径x方向a: "))
(setq b (getreal "请输入短轴半径y方向b: "))
(setq c (getreal "请输入纵轴半径z方向c: "))
(setq ang -89) ;错在-90 应为-89
(while (<= ang 89)
(setq ang1 (/ (* pi ang) 180))
(setq a1 (+ (car pt0) (* a (cos ang1) )) )
(setq pt0y (cadr pt0))
(setq c0 (+ (caddr pt0)(* c (sin ang1) )) )
(setq b1 (* b (cos ang1)) )
(setq ang (+ 1 ang))
(setq pt1 (list (* a1 -1.0) pt0y c0)) ;错-a1 应为(* a1 -1.0)
(setq pt2 (list a1 pt0y c0))
(command "ellipse" pt1 pt2 b1)
)
)
gbg

谢谢老顾了,我刚开始学习lisp,掌握的知识很少的,感谢你的讲解!
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
回复


主题工具 搜索本主题
搜索本主题:

高级搜索
显示模式

发帖规则
不可以发表新主题
不可以回复主题
不可以上传附件
不可以编辑您的帖子

vB 代码开启
[IMG]代码开启
HTML代码关闭



所有的时间均为北京时间。 现在的时间是 02:33 AM.


于2004年创办,几何尺寸与公差论坛"致力于产品几何量公差标准GD&T | GPS研究/CAD设计/CAM加工/CMM测量"。免责声明:论坛严禁发布色情反动言论及有关违反国家法律法规内容!情节严重者提供其IP,并配合相关部门进行严厉查处,若內容有涉及侵权,请立即联系我们QQ:44671734。注:此论坛须管理员验证方可发帖。
沪ICP备06057009号-2
更多