Query Features
QueryFeaturesButton.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.Collections.Generic
Imports System.ComponentModel
Imports System.Data
Imports System.Drawing
Imports System.Linq
Imports System.Text

Imports ESRI.ArcGISExplorer
Imports ESRI.ArcGISExplorer.Application
Imports ESRI.ArcGISExplorer.Mapping
Imports ESRI.ArcGISExplorer.Geometry
Imports ESRI.ArcGISExplorer.Data
Imports ESRI.ArcGISExplorer.Threading

''' <summary>
''' Implements a custom query features button
''' </summary>
''' <remarks>
''' Allows the user to digitize a polygon on the map, then uses
''' the resulting geometry to query the selected feature layer
''' and display the results in a DataGridView on a form.
''' The grid is populated by binding the query results using
''' a TableBindingAdapter.
''' </remarks>
Public Class QueryFeaturesButton
  Inherits ESRI.ArcGISExplorer.Application.Button
  ''' <summary>
  ''' Raised when the button is clicked on the ribbon
  ''' </summary>
  Public Overrides Sub OnClick()
    ' get the first selected item in the map. It's safe to assume the item is a
    ' feature layer because the declaration of this button in the AddIns.xml specifies
    ' the E3_FeatureLayerSelectedCondition condition
    Dim layer As FeatureLayer = TryCast(ESRI.ArcGISExplorer.Application.Application.SelectedItems(0), FeatureLayer)

    ' allow the user to digitize a polygon on the map
    Dim polygon As Polygon = ESRI.ArcGISExplorer.Application.Application.ActiveMapDisplay.TrackPolygon()
    Try


      ' query the feature layer for the features that intersect the polygon
      Dim rowCollection As RowCollection = layer.Table.Search(New Filter(polygon, FilterSearchOptions.Intersects))

      ' create the table binding adapter and fill it
      Dim tableBindingAdapter As TableBindingAdapter = New TableBindingAdapter(rowCollection)
      tableBindingAdapter.UseColumnAliasNames = True
      tableBindingAdapter.UseCodedValueDomains = True
      tableBindingAdapter.Fill()

      ' display the results
      Dim resultsForm As QueryResultsForm = New QueryResultsForm(tableBindingAdapter)
      resultsForm.ShowDialog()

    Catch ex As NullReferenceException
      System.Windows.Forms.MessageBox.Show("No features were selected. Please try again.")
    End Try
  End Sub
End Class