[ObjectARX]-创建多边形网格

完整的实现代码:

static void AAAMyGroupMyCommand () {
		// Put your command code here

		acutPrintf(_T("\nHello World!"));

		//创建一个简单的多边形网格
		AcGePoint3dArray ptArr;
		ptArr.setLogicalLength(8);
		for (int i = 0; i < 8; i++) //在X-Y平面上产生8个点
		{
			ptArr[i].set((double)(i / 2), (double)(i % 2), 0.0);

		}

		//默认构造函数。构造一个带有线型生成off的开放折线,并初始化开始和结束宽度到0.0,凸起到0.0,仰角到0.0,类型到AcDb::k2dSimplePoly,法线到(0,0,1),厚度到0.0。
		AcDb2dPolyline *pNewPline = new AcDb2dPolyline(AcDb::k2dSimplePoly, ptArr, 0.0, Adesk::kTrue);
		pNewPline->setColorIndex(100);

		//没有任何参数的多边形网格构造函数
		AcDbPolygonMesh *pMesh = new AcDbPolygonMesh();
		pMesh->setMSize(2);  //设置多边形在M方向上的顶点数为2
		pMesh->setNSize(8);  //设置多边形在N方向上的顶点数为8
		pMesh->makeMClosed();  //这个函数设置多边形在M方向上闭合。
		pMesh->makeNClosed();  //这个函数设置多边形在N方向上闭合。

		AcDbVoidPtrArray arr;
		arr.append(pMesh);

		//获得指向块表的指针
		AcDbBlockTable *pBlockTable;
		acdbHostApplicationServices()->workingDatabase()->getSymbolTable(pBlockTable, AcDb::kForRead);

		//获得指向块表记录(模型空间)的指针
		AcDbBlockTableRecord *pBlockTableRecord;
		pBlockTable->getAt(ACDB_MODEL_SPACE, pBlockTableRecord, AcDb::kForWrite);
		pBlockTable->close();

		AcDbObjectId plineObjId;
		//将pNewPline添加到数据库和块表记录中。如果操作成功,则将plineObjId设置为新添加实体的AcDbObjectId。
		pBlockTableRecord->appendAcDbEntity(plineObjId, pNewPline);

		AcDbObjectIterator *pVertIter = pNewPline->vertexIterator();//创建一个新的AcDbObjectIterator集,用于在折线的顶点上迭代
		AcDb2dVertex *pVertex;
		AcGePoint3d location;
		AcDbObjectId vertexObjId;
		for (int vertexNumber = 0; !pVertIter->done(); vertexNumber++, pVertIter->step())
		{
			vertexObjId = pVertIter->objectId();
			acdbOpenObject(pVertex, vertexObjId, AcDb::kForRead);//指向打开对象的输出指针pVertex,输入要打开对象的对象ID:vertexObjId
			location = pVertex->position();
			pVertex->close();

			//AcDbPolygonMeshVertex类表示AutoCAD中多边形网格内的顶点。
			AcDbPolygonMeshVertex* polyVertex = new AcDbPolygonMeshVertex(pVertex->position());
			pMesh->appendVertex(polyVertex);
			polyVertex->close();
		}
		delete pVertIter;

		pBlockTableRecord->appendAcDbEntity(pMesh);
		pBlockTableRecord->close();
		pNewPline->close();
		pMesh->close();

		acutPrintf(_T("\nHello World2!"));
	}

效果:

参考文献:

Creating a simple Polygon Mesh 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值