明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 560|回复: 9

[源码] 炸開圖塊修改,然後再依原圖塊存檔的小程序

[复制链接]
发表于 2024-7-18 23:05:04 | 显示全部楼层 |阅读模式
本帖最后由 stgpmin 于 2024-7-18 23:11 编辑

大家好,分享一個編輯圖塊的小程序。我的作圖習慣會將平面圖存成圖塊,方便在模型空間內會有多張圖框,例如一樓平面圖就會在建築平面、配置平面、景觀平面等重複出現。
透過我寫的這個小程序可以記憶被炸開的圖塊屬性,包含圖塊名稱、基準點、旋轉、比例、鏡射等等。在完成編輯圖塊後,就可以選擇物件再重新回存為原本的圖塊,而其他的圖塊副本也會一起更新。

這個小程序編寫起因是鑑於原地編輯圖塊有很多不方便的地方(例如無法再次製作圖塊,有些涉及製作圖塊的外掛指令也會無法使用),尤其是在編輯過程中是無法存檔跟自動儲存的。不過目前還有無法克服的地方,就是要回存為原本圖塊時,無法自動選取中間這段時間所建立的物件,必須手動選取。
使用方法很簡單,
1.輸入xb1,選擇圖塊,該圖塊就會執行炸開指令,
2.編輯圖塊完成後,輸入cb1,原本圖塊的內容物件會群組化方便選取,再選擇其他想放入圖塊的物件後,按enter,完成。
3.有時編輯圖塊後,會忘記曾經執行過這個小程序而再次執行去炸開另一個圖塊,所以這個小程序有設置防呆,如果沒執行cb1,是無法再次執行xb1指令。
4.若強制要再次執行xb1,可以輸入xx1解開禁制。
搭配我另一個發布的小程序ibb,對於使用圖塊作圖有很大便利性。

  1. (defun C:xb1 (/ ss bss en1 EN1_data)
  2.   (if (= xb_name nil)
  3.     (progn
  4.       (command "ucs" "w")
  5.       (setq bss (entsel))
  6.       (command "_.undo" "_group")
  7.       (setq eN1 (car bss))
  8.       (setq EN1_data (entget EN1))
  9.       (setq xb_name (cdr (assoc 2 EN1_data))) ;名稱
  10.       (setq xb_pt (cdr (assoc 10 EN1_data)))
  11.       ;;插入點
  12.       (setq ttx (polar xb_pt 0 100))
  13.       (setq tty (polar xb_pt (/ pi 2) 100))
  14.       (SETQ mir_41 (assoc 41 EN1_data))
  15.       (SETQ mir_42 (assoc 42 EN1_data))
  16.       
  17.       (setq xb_layer (cdr (assoc 8 EN1_data)))
  18.       ;;圖層
  19.       (setq xb_rot (cdr (assoc 50 EN1_data)))
  20.       ;;旋轉
  21.       (setq xb_dg1 (* (/ xb_rot pi) 180))
  22.       (setq xb_sc (cdr (assoc 41 EN1_data)))
  23.       ;;以下為X向鏡射
  24.       (if (< (cdr (assoc 41 EN1_data)) 0)
  25.   (progn
  26.     (setq mi_x "1")
  27.   )
  28.       )
  29.       ;;以下為y向鏡射
  30.       (if (< (cdr (assoc 42 EN1_data)) 0)
  31.   (progn
  32.     (setq mi_y "1")
  33.   )
  34.       )
  35.       ;;;將xb_sc轉為正數
  36.       (if (= mi_x "1")
  37.   (setq xb_sc (abs xb_sc))
  38.       )
  39.       ;;比例
  40.       (setq sc_re (/ 1 xb_sc))
  41.       ;;有旋轉及縮放的處理差異
  42.       (if (and (= xb_rot 0) (= xb_sc 1))
  43.   (progn
  44.     (COMMAND "EXPLODE" bss "")
  45.     (setq ss (ssget "_p"))
  46.     (SETVAR "QAFLAGS" 1)
  47.     (COMMAND "GROUP" SS "")
  48.     (SETQ ENLAST1 (ENTLAST))
  49.     (SETVAR "QAFLAGS" 0)
  50.     (command "pickstyle" "0")
  51.     (command "ucs" "p")
  52.   )
  53.   (progn
  54.     (COMMAND "EXPLODE" bss "")
  55.     (setq ss (ssget "_p"))
  56.     (SETVAR "QAFLAGS" 1)
  57.     (COMMAND "GROUP" SS "")
  58.     (SETQ ENLAST1 (ENTLAST))
  59.     (SETVAR "QAFLAGS" 0)
  60.     (command "pickstyle" "0")
  61.     (command "ucs" "p")
  62.   )
  63.       )
  64.     )
  65.     (princ "前次編輯未結束")
  66.   )
  67.   (command "_.undo" "_end")
  68. )
  69. (defun C:cb1 (/ HOLDECHO HOLDBLIP A AA BLKREF pt)
  70.   (setvar "CMDECHO" 0)
  71.   (command "ucs" "w")
  72.   (setq olayer (getvar "clayer"))
  73.   (setvar "clayer" xb_layer)
  74.   (command "pickstyle" "1")
  75.   (redraw ENLAST1 3)
  76.   (setq AA (ssget))
  77.   (command "_.undo" "_group")
  78.   (setq HOLDECHO (getvar "cmdecho"))
  79.   (setq HOLDBLIP (getvar "blipmode"))
  80.   (setq HOLDOSMODE (getvar "OSMODE"))
  81.   (setvar "cmdecho" 0)
  82.   (setvar "blipmode" 0)
  83.   (setvar "OSMODE" 0)
  84.   (setq A (rtos (* (getvar "CDATE") 1E8)))
  85.   (command "scale" aa "" xb_pt sc_re)
  86.   ;;縮回1
  87.   (command "rotate" aa "" xb_pt (- 0 xb_dg1))
  88.   ;;轉回0
  89.   (if (= mi_x "1")
  90.     (command "mirror" aa "" xb_pt tty "y"))
  91.   (if (= mi_y "1")
  92.     (command "mirror" aa "" xb_pt ttx "y"))
  93.   ;;鏡射回去
  94.   (if (/= AA NIL)
  95.     (progn
  96.       (command "-BLOCK" xb_name "y" xb_pt AA "")
  97.       (command "-INSERT" xb_name xb_pt "" "" "" "" "")
  98.       (SETQ ENLAST1 (ENTLAST))
  99.       (setq enL1_data (entget ENLAST1))
  100.       (command "scale" ENLAST1 "" xb_pt xb_sc)
  101.     (setq oldr (assoc 41 enL1_data))
  102.     (setq enL1_data (subst mir_41 oldr enL1_data))
  103.     (entmod enL1_data)
  104.     (setq oldr (assoc 42 enL1_data))
  105.     (setq enL1_data (subst mir_42 oldr enL1_data))
  106.     (entmod enL1_data)
  107.       (command "rotate" ENLAST1 "" xb_pt xb_dg1)
  108.       (command "attsync" "" ENLAST1 "")
  109.       ;;放置最下方
  110.       (command "draworder" ENLAST1 "" "b")
  111.       (command "hatchtoback")
  112.     )
  113.   )
  114.   (if (/= AA NIL)
  115.     (setq xb_name nil)
  116.   )
  117.   (setvar "blipmode" HOLDBLIP)
  118.   (setvar "cmdecho" HOLDECHO)
  119.   (setvar "OSMODE" HOLDOSMODE)
  120.   (setvar "clayer" olayer)
  121.   (command "_.undo" "_end")
  122.   (command "ucs" "p")
  123.   (setq mi_x "0" mi_y "0")
  124.   (princ)
  125. )
  126. (defun C:xx1 ()
  127.   (setq xb_name nil)
  128.   (princ "Xb1指令重置")
  129. )

