ArcGIS Pro SDK (八)地理数据库 3 数据

ArcGIS Pro SDK (八)地理数据库 3 数据

文章目录

  • [ArcGIS Pro SDK (八)地理数据库 3 数据](#ArcGIS Pro SDK (八)地理数据库 3 数据)
    • [1 从地理数据库打开数据集](#1 从地理数据库打开数据集)
    • [2 检查表是否存在](#2 检查表是否存在)
    • [3 检查要素类是否存在](#3 检查要素类是否存在)
    • [4 打开关系两个表之间的类](#4 打开关系两个表之间的类)
    • [5 从关系类获取相关要素类](#5 从关系类获取相关要素类)
    • [6 从 shapefile 数据存储打开要素类](#6 从 shapefile 数据存储打开要素类)
    • [7 打开 CAD 数据存储](#7 打开 CAD 数据存储)

环境:Visual Studio 2022 + .NET6 + ArcGIS Pro SDK 3.0

1 从地理数据库打开数据集

csharp 复制代码
public async Task OpeningDatasetsFromGeodatabase()
{
    await ArcGIS.Desktop.Framework.Threading.Tasks.QueuedTask.Run(
        () =>
        {
            using (Geodatabase geodatabase = new Geodatabase(new DatabaseConnectionFile(new Uri("path\\to\\sde\\file\\sdefile.sde"))))
            {
                using (Table table = 
                       geodatabase.OpenDataset<Table>("LocalGovernment.GDB.EmployeeInfo"))
                {
                }

                // 打开一个要素类(在要素数据集内或要素数据集外)。
                using (FeatureClass featureClass = 
                       geodatabase.OpenDataset<FeatureClass>("LocalGovernment.GDB.AddressPoint"))
                {
                }

                // 你可以将要素类作为表打开,这将为你提供一个表引用。
                using (Table featureClassAsTable = geodatabase.OpenDataset<Table>("LocalGovernment.GDB.AddressPoint"))
                {
                    // 但它实际上是一个要素类对象。
                    FeatureClass featureClassOpenedAsTable = featureClassAsTable as FeatureClass;
                }

                // 打开一个要素数据集。
                using (FeatureDataset featureDataset = geodatabase.OpenDataset<FeatureDataset>("LocalGovernment.GDB.Address"))
                {
                }

                // 打开一个关系类。就像你可以将要素类作为表打开一样,你也可以将带有属性的关系类作为关系类打开。
                using (RelationshipClass relationshipClass = geodatabase.OpenDataset<RelationshipClass>("LocalGovernment.GDB.AddressPointHasSiteAddresses"))
                {
                }
            }
        });
}

2 检查表是否存在

csharp 复制代码
// 必须在 QueuedTask.Run() 中调用
public bool TableExists(Geodatabase geodatabase, string tableName)
{
    try
    {
        TableDefinition tableDefinition = geodatabase.GetDefinition<TableDefinition>(tableName);
        tableDefinition.Dispose();
        return true;
    }
    catch
    {
        // 如果定义不存在,GetDefinition 会抛出异常
        return false;
    }
}

3 检查要素类是否存在

csharp 复制代码
// 必须在 QueuedTask.Run() 中调用
public bool FeatureClassExists(Geodatabase geodatabase, string featureClassName)
{
    try
    {
        FeatureClassDefinition featureClassDefinition = geodatabase.GetDefinition<FeatureClassDefinition>(featureClassName);
        featureClassDefinition.Dispose();
        return true;
    }
    catch
    {
        // 如果定义不存在,GetDefinition 会抛出异常
        return false;
    }
}

4 打开关系两个表之间的类

csharp 复制代码
// 必须在 QueuedTask.Run() 中调用。 
// 当与文件或企业级地理数据库一起使用时,此例程需要两个表名。
// 当与要素服务一起使用时,此例程需要图层 ID 或服务中暴露的表的名称(例如 "L0States")。
public IReadOnlyList<RelationshipClass> OpenRelationshipClassFeatureServices(Geodatabase geodatabase, string originClass, string destinationClass)
{
    return geodatabase.OpenRelationshipClasses(originClass, destinationClass);
}

5 从关系类获取相关要素类

csharp 复制代码
public async Task GetFeatureClassesInRelationshipClassAsync()
{
    await ArcGIS.Desktop.Framework.Threading.Tasks.QueuedTask.Run(
        () =>
        {
            using (Geodatabase geodatabase = new Geodatabase(new FileGeodatabaseConnectionPath(new Uri(@"C:\Data\LocalGovernment.gdb"))))
            {
                IReadOnlyList<RelationshipClassDefinition> relationshipClassDefinitions = 
                    geodatabase.GetDefinitions<RelationshipClassDefinition>();

                foreach (var relationshipClassDefinition in relationshipClassDefinitions)
                {
                    IReadOnlyList<Definition> definitions = 
                        geodatabase.GetRelatedDefinitions(relationshipClassDefinition,
                                                          DefinitionRelationshipType.DatasetsRelatedThrough);

                    foreach (var definition in definitions)
                    {
                        System.Diagnostics.Debug.WriteLine(
                            $"关系类中的要素类是:{definition.GetName()}");
                    }
                }
            }
        });
}

6 从 shapefile 数据存储打开要素类

csharp 复制代码
public async Task OpenShapefileFeatureClass()
{
    await ArcGIS.Desktop.Framework.Threading.Tasks.QueuedTask.Run(
        () =>
        {
            var fileConnection = new FileSystemConnectionPath(new Uri("path\\to\\folder\\containing\\shapefiles"), FileSystemDatastoreType.Shapefile);
            using (FileSystemDatastore shapefile = new FileSystemDatastore(fileConnection))
            {
                FeatureClass taxLotsFeatureClass = shapefile.OpenDataset<FeatureClass>("TaxLots");
                FeatureClass manHolesFeatureClass = shapefile.OpenDataset<FeatureClass>("ManHoles.shp"); // 可以使用 .shp 扩展名,但不是必需的。
                Table taxDetailsTableWithoutExtension = shapefile.OpenDataset<Table>("TaxDetails");
                Table taxDetailsTable = shapefile.OpenDataset<Table>("TaxDetails.dbf");
            }
        });
}

7 打开 CAD 数据存储

csharp 复制代码
public async Task OpenCADFeatureClass()
{
    await ArcGIS.Desktop.Framework.Threading.Tasks.QueuedTask.Run(
        () =>
        {
            var fileConnection = new FileSystemConnectionPath(new Uri("path\\to\\folder\\containing\\CAD"), FileSystemDatastoreType.Cad);
            using (FileSystemDatastore cadDatastore = new FileSystemDatastore(fileConnection))
            {
                // 注意 - 扩展名是必需的
                var cadDataset = cadDatastore.OpenDataset<FeatureClass>("hatchplayboundaries.dwg");
                // 注意引用要素类的模式。
                var cadfeatureClass = cadDatastore.OpenDataset<FeatureClass>("hatchplayboundaries.dwg:Polyline");

                int numRows = 0;
                using (var cursor = cadfeatureClass.Search())
                {
                    while (cursor.MoveNext())
                        numRows++;
                }
            }
        });
}
相关推荐
向宇it9 小时前
【unity小技巧】unity 什么是反射?反射的作用?反射的使用场景?反射的缺点?常用的反射操作?反射常见示例
开发语言·游戏·unity·c#·游戏引擎
九鼎科技-Leo10 小时前
什么是 WPF 中的依赖属性?有什么作用?
windows·c#·.net·wpf
Heaphaestus,RC11 小时前
【Unity3D】获取 GameObject 的完整层级结构
unity·c#
baivfhpwxf202311 小时前
C# 5000 转16进制 字节(激光器串口通讯生成指定格式命令)
开发语言·c#
直裾11 小时前
Scala全文单词统计
开发语言·c#·scala
GIS思维11 小时前
ArcGIS定义投影与投影的区别(数据和底图不套合的原因和解决办法)
arcgis·gis·地理信息·arcgis坐标系·动态投影
ZwaterZ13 小时前
vue el-table表格点击某行触发事件&&操作栏点击和row-click冲突问题
前端·vue.js·elementui·c#·vue
阮少年、15 小时前
ArcGIS Pro的arpx项目在ArcGIS Server中发布要素服务(FeatureServer)
arcgis·arcgis server·gis服务发布·要素服务
ZwaterZ15 小时前
el-table-column自动生成序号&&在序号前插入图标
前端·javascript·c#·vue
SRC_BLUE_1718 小时前
SQLI LABS | Less-55 GET-Challenge-Union-14 Queries Allowed-Variation 2
oracle·c#·less