设为首页收藏本站

晓东CAD家园-论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 714|回复: 7

[工具] 表格按三种方式(行、手描边界、选边界)拆分(第二版)

[复制链接]

已领礼包: 51个

财富等级: 招财进宝

发表于 2016-12-9 19:59:47 | 显示全部楼层 |阅读模式
  • 插件名称 : 表格拆分
  • 作  者 : Lispboy
  • 运行环境 :XDRX API 晓东工具箱 
  • 发布时间 :2016-12-09
  • 命令名称 :XDTB_TABLEBRK
  • 插件介绍 :表格拆分
  • 备  注 : (点击图片可以放大)
(点击图片可以放大)

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

插件详细内容

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

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

x
本帖最后由 newer 于 2016-12-9 20:05 编辑

最近接个活,要做1万8千个点的63公里的高速路的用地坐标标注,100多张1号图,不是人干的活,写了个程序,几秒钟编号,表格生成完毕,交给同事布置图面出图。


工作中,布置图面也是一种累人的活,又写了个工具,逐步完善到选择边界根据图面空白地方自动把表格排好. 好多人几个月的工作量几天就完成了。

本程序不只是支持ACAD的TABLE实体,还支持TABLE变成块后的实体(图块),因为工作中发现,几百行的表格ACAD打开图就很慢了,再多基本就打不开图了,所以把表格变成了图块,打开图快多了。

