LayerSelectable.vb
' Copyright 2012 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 ESRI.ArcGIS.Carto Imports ESRI.ArcGIS.Controls Imports ESRI.ArcGIS.ADF.BaseClasses Imports ESRI.ArcGIS.SystemUI Public NotInheritable Class LayerSelectable Inherits BaseCommand Implements ICommandSubType Private m_pMapControl As IMapControl3 Private m_lSubType As Long Public Sub New() MyBase.New() End Sub Public Overrides Sub OnCreate(ByVal hook As Object) m_pMapControl = hook End Sub Public Overrides Sub OnClick() Dim pLayer As IFeatureLayer pLayer = m_pMapControl.CustomProperty If (m_lSubType = 1) Then pLayer.Selectable = True If (m_lSubType = 2) Then pLayer.Selectable = False End Sub Public Function GetCount() As Integer Implements ESRI.ArcGIS.SystemUI.ICommandSubType.GetCount Return 2 End Function Public Sub SetSubType(ByVal SubType As Integer) Implements ESRI.ArcGIS.SystemUI.ICommandSubType.SetSubType m_lSubType = SubType End Sub Public Overrides ReadOnly Property Enabled() As Boolean Get Dim pLayer As ILayer pLayer = m_pMapControl.CustomProperty If (TypeOf pLayer Is IFeatureLayer) Then Dim pFeatureLayer As IFeatureLayer pFeatureLayer = pLayer If (m_lSubType = 1) Then Return Not pFeatureLayer.Selectable If (m_lSubType = 2) Then Return pFeatureLayer.Selectable Else Return False End If End Get End Property Public Overrides ReadOnly Property Caption() As String Get If (m_lSubType = 1) Then Return "Layer Selectable" Else Return "Layer Unselectable" End If End Get End Property End Class