找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 449|回复: 2

[求助] [求助]:请帮我看看我的程序错误在那里(谢谢)

[复制链接]
发表于 2004-6-12 10:05:05 | 显示全部楼层 |阅读模式

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

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

×
我编的程序是在选择的边界内部间隔10米的点画。思想是在选择边界后再拾取一内部点,在内部点的基础上用一个二重循环把X和Y坐标累加累减得到点,其中,用一个网友提供的测试点在边界内部的函数来控制循环的终止(在此感谢网友们的无私奉献)。我的程序不能运行使用。我不知道错误出在那里。请帮忙看看问题所在



谢谢网友们的帮忙。程序能运行了,但还有一个问题。就是画的圆为什么总有一个出边界。我怎么也找不到那里出了问题。请大家帮我改正。


  1. (defun c:tc (/           plendpt     x_lst       e         op
  2.          n           fst_pt     int_num   online    pc
  3.          pn           min_num     edge_int_num         pt_online_num
  4.          op1
  5.         )
  6.   (defun zn ()
  7.     (setq min_num 0.0001)
  8.     (princ "\n选择边界:")
  9.     (while (not e) (setq e (car (entsel))))
  10.     (if    (= "LWPOLYLINE" (cdr (assoc 0 (entget e))))
  11.       (progn
  12.     (redraw e 3)
  13.     (while (not op) (setq op (getpoint "\n请拾取边界内部点:")))
  14.     (foreach n (entget e)
  15.       (if (= 10 (car n))
  16.         (if    plendpt
  17.           (setq plendpt (append plendpt (list (cdr n))))
  18.           (setq plendpt (list (cdr n)))
  19.         )
  20.       )
  21.     )
  22.     (setq X_lst (mapcar '(lambda (x) (car x)) plendpt))
  23.     (setq delta_X (abs (- (apply 'max x_lst) (car op))))
  24.     (setq plendpt        (append plendpt (list (nth 0 plendpt)))
  25.           edge_int_num  0
  26.           pt_online_num 0
  27.           online        nil
  28.     )
  29.     (while (> (length plendpt) 1)
  30.       (setq    pc (nth 0 plendpt)
  31.         pn (nth 1 plendpt)
  32.       )
  33.       (setq op1 (polar op 0 (* delta_x 2)))
  34.       (if (inters op
  35.               op1
  36.               pc
  37.               pn
  38.           )

  39.         (setq edge_int_num (+ 1 edge_int_num))
  40.       )
  41.       (if (equal (+ (distance op pc) (distance pc op1))
  42.              (distance op op1)
  43.              min_num
  44.           )
  45.         (setq pt_online_num (+ 1 pt_online_num))
  46.       )

  47.       (if (equal (+ (distance op pc) (distance op pn))
  48.              (distance pc pn)
  49.              min_num
  50.           )
  51.         (setq online "t")
  52.       )
  53.       (setq plendpt (cdr plendpt))
  54.     )
  55.     (redraw e 4)
  56.       )
  57.     )
  58.   )

  59.   (zn)
  60.   (setq p0 op)
  61.   (setq p1 op)
  62.   (setq p2 op)
  63.   (setq p3 op)
  64.   (setq p4 op)
  65.   (setq p5 op)
  66.   (setq p6 op)
  67.   (setq p7 op)
  68.    
  69.    
  70.   (zn)
  71.    (setq op p3)
  72.   (zn)
  73.    (while (and (= (rem (+ pt_online_num edge_int_num) 2) 1)
  74.           (not online) )
  75.    
  76.         (while (and (= (rem (+ pt_online_num edge_int_num) 2) 1)
  77.           (not online) )
  78.           (command "circle" op 1 "")
  79.          
  80.           (setq op (polar op pi 10) )
  81.        
  82.           (zn)
  83.               )
  84.           (command "circle" op 1 "")
  85.           (setq op p4)
  86.           (setq op (polar op (/ pi 2) 10))
  87.           (setq p4 op)
  88.           (zn)
  89.     )
  90.   
  91.    (zn)
  92.    (setq op p2)
  93.   (zn)
  94.    (while (and (= (rem (+ pt_online_num edge_int_num) 2) 1)
  95.           (not online) )
  96.    
  97.         (while (and (= (rem (+ pt_online_num edge_int_num) 2) 1)
  98.           (not online) )
  99.           (command "circle" op 1 "")
  100.          
  101.           (setq op (polar op 0 10) )
  102.        
  103.           (zn)
  104.               )
  105.           (command "circle" op 1 "")
  106.           (setq op p1)
  107.           (setq op (polar op (/ (* pi 3) 2) 10))
  108.           (setq p1 op)
  109.           (zn)
  110.     )
  111.    
  112.   
  113.   (zn)
  114.    (setq op p7)
  115.   (zn)
  116.    (while (and (= (rem (+ pt_online_num edge_int_num) 2) 1)
  117.           (not online) )
  118.    
  119.         (while (and (= (rem (+ pt_online_num edge_int_num) 2) 1)
  120.           (not online) )
  121.           (command "circle" op 1 "")
  122.          
  123.           (setq op (polar op pi 10) )
  124.        
  125.           (zn)
  126.               )
  127.           (command "circle" op 1 "")
  128.           (setq op p5)
  129.           (setq op (polar op (/ (* pi 3) 2) 10))
  130.           (setq p5 op)
  131.           (zn)
  132.     )
  133.   (zn)
  134.    (setq op p6)
  135.   (zn)
  136. (while (and (= (rem (+ pt_online_num edge_int_num) 2) 1)
  137.           (not online) )
  138.    
  139.         (while (and (= (rem (+ pt_online_num edge_int_num) 2) 1)
  140.           (not online) )
  141.           (command "circle" op 1 "")
  142.          
  143.           (setq op (polar op 0 10) )
  144.        
  145.           (zn)
  146.               )
  147.           (command "circle" op 1 "")
  148.           (setq op p0)
  149.           (setq op (polar op (/ pi 2) 10))
  150.           (setq p0 op)
  151.           (zn)
  152.     )
  153.   
  154.   
  155. )

斑竹技巧提示:发代码请使用代码段:
[code]
你的代码
....
[/code]
注意:以上方括号应为半角符号!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2004-6-13 16:17:00 | 显示全部楼层
建议楼上的朋友用CAD自带的VLISP编译器进行逐步或设断点编译
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-6-13 22:20:49 | 显示全部楼层
多了一句画圆语句,修改如下:
多说一句:你的程序看起来很累。建议整理一下思路,把程序的结构重整一下。程序大的流程要清晰,这个程序子程序的功能应该是判断点是否在曲线内,却包含了选择边界这些语句,而最终的判断又没有全部在子程序完成,有点混乱且效率不高。结构不清楚的程序调试和升级都很不方便。

  1.   [FONT=courier new]
  2. (defun c:tc (/               plendpt         x_lst           e             op
  3.              n               fst_pt         int_num   online    pc
  4.              pn               min_num         edge_int_num             pt_online_num
  5.              op1
  6.             )
  7.   
  8.   (defun zn ()
  9.     (setq min_num 0.0001)
  10.     (princ "\n选择边界:")
  11.     (while (not e) (setq e (car (entsel))))
  12.     (if        (= "LWPOLYLINE" (cdr (assoc 0 (entget e))))
  13.       (progn
  14.         (redraw e 3)
  15.         (while (not op) (setq op (getpoint "\n请拾取边界内部点:")))
  16.         (foreach n (entget e)
  17.           (if (= 10 (car n))
  18.             (if        plendpt
  19.               (setq plendpt (append plendpt (list (cdr n))))
  20.               (setq plendpt (list (cdr n)))
  21.             )
  22.           )
  23.         )
  24.         (setq X_lst (mapcar '(lambda (x) (car x)) plendpt))
  25.         (setq delta_X (abs (- (apply 'max x_lst) (car op))))
  26.         (setq plendpt            (append plendpt (list (nth 0 plendpt)))
  27.               edge_int_num  0
  28.               pt_online_num 0
  29.               online            nil
  30.         )
  31.        
  32.         (while (> (length plendpt) 1)
  33.           (setq        pc (nth 0 plendpt)
  34.                 pn (nth 1 plendpt)
  35.           )
  36.           (setq op1 (polar op 0 (* delta_x 2)))
  37.           (if (inters op
  38.                       op1
  39.                       pc
  40.                       pn
  41.               )

  42.             (setq edge_int_num (+ 1 edge_int_num))
  43.           )
  44.           (if (equal (+ (distance op pc) (distance pc op1))
  45.                      (distance op op1)
  46.                      min_num
  47.               )
  48.             (setq pt_online_num (+ 1 pt_online_num))
  49.           )

  50.           (if (equal (+ (distance op pc) (distance op pn))
  51.                      (distance pc pn)
  52.                      min_num
  53.               )
  54.             (setq online "t")
  55.           )
  56.           (setq plendpt (cdr plendpt))
  57.         ) ;while
  58.        
  59.         (redraw e 4)
  60.       )
  61.     )
  62.   )   ;;;;zn
  63.   

  64. ;;;  main
  65.   
  66.   (zn)
  67.   (setq p0 op)
  68.   (setq p1 op)
  69.   (setq p2 op)
  70.   (setq p3 op)
  71.   (setq p4 op)
  72.   (setq p5 op)
  73.   (setq p6 op)
  74.   (setq p7 op)


  75.   (zn)
  76.   (setq op p3)
  77.   (zn)
  78.   (while (and (= (rem (+ pt_online_num edge_int_num) 2) 1)
  79.               (not online)
  80.          )

  81.     (while (and        (= (rem (+ pt_online_num edge_int_num) 2) 1)
  82.                 (not online)
  83.            )
  84.       (command "circle" op 1 "")

  85.       (setq op (polar op pi 10))

  86.       (zn)
  87.     )
  88. ;;;    (command "circle" op 1 "")  就是多了这一句
  89.     (setq op p4)
  90.     (setq op (polar op (/ pi 2) 10))
  91.     (setq p4 op)
  92.     (zn)
  93.   )

  94.   (zn)
  95.   (setq op p2)
  96.   (zn)
  97.   (while (and (= (rem (+ pt_online_num edge_int_num) 2) 1)
  98.               (not online)
  99.          )

  100.     (while (and        (= (rem (+ pt_online_num edge_int_num) 2) 1)
  101.                 (not online)
  102.            )
  103.       (command "circle" op 1 "")

  104.       (setq op (polar op 0 10))

  105.       (zn)
  106.     )
  107. ;;;    (command "circle" op 1 "")
  108.     (setq op p1)
  109.     (setq op (polar op (/ (* pi 3) 2) 10))
  110.     (setq p1 op)
  111.     (zn)
  112.   )


  113.   (zn)
  114.   (setq op p7)
  115.   (zn)
  116.   (while (and (= (rem (+ pt_online_num edge_int_num) 2) 1)
  117.               (not online)
  118.          )

  119.     (while (and        (= (rem (+ pt_online_num edge_int_num) 2) 1)
  120.                 (not online)
  121.            )
  122.       (command "circle" op 1 "")

  123.       (setq op (polar op pi 10))

  124.       (zn)
  125.     )
  126. ;;;    (command "circle" op 1 "")
  127.     (setq op p5)
  128.     (setq op (polar op (/ (* pi 3) 2) 10))
  129.     (setq p5 op)
  130.     (zn)
  131.   )
  132.   (zn)
  133.   (setq op p6)
  134.   (zn)
  135.   (while (and (= (rem (+ pt_online_num edge_int_num) 2) 1)
  136.               (not online)
  137.          )

  138.     (while (and        (= (rem (+ pt_online_num edge_int_num) 2) 1)
  139.                 (not online)
  140.            )
  141.       (command "circle" op 1 "")

  142.       (setq op (polar op 0 10))

  143.       (zn)
  144.     )
  145. ;;;    (command "circle" op 1 "")
  146.     (setq op p0)
  147.     (setq op (polar op (/ pi 2) 10))
  148.     (setq p0 op)
  149.     (zn)
  150.   )


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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-24 01:49 , Processed in 0.313139 second(s), 35 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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