[sell]
(defun c:XDTB_TableBrk (/ brkHeight brkSpacing datarows direc e e1 e2 ee g h
                          i in insert ints j key nums p1 p2 pt pts rc row
                          rows start str tf vx w x
                       )
  (defun _prompt ()
    (xdrx_prompt "\n当前模式: " (cond
                                  ((= #table_brk_mode 0)
                                    "按行"
                                  )
                                  ((= #table_brk_mode 1)
                                    "手描边界"
                                  )
                                  (t
                                    "选边界"
                                  )
                                )
    )
  )
  (defun _keyword (key)
    (setq tf nil)
    (cond
      ((= key "RO")
        (setq #table_brk_mode 0)
      )
      ((= key "LI")
        (setq #table_brk_mode 1)
      )
      ((= key "SE")
        (setq #table_brk_mode 2)
      )
    )
    (_prompt)
  )
  (defun _brk (e1 row tf)
    (setq e2 (xdrx_entity_copy e1)
          e2 (entlast)
          start row
          rows (xdrx_table_numrows e1)
          datarows (xdrx_table_NumDataRows e1)
          brkHeight (xdrx_table_breakheight e1 0)
          brkSpacing (xdrx_table_breakSpacing e1)
          w (xdrx_table_width e1)
          h (xdrx_table_height e1)
          vx (xdrx_table_direction e1)
          p1 (xdrx_getpropertyvalue e1 "position")
    )
    (xdrx_table_deleteRows e1 start rows)
    (xdrx_table_deleteRows e2 (cadr datarows) (- start 2))
    (if (not brkheight)
      (setq p2 (mapcar
                 '+
                 p1
                 (xdrx_vector_product vx (+ w (/ w 10.0)))
               )
      )
      (progn
        (setq nums (+ 1 (fix (/ h brkheight)))
              p2 (mapcar
                   '+
                   p1
                   (xdrx_vector_product vx (+ (* nums w) (* (- nums 1)
                                                            brkspacing
                                                         ) brkspacing
                                           )
                   )
                 )
        )
      )
    )
    (xdrx_entity_move e2 p1 p2)
    (if tf
      (progn
        (mapcar
          '(lambda (x)
             (setq str (xdrx_getpropertyvalue x "handle"))
             (xdrx_block_make (strcat "XTABLE-" str) x
                              (xdrx_getpropertyvalue x "position") t
             )
           )
          (list e1 e2)
        )
      )
    )
    (setq e1 (entlast))
  )
  (xdrx_begin)
  (xdrx_sysvar_push '("osmode" 0))
  (if (not #table_brk_mode)
    (setq #table_brk_mode 0)
  )
  (_prompt)
  (xdrx_initssget "\n请拾取要拆分的表格[按行[(RO)/手描断线(LI)/选边界(SE)]<退出>:"
                  "RO LI SE" "" "_KEYWORD"
  )
  (if (and
        (setq e (xdrx_ssget ":E:S" '((-4 . "<or") (-4 . "<and")
                             (0 . "INSERT")
                             (2 . "*TABLE-*")
                             (-4 . "and>")
                             (0 . "ACAD_TABLE")
                             (-4 . "or>")
                            )
                )
        )
        (setq e1 (ssname e 0))
      )
    (progn
      (cond
        ((= #table_brk_mode 0)
          (setq pt (getpoint "\n点取要拆分的行<退出>:"))
          (setq pt (trans pt 1 0))
          (if (not (xdrx_object_isa e1 "AcDbTable"))
            (setq e1 (xdrx_entity_explode e1 t)
                  e1 (entlast)
                  tf t
            )
          )
          (if (setq rc (xdrx_table_hittest e1 pt '(0 0 1.0) 1.0 1.0))
            (progn
              (_brk e1 (car rc) tf)
            )
          )
        )
        ((= #table_brk_mode 1)
          (if (setq pts (xd::doc:getfence "打断线第一点" "下一点" 1))
            (progn
              (setq insert e1)
              (setq pts (xd::pnts:ucs2wcs pts)
                    g (xdge::constructor "kcompositecrv3d" pts)
              )
              (xdrx_statusbar_begin "处理中" 20)
              (setq i 0)
              (while (and
                       (progn
                         (if (not (xdrx_object_isa e1 "AcDbTable"))
                           (setq e1 (xdrx_entity_explode e1 t)
                                 e1 (entlast)
                                 tf t
                           )
                           t
                         )
                       )
                       (setq ints (xdrx_entity_intersectwith e1 g))
                     )
                (xdrx_statusbar_setpos (setq i (1+ i)))
                (setq rc (xdrx_table_hittest e1 (car ints) '(0 0 1) 1 1))
                (setq e1 (_brk e1 (car rc) tf))
              )
              (xdrx_statusbar_end)
              (xdge::free g)
            )
          )
        )
        (t
          (if (and
                (setq ee (car (xdrx_entsel "\n选取拆分边界<退出>:" '
                                           ((0 . "*LINE,ARC,SPLINE"))
                              )
                         )
                )
                (setq g (xdge::constructor ee))
              )
            (progn
              (xdrx_statusbar_begin "处理中" 20)
              (setq j 0)
              (xdge::entity:make g)
              (setq i 0)
              (while (and
                       (progn
                         (if (not (xdrx_object_isa e1 "AcDbTable"))
                           (setq e1 (xdrx_entity_explode e1 t)
                                 e1 (entlast)
                                 tf t
                           )
                           t
                         )
                       )
                       (setq ints (xdrx_entity_intersectwith e1 g))
                     )
                (xdrx_statusbar_setpos (setq i (1+ i)))
                (setq direc (xdrx_curve_getfirstderiv ee (car ints)))
                (if (and
                      (> (xdrx_vector_angle direc) PI)
                      (< (xdrx_vector_angle direc) (* 2 PI))
                    )
                  (setq in (car ints))
                  (setq in (last ints))
                )
                (setq rc (xdrx_table_hittest e1 in '(0 0 1) 1 1))
                (setq e1 (_brk e1 (car rc) tf))
              )
              (xdrx_statusbar_end)
              (xdge::free g)
            )
          )
        )
      )
    )
  )
  (xdrx_sysvar_pop)
  (xdrx_end)
  (princ)
)

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

已领礼包: 7711个

财富等级: 富甲天下

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

使用道具 举报

已领礼包: 125个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 382个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 849个

财富等级: 财运亨通

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

使用道具 举报

已领礼包: 1个

财富等级: 恭喜发财

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

使用道具 举报

已领礼包: 3个

财富等级: 恭喜发财

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

使用道具 举报

已领礼包: 69个

财富等级: 招财进宝

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2021-1-18 05:53 , Processed in 0.177282 second(s), 30 queries , Gzip On, WinCache On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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