明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1255|回复: 5

[讨论] 合力位置定位

  [复制链接]
发表于 2014-7-24 12:55 | 显示全部楼层 |阅读模式
求助:自己编了一个小程序,就是根据各个力的作用点求出他们合力的作用点,但是编写while循环的时候出现了小问题,就是不晓得怎么退出while循环,请高人指点

(setvar "cmdecho" 0)                       
(if (= (tblsearch "layer" "合力点") nil)                       
(command "-layer" "m" "合力点" "c" "3" "" "")                       
)                       
(setvar "clayer" "合力点")                       
(setq        pi90        (/ pi 2)        )
(setq        pi270        (* 3 (/ pi 2))        )
(setq        txt_li        '())       
                       
(setq p1 (getpoint "选取点位置:"))                        
(while t                       
(setq xx1 (car p1))                        
(setq yy1 (cadr p1))                        
(setq sstext1 (car (entsel "\n选择文本:")))                       
(setq N1        (atof (cdr (assoc 1 (entget sstext1)))))               
(setq Mx1        (* N1 yy1))               
(setq My1        (* N1 xx1))               
(setq        aa1        (list N1 Mx1 My1))       
(setq        txt_li        (cons aa1 txt_li))       
(setq p1 (getpoint "选取点位置:"))                        
) ;_ 结束while                       
(setq        nn        (vl-list-length txt_li))       
                       
;;存储力矩                       
(setq        sum_li        '())       
(setq j 0)                       
   (repeat 3                       
(setq sum_j 0)                       
(setq i 0)                       
   (repeat nn                       
(setq        list_i        (nth i txt_li))       
(setq        list_i_j        (nth j list_i))       
(setq        sum_j        (+ sum_j list_i_j))       
(setq i (1+ i))                       
)                       
(setq        sum_li        (cons sum_j sum_li))       
(setq j (1+ j))                       
)                       
(setq        My1_sum        (nth 0 sum_li))       
(setq        Mx1_sum        (nth 1 sum_li))       
(setq        N1_sum        (nth 2 sum_li))       
(setq        node_x        (/ My1_sum  N1_sum ))       
(setq        node_y        (/ Mx1_sum  N1_sum ))       
(setq        node_xy        (list node_x  node_y))       
                       
;;画中心点                       
(setq        p1        (polar node_xy pi 250))       
(setq        p2        (polar node_xy 0 250))       
(setq        p3        (polar node_xy pi90 250))       
(setq        p4        (polar node_xy pi270 250))       
(command "line" p1 p2 "")                       
(command "line" p3 p4 "")                       

点评

一个一个的选,太累!  发表于 2014-7-26 13:06
 楼主| 发表于 2014-7-24 13:01 | 显示全部楼层
这是测试的dwg文件

本帖子中包含更多资源

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

x

点评

实在看不懂  发表于 2014-7-24 23:32
发表于 2014-7-24 18:26 | 显示全部楼层
(while T ....)
这是无限循环的架势

(setq loop T)
(while loop
    ...
    (if (...)
       (setq loop nil)
    )
)
这样才可以退出循环
发表于 2014-7-24 20:00 | 显示全部楼层
  1. (while t

换成
  1. (while (and (setq p1 (getpoint "选取点位置:"))
  2. (setq sstext1 (car (entsel "\n选择文本:"))))
  3. 即可
  4. 第一个(setq p1 (getpoint "选取点位置:"))和最后一个 (setq p1 (getpoint "选取点位置:"))去掉
  5. (setq sstext1 (car (entsel "\n选择文本:"))) 去掉

评分

参与人数 1明经币 +1 收起 理由
lucas_3333 + 1 赞一个!

查看全部评分

 楼主| 发表于 2014-7-25 23:27 | 显示全部楼层
edata 发表于 2014-7-24 20:00
换成

可以了,有些逻辑自己百思不得其解,但是一经点拨茅塞顿开,只能说佩服,在此感谢
 楼主| 发表于 2014-7-25 23:29 | 显示全部楼层
masterlong 发表于 2014-7-24 18:26
(while T ....)
这是无限循环的架势

已经解决了,谢谢
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-4-26 15:22 , Processed in 1.183144 second(s), 27 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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