AcDbTable 类
Table 例子学习笔记
在这个例子中,ARX向我们展示了ACDBTABLE类的一些基本操作方法,ACDBTABLE类是ACAD2005及其以后的产品,应该是说ACDBDATATABLE的升级产品,AcDbDataCell,AcDbDataTable,AcDbDataColumn在ACAD2004中就已经出现。
AcDbTable 功能很强大的。从最基本的,能设置表格的行、列数目,行、列高度(废话,这是最基本的),还能设置文字样式,每个单元格的前、背景颜色,文字的线宽,文字的可见性,文字的旋转。
表格线的样式,颜色,线宽,可见性。
还可以设置自动缩放。
合并与拆分单元格。
选定子区域(就是选择一部分);
还有自定义实体的夹点等等一系列操作,真强大。
以下是生成一个表格的最简单的例子。
AcDbBlockTable *pBlkTbl;
acdbHostApplicationServices()->workingDatabase()->getBlockTable(pBlkTbl, AcDb::kForWrite);
// 获得模型空间的块表记录
AcDbBlockTableRecord *pBlkTblRcd;
pBlkTbl->getAt(ACDB_MODEL_SPACE, pBlkTblRcd,AcDb::kForWrite);
AcDbTable* pTable = new AcDbTable;
AcDbDictionary *pDict = NULL;
AcDbObjectId idTblStyle;
acdbHostApplicationServices()->workingDatabase()->getTableStyleDictionary(pDict,AcDb::kForRead);
pDict->getAt(_T("Standard"),idTblStyle);
pDict->close();
pTable->setTableStyle( idTblStyle );
AcDbTextStyleTable* pTextStyle = NULL;
acdbHostApplicationServices()->workingDatabase()->getTextStyleTable(pTextStyle,AcDb::kForRead);
AcDbObjectId textID;
pTextStyle->getAt(_T("Standard"),textID);
pTextStyle->close();
if( !textID.isNull() )
{
pTable->setTextStyle(textID);
}
pTable->setNumColumns(2);
pTable->setNumRows(4);
pTable->generateLayout();
pTable->suppressHeaderRow(false);//禁用标题
//定义插入点
pTable->setPosition(AcGePoint3d(100,100, 0));
//定义行高
pTable->setRowHeight(0,30);
pTable->setRowHeight(1,5);
pTable->setRowHeight(2,5);
pTable->setRowHeight(3,5);
//定义列宽
pTable->setColumnWidth(0,45);
pTable->setColumnWidth(1,40);
pTable->setTextString(1,1,_T("sfsfsdfsd"));
pTable->setAutoScale(1,1,true);
pBlkTblRcd->appendAcDbEntity(pTable);
pTable->setRegen();
pTable->close();
pBlkTblRcd->close();
pBlkTbl->close();
//刷新屏幕
actrTransactionManager->flushGraphics(); /*refresh screen*/
acedUpdateDisplay();
合并行 列 pTable->mergeCells(1,2,0,0);
第一个函数和第二个函数是行的序号 三个和第四个是列的序号
最新文章
- IIS7.0发布Web服务-0001
- Android应用第一次安装成功点击“打开”后Home键切出应用后再点击桌面图标返回导致应用重启问题
- 无忧之道:Docker中容器的备份、恢复和迁移
- SSH协议及其应用
- [杂]SQL Server 之 Understanding Connection Pooling and Transactions
- php中的require() 语句的使用方法
- session与cookie的区别,有哪些不同之处
- ROW_NUMBER分页的注意事项
- You and your research
- 两种MD5最后的值不一样,因为两种做法不一样
- C++基础——C面向过程与C++面向对象编程01_圆面积求解
- C# 中直接调用js方法
- oracle11g的内存分配不当,导致的错误ORA-01034,ORA-00838,ORA-27101
- SSD中的GC机制以及Trim
- 为Python添加中文关键字
- map和unordered_map的差别和使用
- Oracle 18C DBCA建库报ora-01012错误
- Java Base64 加密/解密
- 20155321 《网络攻防》 Exp7 网络欺诈防范
- 如何解决python连接数据库编码问题(python传数据到mysql乱码)'ascii' codec can't encode _mysql_exceptions.OperationalError: (1366, ";Incorrect string value:?
热门文章
- 使用SQL Profile及SQL Tuning Advisor固定运行计划
- wikioi 1029 中序遍历总数
- ganglia收集hbase的metrics
- xcode 4.5 new feature __ ios6 新特性
- js上传文件
- &;quot;未能载入文件或程序集“XXX”或它的某一个依赖项。系统找不到指定的文件&;quot;的解决方式
- java(JSP)中几种获取项目路径方式
- iOS 中删除cookie的正确做法
- cf 749D Leaving Auction
- django 菜单权限