明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1813|回复: 7

[讨论] 单向陈列

[复制链接]
发表于 2014-7-10 11:20:17 | 显示全部楼层 |阅读模式
请人帮我加一个记忆功能,谢谢先

本帖子中包含更多资源

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

x
发表于 2014-7-10 14:07:25 | 显示全部楼层
我这有个跟你差不多的,复制次数是有记忆功能的

  1. (defun c:cs ( / cc_st callong cc_corsleft cc_cors  Distcc_key )
  2. (princ "单向阵列")
  3. (setq *error* ss_err)
  4. (SETQ OS (GETVAR "OSMODE"))
  5. (setq cc_get (ssget ))
  6. (setvar "cmdecho" 0 )
  7. (command "undo" "be")
  8. (initget 1)
  9. (setq cc_pt  (getpoint "\n基点:"))
  10. (initget 1 "Big Small Distcc")
  11. (setq cc_cor (getpoint cc_pt  "\n输入距离或[计算距离(D)]:"))
  12. (cond ((= cc_cor "Big")(setq cc_cor(polar cc_pt 0 126.8)))
  13.       ((= cc_cor "Small")(setq cc_cor(polar cc_pt 0 101.4)))
  14.       ((= cc_cor "Distcc")
  15. (progn
  16. (setq Distcc_key 0)
  17. (setq cc_time (getint "\n复制次数:"))
  18. (setq cc_cor  (getpoint cc_pt  "\n选取距离:"))
  19. )))
  20. (if (= Distcc_key 0)
  21. (cs_caldist)
  22. (cs_caltime)
  23. )
  24. (prin1)
  25. )

  26. (defun cs_caldist ( )
  27. (setq alldist(distance cc_pt cc_cor))
  28. (setq eachdist(/ alldist cc_time))
  29. (setq td(mapcar '- cc_cor cc_pt))
  30. (setq eachtd(mapcar '(lambda(n)(/ n  cc_time)) td) )
  31. (setq i 1)

  32. ;(setq cc_cors (mapcar '+ cc_pt (mapcar '(lambda(n)(* 1 n)) eachtd)) )

  33. (repeat cc_time
  34. (setq cc_cors (mapcar '+ cc_pt (mapcar '(lambda(n)(* i n)) eachtd)) )
  35. (ost)
  36. (command "copy" cc_get "" cc_pt  cc_cors ) (ose)
  37. (setq i(1+ i))
  38. ;(setq cc_cors(mapcar '+ cc_cors eachtd))
  39. )(prin1)
  40. )

  41. (defun cs_caltime ( )
  42. (if (/= cc_Ttime nil)(setq cc_Ttime cc_time)
  43. (setq cc_Ttime 1)
  44. )
  45. (setq cc_cors cc_cor)
  46. (mapcar 'princ (list "\n复制次数或[自动计算(C)]<" cc_Ttime ">:" ))
  47. (initget "Cal")
  48. (setq  cc_time (getint ))
  49. (if (= cc_time nil )(setq cc_time cc_Ttime))

  50. (setq cc_corsleft (mapcar '- cc_cor cc_pt))
  51. (if (= cc_time "Cal")
  52. (progn (setq callong(getdist "\n选取总距离:"))
  53. (setq cc_time (fix(/  callong (distance cc_pt cc_cor)))))
  54. )

  55. (setq cc_st 0)
  56. (while (/= cc_st cc_time )
  57. (progn
  58. (SETVAR "OSMODE" 0)
  59. (command "copy" cc_get "" cc_pt  cc_cors )
  60. (SETVAR "OSMODE" OS)
  61. (setq cc_cors (mapcar '+ cc_corsleft cc_cors))
  62. (setq cc_st (+ 1 cc_st)))
  63. )
  64. (command "undo" "e")
  65. (if (numberp cc_time)
  66. (setq cc_Ttime cc_time))
  67. (setvar "cmdecho" 1 )
  68. (prin1)
  69. )

发表于 2014-7-10 15:35:25 | 显示全部楼层
需要“记忆功能”的含义?
 楼主| 发表于 2014-7-10 16:47:01 | 显示全部楼层
xyp1964 发表于 2014-7-10 15:35
需要“记忆功能”的含义?

就是记住上次输入的数置。不用每次都要重新输入一次
发表于 2014-7-10 17:44:20 | 显示全部楼层
谢谢楼主的奉献!
发表于 2014-7-11 00:13:28 | 显示全部楼层
(setq int (Uint 1 "" "整数" int))
(setq dist(Udist 1 "" "距离<输入或鼠标直接量取>" dist nil))
(setq NO1 (UREAL 7 "" "实数" NO1))
(setq ukw (UKWORD 1 "1 2" "1-任意点/2-中心点" ukw))
 楼主| 发表于 2014-7-11 09:04:13 | 显示全部楼层
我只想在原来的里面加而已。有人帮我吗
 楼主| 发表于 2014-7-14 17:07:50 | 显示全部楼层
万能的明经。难道就没人帮忙吗?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-5-24 12:05 , Processed in 0.162242 second(s), 27 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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