CAD二次开发---导入外部文件中的块并输出预览图形(五)
思路:
1)首先要定义一个数据库对象来表示包含块的文件,改数据库对象会被加载到内存中,但不会被显示在CAD窗口中。
2)调用Database类的ReadDwgFile函数将外部文件DWG文件读入到新创建的数据库对象中。
3)最后调用Database类的WblockCloneObjects函数将外部的DWG文件中块对象复制到当前数据库中。
/// <summary>
/// 外部文件导入块,
/// </summary>
/// <param name="desdb">目标数据库</param>
/// <param name="sourceFileName">完整的外部文件名</param>
public static void ImportBlocksFrmDwg(this Database desdb, string sourceFileName)
{
//public Database(bool buildDefaultDrawing, bool noDocument);
Database sourceDb = new Database(false, true);//创建一个新的数据库对象,作为源数据库,以读入外部文件中的对象 try
{
//把DWG文件读入到一个临时的数据库中
// public void ReadDwgFile(string fileName, FileShare fileSharing, bool allowCPConversion, string password);
sourceDb.ReadDwgFile(sourceFileName, System.IO.FileShare.Read, true, null);
//创建一个变量来存储块的ObjectId列表
ObjectIdCollection blocks = new ObjectIdCollection();
//获取源数据的事务处理管理器
Autodesk.AutoCAD.DatabaseServices.TransactionManager tranm = sourceDb.TransactionManager; //在源数据库中开始数据处理 using (Transaction tran = tranm.StartTransaction())
{
//打开源数据库中的块表
// public virtual DBObject GetObject(ObjectId id, OpenMode mode);
//public virtual DBObject GetObject(ObjectId id, OpenMode mode, bool openErased);
//public virtual DBObject GetObject(ObjectId id, OpenMode mode, bool openErased, bool forceOpenOnLockedLayer);
BlockTable bt = (BlockTable)tran.GetObject(sourceDb.BlockTableId, OpenMode.ForRead, false); foreach (ObjectId btrId in bt)
{
BlockTableRecord btr = tranm.GetObject(btrId, OpenMode.ForRead, false) as BlockTableRecord;
//只加入命名块和非布局快到复制列表中
if (!btr.IsAnonymous && !btr.IsLayout)
{
blocks.Add(btrId);
}
btr.Dispose(); }
bt.Dispose();
} IdMapping mapping = new IdMapping(); //从源数据库想目标数据库复制块表记录
sourceDb.WblockCloneObjects(blocks, desdb.BlockTableId, mapping, DuplicateRecordCloning.Replace, false); }
catch(Autodesk.AutoCAD.Runtime.Exception ex )
{
Autodesk.AutoCAD.ApplicationServices.Application.ShowAlertDialog("错误信息"+ex.Message); }
//操作完成,销毁源数据库
sourceDb.Dispose(); }
导入块函数
实例:
[CommandMethod("BlockPreview")]
public void GenerateBlockPreview()
{
Database db = HostApplicationServices.WorkingDatabase;
Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
PromptFileNameResult result = ed.GetFileNameForOpen("请选择需要预览的文件");
if (result.Status != PromptStatus.OK) return;
string filename = result.StringResult;
//在C盘跟目录线,创建一个临时文件夹,用于存放文件中的块预览图标
string path = "C:\\Temp1";
if (!Directory.Exists(path))
Directory.CreateDirectory(path);
using (Transaction tran = db.TransactionManager.StartTransaction())
{
//导入外部的块
db.ImportBlocksFrmDwg(filename);
//打开块表
BlockTable bt = tran.GetObject(db.BlockTableId, OpenMode.ForRead) as BlockTable;
foreach (ObjectId id in bt)
{
BlockTableRecord btr = tran.GetObject(id, OpenMode.ForRead) as BlockTableRecord;
//如果是匿名块,布局块以及没有预览图型块,则返回
if (btr.IsAnonymous || btr.IsLayout || !btr.HasPreviewIcon)
{
//获取预览图块,适用于2008及以下版本
Bitmap preview = BlockThumbnailHelper.GetBlockThumbanail(btr.ObjectId);
//
//Bitmap preview = btr.PreviewIcon;//适用于2009版本及以上版本
preview.Save(path + "\\" + btr.Name + ".bmp");//保存块预览
}
}
tran.Commit();
}
}
读取外部文件中的块,并输出预览图
CAD二次开发---导入外部文件中的块并输出预览图形(五)的更多相关文章
- CAD二次开发中浮动面板不浮动的问题
CAD二次开发中创建了一个浮动面板,想让它创建出来后以浮动状态显示, 但是DockSides.None设置完后,面板还是不浮动.搞了很久,最后原来是 需要先设置Visible,再设置DockSides ...
- CAD二次开发起步
1 环境搭建(VS 2017 + CAD 2019) CAD版本一般要比VS版本晚两年以上,比如我现在使用VS2017,则CAD要用2019版,至于CAD2018能不能用没试验过,有兴趣的小伙伴可以试 ...
- C#进行CAD二次开发环境配置
最近被公司分配到了做CAD二次开发.也是初次接触这方面的东西,其实是有些无从下手的感觉.因为公司这边也没有人有时间带我,只能是自己看书,然后再写一些Demo,再结合实际的应用来一点点的学习.废话不多说 ...
- CAD 二次开发 -- 自动加载开发的DLL
CAD二次开发可以采用写扩展DLL的方式实现.该DLL的函数可以被CAD调用. 但是调用前,必须用命令netload 将该dll加载到CAD. 其实可以修改注册表,当CAD软件启动后,自动加载扩展DL ...
- Cad 二次开发关于SelectCrossingPolygon和SelectFence返回结果Status为error的小测试
CAD2008的二次开发,有个很奇怪的现象,只要你选择的点集不在当前视图上SelectCrossingPolygon和SelectFence返回结果Status就会为error,所以要获取正确的结果, ...
- CAD二次开发
用C#有一段时间了,由于单位需要,开始接触CAD二次开发,网上一搜,加入CAD开发的群,零零碎碎看了一些文章和博客,没有系统地的知识,能解决一些小问题.最近开始系统学习,再次推荐两本书,一本事纸质版的 ...
- 推荐两个不错的CAD二次开发(.Net)手册
推荐两个不错的CAD二次开发(.Net)手册 http://www.mjtd.com/helpcenter/netguide/index.html http://www.ceesky.com/book ...
- C# 将List中的数据导入csv文件中
//http://www.cnblogs.com/mingmingruyuedlut/archive/2013/01/20/2849906.html C# 将List中的数据导入csv文件中 将数 ...
- (转)MyBatis框架的学习(四)——Mapper.xml文件中的输入和输出映射以及动态sql
http://blog.csdn.net/yerenyuan_pku/article/details/71893689 前面对MyBatis框架的学习中,我们对Mapper.xml映射文件多少有些了解 ...
随机推荐
- linux系统PXE+Kickstart自动安装系统
一.PXEPXE(Pre-boot Execution Environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服 ...
- c#跨线程访问控件帮助类
1.背景 对于winform程序来说,当我们点击按钮,需要消耗一定时长才能拿到数据后才能显示在界面上某个控件上的情况,我们通常会专门开一个线程去拿数据,这样不会造成界面处于假死状态 2.常规做法 // ...
- seajs的CMD模式的优势以及使用
之前有一篇博客非常详细的介绍了sea.js的加载流程,以及源代码实现,链接地址:http://www.cnblogs.com/chaojidan/p/4123980.html 这篇博客我主要讲下sea ...
- Java数组的一些基本算法
数组的一些算法问题: 排序:(升序) 选择排序: 求每一轮的最小值:再输出 冒泡排序: 相邻的两个数相比较,把两个数相比较,第一个大于好面的就交换位置 shell排序: ...
- ORA-01033: ORACLE 正在初始化或关闭 进程 ID: 0 会话 ID: 0 序列号: 0
用了很长时间的数据库,一直都挺好,今天早上一来报这个错,开始追究原因. 1.用SYS用户登录: 2.将数据库修改为打开状态,alter database open,出现如下的错误提示: ORA-160 ...
- 关于tp.5.0角色管理导致的创建角色登陆报错问题解决!
今天用tp 5.0的时候,遇到一个问题,就是在利用超级管理员创建管理员角色时,角色账号密码登陆报错的问题 解决方法如下 htaccess文件修改如下 <IfModule mod_rewrite. ...
- js中原型的概念
- cell嵌套UIWebView遇到的几个问题
一.防止死循环问题 方法一:使用动画块 [self.myTableView beginUpdates];[self.myTableView endUpdates]; 在下面的代 ...
- postgres 批量更新内容
在程序中遇到这样的需求, 数据库表格式如下 需要把批量更新status, 如name = fox 时, status = 1, name = boa 时,status = 2 .... 类似的 pos ...
- Direct2D相关
1,如何绘制文本 2,文本格式设置和布局