设为首页收藏本站

晓东CAD家园-论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 760|回复: 7

[填充] 填充图例表(第二版)

[复制链接]

已领礼包: 40个

财富等级: 招财进宝

发表于 2018-7-23 19:24:28 | 显示全部楼层 |阅读模式
  • 插件名称 : 填充图例
  • 作  者 : newer
  • 运行环境 :XDRX API 晓东工具箱 
  • 发布时间 :2018-07-23
  • 命令名称 :XDTB_TJHATULI
  • 插件介绍 :填充图例表(第二版)
  • 备  注 : (点击图片可以放大)
(点击图片可以放大)

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

插件详细内容

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

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

x

根据模式、图层、颜色分类,提取当前图中的填充作成图例表

  1. (defun c:XDTB_TJHATULI (/ blk clr e h ha hascl i lst lyr mode name scl ss x
  2.                           y val info
  3.                        )
  4.   (defun my_err (msg)
  5.     (princ "\n")
  6.     (princ msg)
  7.     (xdrx_end)
  8.     (setq *error* nil)
  9.   )
  10.   (defun _maketuli (clr mode lyr)
  11.     (princ "\nmode=")(princ mode)
  12.     (setq name (xdrx_prompt "XD-TJ-HA-" mode "-" clr t))
  13.     (if (not (setq blk (xdrx_object_get "block" name)))
  14.       (progn
  15.         (setq e (xdrx_polyline_make (xd::pnt:getrecpnts '(0 0 0) (* scl 10.)
  16.                                                         (* 5 scl)
  17.                                     ) t
  18.                 )
  19.         )
  20.         (xdrx_setpropertyvalue e "constantwidth" (* scl 0.3) "color" 7
  21.                                "layer" lyr
  22.         )
  23.         (setq ha (xdrx_hatch_make e))
  24.         (xdrx_setpropertyvalue (xd::pickset:getsub ha '((0 . "HATCH"))) "color" clr "patternname" mode "layer" lyr)
  25.         (xdrx_block_make (strcase name) (list e ha) '(0 0 0.) t)
  26.         (xdrx_entity_delete (entlast))
  27.         (setq blk (xdrx_object_get "block" name))
  28.         (xdrx_draworder->back (setq ha (car (xdrx_block_getentities blk '
  29.                                                                     (
  30.                                                                      (0 . "HATCH")
  31.                                                                     )
  32.                                             )
  33.                                        )
  34.                               )
  35.         )
  36.         (setq hascl (XD::Hatch:GetSclByGap mode (* 1.414 scl)))
  37.         (xdrx_setpropertyvalue ha "PatternScale" hascl "patternname"
  38.                                (list 1 mode)
  39.         )
  40.       )
  41.     )
  42.     blk
  43.   )
  44.   (xdrx_begin)
  45.   (if (not #xd_var_global_hatch_tj_mode)
  46.     (setq #xd_var_global_hatch_tj_mode 2))

  47.   (xdrx_initget "0 1 2")
  48.   (if (setq mode (getint (xdrx_prompt "\n统计模式[图层(0)/颜色(1)/模式(2)]<" #xd_var_global_hatch_tj_mode ">:" t)))
  49.     (setq #xd_var_global_hatch_tj_mode mode))
  50.   (xdrx_initget)
  51.   (setq *error* my_err)
  52.   (if (and (xdrx_initssget "\n选择要统计的填充<退出>:")
  53.            (setq ss (xdrx_ssget  '((0 . "HATCH")))))
  54.     (progn
  55.       (setq scl (* (xd::var:getratio) (xd::var:getscaleratio)))
  56.       (setq lst (mapcar
  57.                   '(lambda (x)
  58.                      (setq info (xdrx_getpropertyvalue x "patternname" "layer" nil "color" t))
  59.                      (setq val (cond ((= #xd_var_global_hatch_tj_mode 2)
  60.                                                            (car info))
  61.                                                           ((= #xd_var_global_hatch_tj_mode 0)
  62.                                                            (cadr info))
  63.                                                           (t
  64.                                                            (last info))))
  65.                      (if (/= (type val) 'STR)
  66.                        (setq val (vl-princ-to-string val)))
  67.                      (list val (car info)(cadr info)(caddr info) x))
  68.                   (xdrx_pickset->ents ss)
  69.                 )
  70.             lst (xd::list:groupbyindex lst 0.01)
  71.             lst (vl-sort lst '(lambda (x y)
  72.                                 (< (car x) (car y))
  73.                               )
  74.                 )
  75.             lst (mapcar
  76.                   'cadr
  77.                   lst
  78.                 )
  79.             i 0
  80.             lst (mapcar
  81.                   '(lambda (x)
  82.                      (setq i (1+ i))
  83.                      (list (itoa i) (_maketuli (caddr x)(car x)(cadr x))
  84.                                     (car x)(cadr x)
  85.                            (vl-princ-to-string (caddr x))
  86.                      )
  87.                    )
  88.                   lst
  89.                 )
  90.             lst (append
  91.                   (list (list "填充图例表" nil nil nil nil) (list "序号"
  92.                                                                   "图例"
  93.                                                                   "模式"
  94.                                                                   "图层"
  95.                                                                   "颜色"
  96.                                                             )
  97.                   )
  98.                   lst
  99.                 )
  100.       )
  101.       (if (not #hatch_tuli_txth)
  102.         (setq #hatch_tuli_txth 5.0)
  103.       )
  104.       (if (setq h (getreal (xdrx_prompt "\n字高<" #hatch_tuli_txth ">:" t)))
  105.         (setq #hatch_tuli_txth h)
  106.       )
  107.       (xdrx_sysvar_push '("cecolor" "7"))
  108.       (xd::text:Init 1)
  109.       (xd::table:makefromlist lst '(0 0 0) #hatch_tuli_txth (/ #hatch_tuli_txth
  110.                                                                2.0
  111.                                                             )
  112.       )
  113.       (if (vl-catch-all-error-p (vl-catch-all-apply 'XD::Drag:SimpleMove
  114.                                                     (list (entlast)
  115.                                                           "\n表格插入点:" 8
  116.                                                           t
  117.                                                     )
  118.                                 )
  119.           )
  120.         (xdrx_entity_delete (entlast))
  121.       )
  122.     )
  123.     (prompt "\n没有选择到填充实体.")
  124.   )
  125.   (xdrx_end)
  126.   (princ)
  127. )


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

已领礼包: 7937个

财富等级: 富甲天下

发表于 2018-7-23 20:48:21 | 显示全部楼层
精彩创意!  学习了!  要是同时发布“脱裤”版本,用起来更加方便。

点评

如果要脱裤,要写很长代码,也要很长的时间。你就不会看到这么多插件了。 画图要快,是因为不做重复的事情,写代码一样,总做重复的事情也不高明啊。  详情 回复 发表于 2018-7-23 21:00
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 40个

财富等级: 招财进宝

 楼主| 发表于 2018-7-23 21:00:59 | 显示全部楼层
本帖最后由 newer 于 2018-7-23 21:03 编辑
dwg001 发表于 2018-7-23 20:48
精彩创意!  学习了!  要是同时发布“脱裤”版本,用起来更加方便。

如果要脱裤,要写很长代码,也要很长的时间。你就不会看到这么多插件了。
用XDRX API,我10分钟就一个这样的插件,没它,可能要几天。

画图要快,是因为不做重复的事情,写代码一样,总做低级、重复的事情也不高明啊。
站在前人的肩膀上,看的才比前人更远。


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

使用道具 举报

已领礼包: 1227个

财富等级: 财源广进

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

使用道具 举报

已领礼包: 12个

财富等级: 恭喜发财

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

使用道具 举报

已领礼包: 3233个

财富等级: 富可敌国

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

使用道具 举报

已领礼包: 64个

财富等级: 招财进宝

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

使用道具 举报

已领礼包: 100个

财富等级: 招财进宝

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2021-3-3 10:59 , Processed in 0.168427 second(s), 31 queries , Gzip On, WinCache On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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