评分

参与人数 2明经币 +2 收起 理由
bssurvey + 1 赞一个!
1028695446 + 1

查看全部评分

发表于 2024-7-18 23:22:16 | 显示全部楼层
这么高级,试用一下,谢谢分享
发表于 2024-7-19 00:33:20 来自手机 | 显示全部楼层
能做一个图块编号 保留原图块内容插件不
发表于 2024-7-19 07:45:29 | 显示全部楼层
好东西,支持一下
 楼主| 发表于 2024-7-19 08:25:08 | 显示全部楼层
jh3030912 发表于 2024-7-19 00:33
能做一个图块编号 保留原图块内容插件不

不太懂,可以多說明一下嗎?
发表于 2024-7-19 08:37:41 | 显示全部楼层
本帖最后由 panliang9 于 2024-7-19 08:57 编辑

谢谢楼主分享!
我理解你的工作是这样的:

1、XB1 命令,块炸开成组,并且给出组名。

2、CB1 命令 ,把“pickstyle” 打开,可以选中刚才哪个组。

发表于 2024-7-19 12:43:49 | 显示全部楼层
没太看明白意思
 楼主| 发表于 2024-7-19 16:11:11 | 显示全部楼层
panliang9 发表于 2024-7-19 08:37
谢谢楼主分享!
我理解你的工作是这样的:

沒錯
說明一下,pickstyle是控制選擇群組
當執行XB1後,會將所炸開的物件做群組,所以必須把pickstyle設為0,才能對炸開後的物件單獨編輯
所以執行CB1時,必須再把pickstyle設為1。
如果你平常習慣是把pickstyle設為0,那就在CB1指令最後面再加入一行(command "pickstyle" "0")
发表于 2024-7-22 10:43:14 | 显示全部楼层
好东西,支持一下
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-25 11:37 , Processed in 0.184587 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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