乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 172|回复: 5

请教下VBA如何创建动态块?

[复制链接]

24

主题

83

帖子

7

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
179
发表于 2020-12-1 23:38:00 | 显示全部楼层 |阅读模式
如题,请教下VBA如何创建动态块?
有可以参考的代码可以分享吗?
非常感谢!
回复

使用道具 举报

1

主题

5

帖子

1

银币

初来乍到

Rank: 1

铜币
9
发表于 2022-4-27 18:07:00 | 显示全部楼层
会了吗 老哥
回复

使用道具 举报

2

主题

39

帖子

9

银币

初来乍到

Rank: 1

铜币
47
发表于 2022-4-27 22:38:00 | 显示全部楼层

官方已明确:动态块可VBA编辑属性、 可参数控制变形;但不可VBA/Vlisp创建。

xtv1jsefeay.png

xtv1jsefeay.png


回复

使用道具 举报

2

主题

39

帖子

9

银币

初来乍到

Rank: 1

铜币
47
发表于 2022-4-27 22:50:00 | 显示全部楼层

创建动态块得 .net或Objarx
下面这段.net 试试看
  1. using System;
  2. using Autodesk.AutoCAD.DatabaseServices;
  3. using Autodesk.AutoCAD.Geometry;
  4. using Autodesk.AutoCAD.Runtime;
  5. [assembly: CommandClass(typeof(Sample.AddBlock))]
  6. namespace Sample
  7. {
  8.     class AddBlock
  9.     {
  10.         ///
  11.         /// 把块定义变为块参照插入
  12.         ///
  13.         [CommandMethod("AddBlock")]
  14.         public void AddBk()
  15.         {
  16.             Database db = HostApplicationServices.WorkingDatabase;
  17.             ObjectId blkid;
  18.             //创建块定义
  19.             using (Transaction trans = db.TransactionManager.StartTransaction())
  20.             {
  21.                 BlockTable bt = trans.GetObject(db.BlockTableId, OpenMode.ForWrite) as BlockTable;
  22.                 BlockTableRecord blk = new BlockTableRecord();
  23.                 blk.Name = "BLK";
  24.                 Line L = new Line(Point3d.Origin, new Point3d(1000, 1000, 0));
  25.                 Circle C = new Circle(Point3d.Origin, Vector3d.ZAxis, 500);
  26.                 blk.AppendEntity(L);
  27.                 blk.AppendEntity(C);
  28.                 blkid = bt.Add(blk);
  29.                 trans.AddNewlyCreatedDBObject(blk, true);
  30.                 trans.Commit();
  31.             }
  32.             
  33.             //把块参照添加到块表记录
  34.             using (Transaction tr = db.TransactionManager.StartTransaction())
  35.             {
  36.                 BlockTable bt = tr.GetObject(db.BlockTableId, OpenMode.ForRead) as BlockTable;
  37.                 BlockTableRecord btr = tr.GetObject(bt[BlockTableRecord.ModelSpace], OpenMode.ForWrite) as BlockTableRecord;
  38.                 BlockReference br = new BlockReference(new Point3d(0,0, 0), blkid);     // 通过块定义创建块参照
  39.                 btr.AppendEntity(br);
  40.                 tr.AddNewlyCreatedDBObject(br, true);   // 通过事务添加块参照到数据库
  41.                 tr.Commit();
  42.             }
  43.         }
  44.     }
  45. }

回复

使用道具 举报

1

主题

5

帖子

1

银币

初来乍到

Rank: 1

铜币
9
发表于 2022-4-28 17:48:00 | 显示全部楼层
好的我试试
回复

使用道具 举报

1

主题

21

帖子

5

银币

初来乍到

Rank: 1

铜币
25
发表于 2022-5-4 00:13:00 | 显示全部楼层
好像是没有对应的动态块创建命令,我一般都是手动设置动态块的属性和范围后,VBA可调用已存在的对应块定义,插入块参照,设置指定的参数属性。
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-12 22:58 , Processed in 0.524120 second(s), 67 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表