找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 961|回复: 2

很久没有写程序了。发个旧程序,stgz=实体规整 by lxx.2009.7

[复制链接]
发表于 2013-3-31 20:19:25 | 显示全部楼层 |阅读模式

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

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

×

  1. ;|stgz=实体规整 by lxx.2009.7|;
  2. (defun c:stgz (/ D E E10 E11 ENT ENTYP FIL FILLST FILSS I IDFIL SS X)
  3.   (vl-load-com)
  4.   (if (not (setq d (getint "\n 四舍五入值(负数为小数点后位数)/<0>")))
  5.     (setq d 0)
  6.   )
  7.   (princ "\n 选择过滤实体类型/<全部类型实体>:")
  8.   (setq idfil '(10 11)) ;; 起点终点圆心.
  9.   (setq        filss (ssget)
  10.         i     -1
  11.   )
  12.   (if filss
  13.     (progn
  14.       (while (setq e (ssname filss (setq i (1+ i))))
  15.         (setq entyp (cdr (assoc 0 (entget e))))
  16.         (if (not (member entyp fillst))
  17.           (setq fillst (cons entyp fillst))
  18.         )
  19.       )
  20.       (setq fil
  21.              (cons 0
  22.                    (vl-string-right-trim
  23.                      ","
  24.                      (apply 'strcat
  25.                             (mapcar '(lambda (x) (strcat x ",")) fillst)
  26.                      )
  27.                    )
  28.              )
  29.       )
  30.     )
  31.   )
  32.   (princ "\n 选择要处理的实体:")
  33.   (setq i -1)
  34.   (if (if fil
  35.         (setq ss (ssget (list fil)))
  36.         (setq ss (ssget))
  37.       )
  38.     (while (setq e (ssname ss (setq i (1+ i))))
  39.       (setq ent (entget e)
  40.             e10 (assoc 10 ent)
  41.             e11 (assoc 11 ent))
  42.       (setq ent (subst (cons 10 (mapcar '(lambda(x)(x-sswr x d))(cdr e10))) e10 ent)
  43.             ent (subst (cons 11 (mapcar '(lambda(x)(x-sswr x d))(cdr e11))) e11 ent))
  44.       (entmod ent)
  45.       )
  46.   )
  47. )

  48. ;| 四舍五入.!!! ok!----by lxx.2006.9
  49. (x-sswr -325.3525 2) ->325.35
  50. (x-sswr 325.3525 -2) -> 300
  51. (x-sswr 325 -1) ->325.353
  52. |;
  53. (defun x-sswr (num n / e r)
  54.   (setq        e   (expt 10. n)
  55.         r   (rem num e)
  56.         num (- num r)
  57.   )
  58.   (if (> r (/ e 2))
  59.     (+ num e)
  60.     num
  61.   )
  62. )

点评

不减当年  发表于 2013-4-2 00:43
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 8976个

财富等级: 富甲天下

发表于 2013-4-3 06:19:03 | 显示全部楼层
感谢 梦断江南 版主分享程序!:lol
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1742个

财富等级: 堆金积玉

发表于 2013-4-3 08:23:28 | 显示全部楼层
{:soso_e179:}不错,感谢分享源码!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-16 06:05 , Processed in 0.380824 second(s), 39 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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