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);

第一个函数和第二个函数是行的序号 三个和第四个是列的序号

最新文章

  1. IIS7.0发布Web服务-0001
  2. Android应用第一次安装成功点击“打开”后Home键切出应用后再点击桌面图标返回导致应用重启问题
  3. 无忧之道:Docker中容器的备份、恢复和迁移
  4. SSH协议及其应用
  5. [杂]SQL Server 之 Understanding Connection Pooling and Transactions
  6. php中的require() 语句的使用方法
  7. session与cookie的区别,有哪些不同之处
  8. ROW_NUMBER分页的注意事项
  9. You and your research
  10. 两种MD5最后的值不一样,因为两种做法不一样
  11. C++基础——C面向过程与C++面向对象编程01_圆面积求解
  12. C# 中直接调用js方法
  13. oracle11g的内存分配不当,导致的错误ORA-01034,ORA-00838,ORA-27101
  14. SSD中的GC机制以及Trim
  15. 为Python添加中文关键字
  16. map和unordered_map的差别和使用
  17. Oracle 18C DBCA建库报ora-01012错误
  18. Java Base64 加密/解密
  19. 20155321 《网络攻防》 Exp7 网络欺诈防范
  20. 如何解决python连接数据库编码问题(python传数据到mysql乱码)'ascii' codec can't encode _mysql_exceptions.OperationalError: (1366, "Incorrect string value:?

热门文章

  1. 使用SQL Profile及SQL Tuning Advisor固定运行计划
  2. wikioi 1029 中序遍历总数
  3. ganglia收集hbase的metrics
  4. xcode 4.5 new feature __ ios6 新特性
  5. js上传文件
  6. "未能载入文件或程序集“XXX”或它的某一个依赖项。系统找不到指定的文件"的解决方式
  7. java(JSP)中几种获取项目路径方式
  8. iOS 中删除cookie的正确做法
  9. cf 749D Leaving Auction
  10. django 菜单权限