PIE-SDK For C++矢量数据的创建

1.功能简介

        GIS将地理空间数据表示为矢量数据和栅格数据。矢量数据模型使用点、线和多边形来表示具有清晰空间位置和边界的空间要素,如控制点、河流和宗地等,每个要素被赋予一个ID,以便与其属性相关联。栅格数据模型使用一个格网和格网元胞(像元)代表空间要素,元胞值表示该元胞位置的空间要素属性。栅格数据模型适用于表示连续的要素,如海拔和降水量。

[矢量数据模型]                                                                                                                   [栅格数据模型]

        PIE支持多种矢量数据的创建,下面对矢量数据格式的数据创建功能进行介绍。

2.功能实现说明

2.1 Shape数据介绍

        Shapefile是由ESRI开发后被广泛应用的数据格式,它采用文件的方式分开存储数据的控件信息和属性信息,但其不能存储拓扑关系,具有简单、快速显示的优点。一个Shape数据的文件结构如下所示:

[Shape数据文件结构]

编号

后缀

文件说明

1

.shp

基本文件,存储地理要素的几何图形信息;

2

.dbf

基本文件,存储地理要素的属性信息;

3

.shx

基本文件,存储图形要素与属性信息的索引;

4

.prj

可选文件,存储数据的空间参考信息;

5

.sbn/.sbx

可选文件,存储数据的空间索引信息(ESRI创建的空间索引);

6

.qix

可选文件,存储数据的空间索引信息(PIE创建的空间索引);

[Shape数据文件结构说明]

2.2 实现思路及原理说明

第一步

创建字段信息并添加值,创建空间参考,保存等

第二步

创建矢量要素数据集

2.3 核心接口与方法

接口/类

方法/属性

说明

SysDataSource::DatasetFactory

CreateFeatureDataset(…)

创建要素数据集

SysCarto::LayerFactory

CreateDefaultFeatureLayer(…)

创建矢量图层

SysGeometry::SpatialReferenceFactory

CreateSpatialReference(int Code)

创建空间参考

SysDataSource::Field

Name,AliasName,DefaultValue

字段属性

SysDataSource::Fields

AddField(IField ptrField)

添加字段

SysDataSource::Feature

SetValue(int nIndex, object field)

设置字段值

SysDataSource::FeatureDataset

AddFeature(IFeature ptrFeature)

添加要素

2.4示例代码

项目路径

百度云盘地址下/PIE示例程序/04数据操作/01.矢量数据的创建

视频路径

百度云盘地址下/PIE视频教程/04数据操作/01.矢量数据的创建.avi

示例代码

/** 创建矢量数据

* @brief

* @param[in] bool checked 是否选中

* @return

*/

void PIEMainWindow::On_ActionCreateShpFile_Triggered(bool checked)

{

    QString saveFilePath = QFileDialog::getSaveFileName(this, "选择存储路径", "../", "ShapeFile (*.shp)");

    if (saveFilePath.isEmpty())

    {

        return;

    }

    //1 建立字段

    SysDataSource::FieldsPtr fields = new SysDataSource::Fields();

    SysDataSource::FieldPtr name_Field = new SysDataSource::Field("name", SysDataSource::FieldType::OFTString, 20, 4);

    name_Field->SetAliasName("名称");

    //2 建立空间参考

    SysGeometry::SpatialReferencePtr spPtr = SysGeometry::SpatialReferenceFactory::CreateSpatialReference(4326);

    //3 创建矢量数据集

    SysDataSource::FeatureDatasetPtr featureDataSetPtr = SysDataSource::DatasetFactory::Instance()->CreateFeatureDataset(saveFilePath, fields,SysGeometry::GeometryType::GeometryPoint, spPtr, "Shape");

    if (featureDataSetPtr==nullptr)

    {

        return;

    }

    //4 写入要素

    SysDataSource::FeaturePtr newFeaturePtrA = featureDataSetPtr->CreateNewFeature();

    SysGeometry::PointPtr point = new SysGeometry::Point();

    point->SetX(116.4); point->SetY(39.9);

    newFeaturePtrA->SetGeometry(point);

    newFeaturePtrA->SetValue(0, "北京市");

    featureDataSetPtr->AddFeature(newFeaturePtrA);

 

    SysDataSource::FeaturePtr newFeaturePtrB = featureDataSetPtr->CreateNewFeature();

    SysGeometry::PointPtr pointB = new SysGeometry::Point();

    pointB->SetX(121.48); pointB->SetY(31.22);

    newFeaturePtrB->SetGeometry(pointB);

    newFeaturePtrB->SetValue(0, "上海市");

    featureDataSetPtr->AddFeature(newFeaturePtrB);

    //5 保存要素

    featureDataSetPtr->Save();

    featureDataSetPtr->CreateSpatialIndex();

    //6 创建图层

    SysCarto::LayerPtr layer = SysCarto::LayerFactory::Instance()->CreateDefaultFeatureLayer(featureDataSetPtr);

    if (layer!=nullptr)

    {

        m_pCurrentControl->GetMap()->AddLayer(layer);

        m_pCurrentControl->GetActiveView()->Refresh();

    }

}

2.5示例截图

   生成的shape文件,格式如下:

posted @ 2020-02-27 11:37  PIESAT  阅读(434)  评论(0编辑  收藏  举报