设为首页收藏本站

晓东CAD家园-论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 5588|回复: 68

[矩形] 统计矩形的长度,高度,数量,总长,面积并制表

  [复制链接]

已领礼包: 40个

财富等级: 招财进宝

发表于 2017-6-17 18:23:44 | 显示全部楼层 |阅读模式
  • 插件名称 : 矩形统计
  • 作  者 : Newer
  • 运行环境 :XDRX API 晓东工具箱 
  • 发布时间 :2017-06-17
  • 命令名称 :XDTB_TJRec
  • 插件介绍 :统计矩形的长度,高度,数量,总长,面积并制表
  • 备  注 : (点击图片可以放大)
(点击图片可以放大)

晓东温馨提示 1、运行环境为 晓东工具箱XDRX API 的插件,请下载最新版本的 晓东工具箱XDRX API开发环境 一键安装
2、在ACAD中如何加载插件,请看 论坛插件使用方法
3、如果您有要求需要定制插件,请到 编程申请 论坛发帖求助

插件详细内容

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

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

x
本帖最后由 newer 于 2017-6-17 18:25 编辑

[sell=5]
  1. (defun c:XDTB_TJRec (/ ar ar1 data e i key l l1 l2 len len1 lst num nums p1
  2.                        p2 p3 pt pts scl ss tb tlen txth val w x y
  3.                     )
  4.   (defun _process (e)
  5.     (if (XD::Polyline:IsRectang e)
  6.       (progn
  7.         (setq pts (xdrx_getpropertyvalue e "vertices")
  8.               p1 (car pts)
  9.               p2 (cadr pts)
  10.               p3 (caddr pts)
  11.               l1 (distance p1 p2)
  12.               l2 (distance p2 p3)
  13.               l (list l1 l2)
  14.               l (vl-sort l '(lambda (x y)
  15.                               (> x y)
  16.                             )
  17.                 )
  18.         )
  19.         (list (rtos (car l) 2 #xd_var_rectang_tol) (rtos (cadr l) 2 #xd_var_rectang_tol))
  20.       )
  21.     )
  22.   )
  23.   (defun _keyword (key)
  24.     (cond
  25.       ((= key "D")
  26.         (if (setq val (getint (xdrx_prompt "\n保留小数位数<"
  27.                                            #xd_var_rectang_tol ">:" t
  28.                               )
  29.                       )
  30.             )
  31.           (setq #xd_var_rectang_tol val)
  32.         )
  33.       )
  34.       ((= key "E")
  35.         (if (setq val (getreal (xdrx_prompt "\n表格字高<"
  36.                                             #xd_var_rectang_txtheight ">:" t
  37.                                )
  38.                       )
  39.             )
  40.           (setq #xd_var_rectang_txtheight val)
  41.         )
  42.       )
  43.     )
  44.     (_prompt)
  45.   )
  46.   (defun _prompt ()
  47.     (xdrx_prompt "\n当前设置: 字高(" #xd_var_rectang_txtheight
  48.                  ") / 小数位数(" #xd_var_rectang_tol ")"
  49.     )
  50.   )
  51.   (xdrx_begin)
  52.   (xdrx_sysvar_push '("dimzin" 0))
  53.   (if (not #xd_var_rectang_tol)
  54.     (setq #xd_var_rectang_tol 1)
  55.   )
  56.   (if (not #xd_var_rectang_txtheight)
  57.     (setq #xd_var_rectang_txtheight 3.5)
  58.   )
  59.   (_prompt)
  60.   (if (and
  61.         (xdrx_initget "D E")
  62.         (xdrx_initssget "\n选取要统计的矩形[字高(E)/小数位(D)]<退出>:" "D E"
  63.                         "" "_keyword"
  64.         )
  65.         (setq ss (xdrx_ssget '((0 . "*POLYLINE") (-4 . "&=")
  66.                               (70 . 1)
  67.                              )
  68.                  )
  69.         )
  70.       )
  71.     (progn
  72.       (setq data nil
  73.             i 0
  74.       )
  75.       (mapcar
  76.         '(lambda (x)
  77.            (if (setq lst (_process x))
  78.              (setq lst (cons (apply
  79.                                'strcat
  80.                                lst
  81.                              ) lst
  82.                        )
  83.                    data (cons lst data)
  84.              )
  85.            )
  86.          )
  87.         (xdrx_pickset->ents ss)
  88.       )
  89.       (setq data (xd::list:groupbyindex data 0.1)
  90.             data (vl-sort data '(lambda (x y)
  91.                                   (< (car x) (car y))
  92.                                 )
  93.                  )
  94.             i 0
  95.             tlen 0.0
  96.             nums 0
  97.             ar 0.0
  98.             data (mapcar
  99.                    '(lambda (x)
  100.                       (setq val (list (itoa (setq i (1+ i))) (setq l
  101.                                                                    (caadr x)
  102.                                                              )
  103.                                       (setq w (cadadr x))
  104.                                       (setq num (itoa (length (cdr x))))
  105.                                       (setq len (* (atoi num) (* 2
  106.                                                                  (+
  107.                                                                     (atof l)
  108.                                                                     (atof w)
  109.                                                                  )
  110.                                                               )
  111.                                                 )
  112.                                             ar1 (* (atoi num) (*
  113.                                                                  (atof l)
  114.                                                                  (atof w)
  115.                                                               )
  116.                                                 )
  117.                                             nums (+ nums (atoi num))
  118.                                             len1 (rtos len 2
  119.                                                        #xd_var_rectang_tol
  120.                                                  )
  121.                                       )
  122.                                       (rtos ar1 2 #xd_var_rectang_tol)
  123.                                 )
  124.                       )
  125.                       (setq tlen (+ len tlen)
  126.                             ar (+ ar1 ar)
  127.                       )
  128.                       val
  129.                     )
  130.                    data
  131.                  )
  132.             data (cons (list "编 号" "长 度" "高 度" "数 量" "总 长" "面 积")
  133.                        data
  134.                  )
  135.             data (cons (list "矩形统计表" nil nil nil nil nil) data)
  136.             data (append
  137.                    data
  138.                    (list (list "合 计" nil "" (itoa nums) (rtos tlen 2 #xd_var_rectang_tol)
  139.                                (rtos ar 2 #xd_var_rectang_tol)
  140.                          )
  141.                    )
  142.                  )
  143.       )
  144.       (if (setq pt (getpoint "\n表格插入点<退出>:"))
  145.         (progn
  146.           (xd::text:init 1)
  147.           (setq scl (* (xd::var:getratio) (XD::Var:GetScaleRatio))
  148.                 txth (* scl #xd_var_rectang_txtheight)
  149.           )
  150.           (setq tb (xd::table:makefromlist data pt txth (/ txth 3.0)))
  151.         )
  152.       )
  153.     )
  154.   )
  155.   (xdrx_sysvar_pop)
  156.   (xdrx_end)
  157.   (princ)
  158. )

[/sell]

评分

参与人数 1D豆 +5 收起 理由
yufeng37 + 5 很给力!经验;技术要点;资料分享奖!

查看全部评分

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

已领礼包: 39个

财富等级: 招财进宝

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

使用道具 举报

已领礼包: 41个

财富等级: 招财进宝

发表于 2017-6-17 23:48:16 来自手机 | 显示全部楼层
顶版主,汇总使用更广泛了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 5961个

财富等级: 富甲天下

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

使用道具 举报

已领礼包: 1304个

财富等级: 财源广进

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

使用道具 举报

已领礼包: 2100个

财富等级: 金玉满堂

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

使用道具 举报

已领礼包: 41个

财富等级: 招财进宝

发表于 2017-6-18 17:53:59 | 显示全部楼层

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

使用道具 举报

已领礼包: 733个

财富等级: 财运亨通

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

使用道具 举报

已领礼包: 1个

财富等级: 恭喜发财

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

使用道具 举报

已领礼包: 96个

财富等级: 招财进宝

发表于 2017-6-27 10:55:03 | 显示全部楼层
看看再说话。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

使用道具 举报

已领礼包: 349个

财富等级: 日进斗金

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

使用道具 举报

发表于 2017-8-10 15:13:46 | 显示全部楼层
有光文字统计的插件
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2017-8-10 15:16:16 | 显示全部楼层
好东西,就是运行环境局限性了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2021-3-9 18:07 , Processed in 0.206993 second(s), 50 queries , Gzip On, WinCache On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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