找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 321|回复: 3

[原创] 取出嵌套块中文字的图元及包围盒

[复制链接]

已领礼包: 201个

财富等级: 日进斗金

发表于 2022-6-27 16:12:36 | 显示全部楼层 |阅读模式

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

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

×
(get_ename_pts e str)
函数功能:取出块中包含文字的图元及包围盒。
可用于嵌套块
其中:
        e---insert块
        str---文字包含的内容。
(defun get_ename_pts(e str / e1 mat pts)
        (defun get_e1 (e)
                (car
                        (xdrx-block-getentities
                                t
                                (cadr (xdrx-getpropertyvalue e "blocktablerecord"));;;取出块的对象名
                                (list
                                        '(0 . "*text")
                                        (cons 1  (strcat "*" str "*"))
                                );;;list
                        );;;xdrx
                );;;car
        );;;defun
        (defun get_mat (e / lst-blk)
                (if (not (vl-position e1 (xdrx-getpropertyvalue e "entities")))
                        (progn
                                (if (setq lst-blk (xdrx-block-getentities (cadr (xdrx-getpropertyvalue e "blocktablerecord")) '((0 . "insert"))))
                                        (vl-some
                                                '(lambda(x)
                                                        (if (get_e1 x)
                                                                (progn
                                                                        (setq mat (cons (xdrx-getpropertyvalue x "BlockTransform") mat))
                                                                        (get_mat x)
                                                                );;;progn
                                                        );;;if
                                                );;;lambda
                                                lst-blk
                                        );;;vl
                                );;;if
                        );;;progn
                );;;if
                mat
        );;;;defun
        (setq e1 (get_e1 e))
        (if e1
                (setq mat (list (xdrx-getpropertyvalue e "BlockTransform"))
                         mat (apply 'xdrx-matrix-product (reverse (get_mat e)))
                        pts (xdrx-points-transform (xdrx-entity-box e1) mat)
                );;;;setq
        );;;if
        (list e1 pts)
);;;defun

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

已领礼包: 414个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 244个

财富等级: 日进斗金

发表于 2022-6-28 14:08:37 | 显示全部楼层

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-19 11:41 , Processed in 0.395279 second(s), 35 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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