获取外部图纸中的数据库
2015-09-18 14:40
183 查看
其中filePath是外部图纸的保存地址,这是对于使用ZWCAD来编写时,需要在创建数据库之前,提供一个服务,具体代码如下面:
ZcDbDatabase * getDataByDwg(CString filePath)
{
//提供服务
class ZcDbHostApplicationServicesEx : public ZcDbHostApplicationServices
{
public:
ZcDbHostApplicationServicesEx(){};
virtual Zcad::ErrorStatus findFile(ZTCHAR * pcFullPathOut,
int nBufferLength,
const ZTCHAR * pcFilename,
ZcDbDatabase * pDb = NULL,
ZcDbHostApplicationServices::FindFileHint hint = kDefault){return Zcad::eOk;}
};
Zcad::ErrorStatus es;
ZcDbHostApplicationServicesEx *pdbsvr = new ZcDbHostApplicationServicesEx;
zcdbSetHostApplicationServices(pdbsvr);
//定义一个数据库对象
ZcDbDatabase *pDb = NULL;
pDb = new ZcDbDatabase(ZSoft::kFalse);
Zcad::ErrorStatus es = pDb->readDwgFile(filePath);
if (Zcad::eOk != es)
{
zcutPrintf(filePath + _T("\n在当前文件中不存在!"));
delete pDb;
pDb = NULL;
return NULL;
}
return pDb;
}
///////////////////////////////////////////////////////////////////////////////////////////////////////
对于autocad的话,就不需要提供服务,可以直接创建数据库,然后通过readDwgFile来获得外部图纸的数据库,代码如下:
AcDbDatabase * getDataByDwg(CString filePath)
{
//定义一个数据库对象
AcDbDatabase *pDb = NULL;
pDb = new AcDbDatabase(Adesk::kFalse);
Acad::ErrorStatus es = pDb->readDwgFile(filePath);
if (Acad::eOk != es)
{
acutPrintf(filePath + _T("\n在当前文件中不存在!"));
delete pDb;
pDb = NULL;
return NULL;
}
return pDb;
}
ZcDbDatabase * getDataByDwg(CString filePath)
{
//提供服务
class ZcDbHostApplicationServicesEx : public ZcDbHostApplicationServices
{
public:
ZcDbHostApplicationServicesEx(){};
virtual Zcad::ErrorStatus findFile(ZTCHAR * pcFullPathOut,
int nBufferLength,
const ZTCHAR * pcFilename,
ZcDbDatabase * pDb = NULL,
ZcDbHostApplicationServices::FindFileHint hint = kDefault){return Zcad::eOk;}
};
Zcad::ErrorStatus es;
ZcDbHostApplicationServicesEx *pdbsvr = new ZcDbHostApplicationServicesEx;
zcdbSetHostApplicationServices(pdbsvr);
//定义一个数据库对象
ZcDbDatabase *pDb = NULL;
pDb = new ZcDbDatabase(ZSoft::kFalse);
Zcad::ErrorStatus es = pDb->readDwgFile(filePath);
if (Zcad::eOk != es)
{
zcutPrintf(filePath + _T("\n在当前文件中不存在!"));
delete pDb;
pDb = NULL;
return NULL;
}
return pDb;
}
///////////////////////////////////////////////////////////////////////////////////////////////////////
对于autocad的话,就不需要提供服务,可以直接创建数据库,然后通过readDwgFile来获得外部图纸的数据库,代码如下:
AcDbDatabase * getDataByDwg(CString filePath)
{
//定义一个数据库对象
AcDbDatabase *pDb = NULL;
pDb = new AcDbDatabase(Adesk::kFalse);
Acad::ErrorStatus es = pDb->readDwgFile(filePath);
if (Acad::eOk != es)
{
acutPrintf(filePath + _T("\n在当前文件中不存在!"));
delete pDb;
pDb = NULL;
return NULL;
}
return pDb;
}
相关文章推荐
- 浅谈MySQL和mariadb区别
- Sharepoint 2013 表单验证四(添加用户到表单验证数据库)
- oracle学习之bulk collect用法
- Mongodb Replica Sets+Sharding群集 部署手册
- mysql性能优化-慢查询分析、优化索引和配置
- Oracle中的索引详解
- 批量修改数据库中某个字段里面的部分内容(mysql数据库replace的用法)
- Mysql/MariaDB启动时处于进度条状态导致启动失败的原因及解决办法
- Mysql 小结
- 所有SQL*Loader实验笔记
- hibernate对数据库进行CRUD操作
- OperationalError: (1130, "Host ... not allowed to connect this MySQL server")
- Neo4j数据库简单
- 数据库优化之利用索引、避免全表扫描
- Oracle存储过程的调试
- ORA-00257: oracle报archiver error的解决方法
- mysql知识点
- 数据库
- 新浪微博数据库是如何设计的
- PostgreSQL的HA解决方案-1主从和备份(master/slave and backup)