frmFileGDB.vb
' Copyright 2010 ESRI ' ' All rights reserved under the copyright laws of the United States ' and applicable international laws, treaties, and conventions. ' ' You may freely redistribute and use this sample code, with or ' without modification, provided you include the original copyright ' notice and use restrictions. ' ' See the use restrictions. ' Imports Microsoft.VisualBasic Imports System Imports System.Linq Imports System.Windows.Forms Imports ESRI.ArcGISExplorer.Data Imports ESRI.ArcGISExplorer.Mapping Partial Public Class frmFileGDB Inherits Form Public Sub New() InitializeComponent() End Sub Private Sub btnBrowse_Click(ByVal sender As Object, ByVal e As EventArgs) Handles btnBrowse.Click 'Routine for adding shapefile data to the map. Begin by browsing for the data. Dim fdlg As FolderBrowserDialog = New FolderBrowserDialog() fdlg.ShowNewFolderButton = False fdlg.Description = "Find File Geodatabase" 'If a shapefile is found, then create a FeatureLayer based on it, add symbology, 'add the data to the map, and then zoom in. If fdlg.ShowDialog() = System.Windows.Forms.DialogResult.OK Then txtDatabase.Text = fdlg.SelectedPath End If End Sub Private Sub btnFind_Click(ByVal sender As Object, ByVal e As EventArgs) Handles btnFind.Click If txtDatabase.Text = "" Then MessageBox.Show("You need to specify a database!!", "No Database", MessageBoxButtons.OK) Return End If 'If we have a database, then try to connect to it Dim fileGDB As Geodatabase = Nothing Try fileGDB = New Geodatabase(txtDatabase.Text) Catch e1 As Exception MessageBox.Show("Could not connect to database!!", "Could not connect", MessageBoxButtons.OK) Return End Try If fileGDB Is Nothing Then MessageBox.Show("Could not connect to database!!", "Could not connect", MessageBoxButtons.OK) Return End If 'if we are this far, then we've connected and we need to create a tree view of the feature classes tvwFeatureClasses.Nodes.Clear() 'Add the Geodatabase Folders (Feature Datasets) and their contents first For Each folder As GeodatabaseFolder In fileGDB.GetGeodatabaseFolders() Dim folderNode As TreeNode = tvwFeatureClasses.Nodes.Add(folder.Name, folder.Name) For Each table As Table In folder.GetTables() folderNode.Nodes.Add(table.Name, table.Name) Next table Next folder 'Add standalone tables second For Each table2 As Table In fileGDB.GetTables(TableDiscoveryOptions.Spatial, False) tvwFeatureClasses.Nodes.Add(table2.Name, table2.Name) Next table2 End Sub Private Sub btnCancel_Click(ByVal sender As Object, ByVal e As EventArgs) Handles btnCancel.Click Me.Close() End Sub Private Sub btnOK_Click(ByVal sender As Object, ByVal e As EventArgs) Handles btnOK.Click If tvwFeatureClasses.Nodes.Count = 0 Then MessageBox.Show("Nothing to add!!", "no data", MessageBoxButtons.OK) Return End If If tvwFeatureClasses.SelectedNode Is Nothing Then MessageBox.Show("Please select a table in the list!", "no data", MessageBoxButtons.OK) Return End If 'If we have a selection from the tree view, then we are ready to add it to the map Dim dataSrcProps As DataSourceProperties = New DataSourceProperties(txtDatabase.Text, tvwFeatureClasses.SelectedNode.Text) Dim fLayer As FeatureLayer = New FeatureLayer(dataSrcProps) fLayer.Connect() If Not fLayer Is Nothing Then If fLayer.Name <> "" Then 'if we've created a layer, then add it to the map contents collection and zoom Dim mapDisp As MapDisplay = ESRI.ArcGISExplorer.Application.Application.ActiveMapDisplay mapDisp.Map.ChildItems.Add(fLayer) mapDisp.ZoomTo(fLayer.Extent) End If End If 'close the form Me.Close() End Sub Private Sub tvwFeatureClasses_AfterSelect(ByVal sender As Object, ByVal e As TreeViewEventArgs) Handles tvwFeatureClasses.AfterSelect If Not tvwFeatureClasses.SelectedNode Is Nothing Then btnOK.Enabled = True Else btnOK.Enabled = False End If End Sub End Class