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++;
                }
            }
        });
}
相关推荐
pchmi39 分钟前
C# OpenCV机器视觉:红外体温检测
人工智能·数码相机·opencv·计算机视觉·c#·机器视觉·opencvsharp
m0_748248022 小时前
【MySQL】C# 连接MySQL
数据库·mysql·c#
鸿业远图科技2 小时前
【吉林乡镇界】面图层shp格式arcgis数据乡镇名称和编码wgs84无偏移内容测评
arcgis
oulaqiao5 小时前
语言集成查询LINQ
c#·linq
xcLeigh6 小时前
WPF实战案例 | C# WPF实现大学选课系统
开发语言·c#·wpf
one9966 小时前
.net 项目引用与 .NET Framework 项目引用之间的区别和相同
c#·.net·wpf
xcLeigh6 小时前
WPF基础 | WPF 布局系统深度剖析:从 Grid 到 StackPanel
c#·wpf
军训猫猫头16 小时前
52.this.DataContext = new UserViewModel(); C#例子 WPF例子
开发语言·c#·wpf
木偶☜19 小时前
Node.js接收文件分片数据并进行合并处理
服务器·javascript·arcgis·node.js