GDAL/OGR创建DXF文件中多图层的方法
2013-06-01 13:06
344 查看
在使用GDAL/OGR创建DXF,有时会将点、线、面数据分到到各自的图层中,或者同类别的要素、对象写到DXF文件中不同的图层。如下图:
有人认为新建多个OGRLayer就可以将类别分开,这种观点是错误的,OGRLayer和DXF中的图层不是一个概念。
在写DXF文件时,不支持创建多个ORGLayer图层,一个OGRDXFWriterDS对应一个OGRDXFWriterLayer在new OGRDXFWriterLayer时,OGRDXFWriterLayer构造函数中,会创建DXF标准字段也就是OGRFieldDefn,DXF不支持额外的新建字段:标准字段新建代码(在OGRDXFWriterLayer.cpp中第58-83行):
下面我们做个试验,看以下创建DXF图层的方法,代码如下:
有人认为新建多个OGRLayer就可以将类别分开,这种观点是错误的,OGRLayer和DXF中的图层不是一个概念。
在写DXF文件时,不支持创建多个ORGLayer图层,一个OGRDXFWriterDS对应一个OGRDXFWriterLayer在new OGRDXFWriterLayer时,OGRDXFWriterLayer构造函数中,会创建DXF标准字段也就是OGRFieldDefn,DXF不支持额外的新建字段:标准字段新建代码(在OGRDXFWriterLayer.cpp中第58-83行):
// 图层字段,设置此字段,将要素分类到,所设置的图层中,不设置默认为0层 OGRFieldDefn oLayerField( "Layer", OFTString ); poFeatureDefn->AddFieldDefn( &oLayerField ); // 好像未被使用,不管它 OGRFieldDefn oClassField( "SubClasses", OFTString ); poFeatureDefn->AddFieldDefn( &oClassField ); // 好像未被使用,也不管它 OGRFieldDefn oExtendedField( "ExtendedEntity", OFTString ); poFeatureDefn->AddFieldDefn( &oExtendedField ); // 线类型字段 OGRFieldDefn oLinetypeField( "Linetype", OFTString ); poFeatureDefn->AddFieldDefn( &oLinetypeField ); // 好像未被使用,也不管它 OGRFieldDefn oEntityHandleField( "EntityHandle", OFTString ); poFeatureDefn->AddFieldDefn( &oEntityHandleField ); //文本字段 好像未被使用,也不管它 OGRFieldDefn oTextField( "Text", OFTString ); poFeatureDefn->AddFieldDefn( &oTextField ); // 块名称 写块时设置此字段 OGRFieldDefn oBlockField( "BlockName", OFTString ); poFeatureDefn->AddFieldDefn( &oBlockField ); // 块缩放 写块时设置此字段 OGRFieldDefn oScaleField( "BlockScale", OFTRealList ); poFeatureDefn->AddFieldDefn( &oScaleField ); // 块角度 写块时设置此字段 OGRFieldDefn oBlockAngleField( "BlockAngle", OFTReal ); poFeatureDefn->AddFieldDefn( &oBlockAngleField );
下面我们做个试验,看以下创建DXF图层的方法,代码如下:
#include "ogrsf_frmts.h" #include "stdio.h" #include <iostream> #include <string> using namespace std; int main() { const char *pszDriverName = "DXF"; OGRSFDriver *poDriver; RegisterOGRDXF(); poDriver = OGRSFDriverRegistrar::GetRegistrar()->GetDriverByName( pszDriverName ); if( poDriver == NULL ) { printf( "%s driver not available.\n", pszDriverName ); exit( 1 ); } OGRDataSource *poDS; // 模板文件名称,文件在GDAL中data下,拷贝到与cpp同目录下 // 也可以设置GDAL_DATA路径 // 按下设置,也可以设置一个正确的相对路径和绝对路径 char **papszOptions = (char **)CPLCalloc(sizeof(char *),3); papszOptions[0] = "HEADER=header.dxf"; papszOptions[1] = "TRAILER=trailer.dxf"; poDS = poDriver->CreateDataSource( "out.dxf", papszOptions ); CPLFree(papszOptions); if( poDS == NULL ) { printf( "Creation of output file failed.\n" ); exit( 1 ); } OGRLayer *poLayer; poLayer = poDS->CreateLayer( "hatch_out", NULL, wkbUnknown, NULL ); if( poLayer == NULL ) { printf( "Layer creation failed.\n" ); exit( 1 ); } OGRFeature *poFeature = OGRFeature::CreateFeature( poLayer->GetLayerDefn() ); // 生成一个正方形,放置在"正方形"图层 OGRLinearRing oSquare; oSquare.addPoint(0.0,0.0); oSquare.addPoint(1.0,0.0); oSquare.addPoint(1.0,1.0); oSquare.addPoint(0.0,1.0); oSquare.closeRings(); poFeature->SetField( "Layer", "正方形" ); poFeature->SetGeometry( &oSquare ); if( poLayer->CreateFeature( poFeature ) != OGRERR_NONE ) { printf( "Failed to create feature in dxffile.\n" ); exit( 1 ); } // 生成一个三角形,放置在"三角形"图层 poFeature = OGRFeature::CreateFeature( poLayer->GetLayerDefn() ); OGRLinearRing oTriangle; oTriangle.addPoint(2.0,2.0); oTriangle.addPoint(3.0,2.0); oTriangle.addPoint(3.0,3.0); oTriangle.closeRings(); poFeature->SetField( "Layer", "三角形" ); poFeature->SetGeometry( &oTriangle ); if( poLayer->CreateFeature( poFeature ) != OGRERR_NONE ) { printf( "Failed to create feature in dxffile.\n" ); exit( 1 ); } // 生成一个菱形,放置在"三角形"图层 poFeature = OGRFeature::CreateFeature( poLayer->GetLayerDefn() ); OGRLinearRing oRhombus; oRhombus.addPoint(4.0,3.0); oRhombus.addPoint(5.0,4.0); oRhombus.addPoint(4.0,5.0); oRhombus.addPoint(3.0,4.0); oRhombus.closeRings(); poFeature->SetField( "Layer", "三角形" ); poFeature->SetGeometry( &oRhombus ); if( poLayer->CreateFeature( poFeature ) != OGRERR_NONE ) { printf( "Failed to create feature in dxffile.\n" ); exit( 1 ); } // 生成一个多段线,不设置图层,将默认层 poFeature = OGRFeature::CreateFeature( poLayer->GetLayerDefn() ); OGRLinearRing oLinearRing; oLinearRing.addPoint(5.0,5.0); oLinearRing.addPoint(6.0,4.0); oLinearRing.addPoint(7.0,5.0); oLinearRing.addPoint(8.0,4.0); poFeature->SetGeometry( &oLinearRing ); if( poLayer->CreateFeature( poFeature ) != OGRERR_NONE ) { printf( "Failed to create feature in dxffile.\n" ); exit( 1 ); } OGRFeature::DestroyFeature( poFeature ); OGRDataSource::DestroyDataSource( poDS ); }
相关文章推荐
- 图层设置GDAL/OGR创建DXF文件中多图层的方法
- GDAL/OGR创建DXF文件中多图层的方法 .
- GDAL/OGR创建DXF文件中多图层的方法 .
- GDAL读写dxf文件中文乱码问题解决方法(二)
- C#用GDAL/OGR库创建与写Shape文件
- C#用GDAL/OGR库创建与写Shape文件(转载)
- GDAL写dxf文件中文乱码问题解决方法
- ubuntu创建、删除文件及文件夹,强制清空回收站方法
- 使用java 程序创建格式为utf-8文件的方法(写入和读取json文件)
- php获得文件大小和文件创建时间的方法
- 创建android项目时没有自动生成R.java文件的解决方法
- [转]linux创建链接文件的两种方法
- ubuntu创建、删除文件及文件夹,强制清空回收站方法
- Ubuntu下创建、重命名、删除文件及文件夹,强制清空回收站方法
- linux ln 创建文件链接使用方法
- c#创建xml读取xml方法并判断文件目录以及文件是否存在
- ios开发者创建app应用开发授权文件 实战方法
- 使用myeclispe或者sts工具,创建的myBatis的 xml文件不提示的问题解决方法
- 快速创建1万(任意)个文件或者文件夹并统计时间的方法