全国高分辨率土地利用数据服务 土地利用数据服务 土地覆盖数据服务 坡度数据服务 土壤侵蚀数据服务 全国各省市DEM数据服务 耕地资源空间分布数据服务 草地资源空间分布数据服务 林地资源空间分布数据服务 水域资源空间分布数据服务 建设用地空间分布数据服务 地形、地貌、土壤数据服务 分坡度耕地数据服务 全国大宗农作物种植范围空间分布数据服务
多种卫星遥感数据反演植被覆盖度数据服务 地表反照率数据服务 比辐射率数据服务 地表温度数据服务 地表蒸腾与蒸散数据服务 归一化植被指数数据服务 叶面积指数数据服务 净初级生产力数据服务 净生态系统生产力数据服务 生态系统总初级生产力数据服务 生态系统类型分布数据服务 土壤类型质地养分数据服务 生态系统空间分布数据服务 增强型植被指数数据服务
多年平均气温空间分布数据服务 多年平均降水量空间分布数据服务 湿润指数数据服务 大于0℃积温空间分布数据服务 光合有效辐射分量数据服务 显热/潜热信息数据服务 波文比信息数据服务 地表净辐射通量数据服务 光合有效辐射数据服务 温度带分区数据服务 山区小气候因子精细数据服务
全国夜间灯光指数数据服务 全国GDP公里格网数据服务 全国建筑物总面积公里格网数据服务 全国人口密度数据服务 全国县级医院分布数据服务 人口调查空间分布数据服务 收入统计空间分布数据服务 矿山面积统计及分布数据服务 载畜量及空间分布数据服务 农作物种植面积统计数据服务 农田分类面积统计数据服务 农作物长势遥感监测数据服务 医疗资源统计数据服务 教育资源统计数据服务 行政辖区信息数据服务
Landsat 8 高分二号 高分一号 SPOT-6卫星影像 法国Pleiades高分卫星 资源三号卫星 风云3号 中巴资源卫星 NOAA/AVHRR MODIS Landsat TM 环境小卫星 Landsat MSS 天绘一号卫星影像
用户在类模块中实现Icommand(参见1.2.1)和ITool接口。ITool接口包括 mouse move, mouse button press/release, keyboard key press/release, double-click以及right click等事件、Cursor属性和Refresh方法。
本例要实现的是如何创建定制的Tool
要点
用户在类模块中实现Icommand(参见1.2.1)和ITool接口。ITool接口包括 mouse move, mouse button press/release, keyboard key press/release, double-click以及right click等事件、Cursor属性和Refresh方法。
Tool既具有Button的功能,又具有与ArcMAP界面交互的功能,Button的功能代码必须写在Icommand的OnClick事件中,而所有实现交互功能的代码必须写在Itool接口的各个事件中。Itool接口的各个事件,用户可以在其中写入相关代码,表示用户与ArcMAP界面交互时一旦触发某事件要实现的功能。
l 程序说明
程序在类模块中实现Icommand和Itool接口来创建自己的Tool.
l 代码
Option Explicit
'实现Icommand和Itool接口
Implements ICommand
Implements ITool
Dim m_pApplication As IApplication
Dim m_pBitmap As IPictureDisp
Dim m_pCursor As IpictureDisp
Private Sub Class_Initialize()
Set m_pBitmap = LoadResPicture(101, 0)
'从.RES文件中调入ID为102的图片作为按下Tool后的MouseCursor
Set m_pCursor = LoadResPicture(102, 2)
End Sub
Private Property Get ICommand_Bitmap() As esriCore.OLE_HANDLE
ICommand_Bitmap = m_pBitmap
End Property
Private Property Get ICommand_Caption() As String
ICommand_Caption = "MyTool"
End Property
Private Property Get ICommand_Category() As String
ICommand_Category = "MyCustomTools"
End Property
Private Property Get ICommand_Checked() As Boolean
End Property
Private Property Get ICommand_Enabled() As Boolean
ICommand_Enabled = True
End Property
Private Property Get ICommand_HelpContextID() As Long
End Property
Private Property Get ICommand_HelpFile() As String
End Property
Private Property Get ICommand_Message() As String
ICommand_Message = "This is my custom tool"
End Property
Private Property Get ICommand_Name() As String
ICommand_Name = "MyCustomTool_MyTool"
End Property
Private Sub ICommand_OnClick()
'加入按下按钮时实现的功能代码
MsgBox "Clicked on my command"
End Sub
Private Sub ICommand_OnCreate(ByVal hook As Object)
'获取ArcMAP的Application实例
Set m_pApplication = hook
End Sub
Private Property Get ICommand_Tooltip() As String
ICommand_Tooltip = "MyTool"
End Property
Private Property Get ITool_Cursor() As esriCore.OLE_HANDLE
ITool_Cursor = m_pCursor
End Property
Private Function ITool_Deactivate() As Boolean
'如果ITool_Deactivate设为False,则Tool不可用
ITool_Deactivate = True
End Function
Private Function ITool_OnContextMenu(ByVal X As Long, ByVal Y As Long) As Boolean
'在这里可以加入用户代码,点击Mouse右键时显示一个定制的context menu
End Function
Private Sub ITool_OnDblClick()
'在这里加入Mouse双击时的功能代码
End Sub
Private Sub ITool_OnKeyDown(ByVal keyCode As Long, ByVal Shift As Long)
End Sub
Private Sub ITool_OnKeyUp(ByVal keyCode As Long, ByVal Shift As Long)
End Sub
Private Sub ITool_OnMouseDown(ByVal Button As Long, ByVal Shift As Long, _
ByVal X As Long, ByVal Y As Long)
'加入Mouse单击时的功能代码
If Button = 1 Then
Dim pPoint As IPoint
Dim pMxApplication As IMxApplication
Set pMxApplication = m_pApp
Set pPoint=pMxApplication.Display.DisplayTransformation.ToMapPoint(X, Y)
m_pApplication.StatusBar.Message(0) = Str(pPoint.X) & "," & Str(pPoint.Y)
End If
End Sub
Private Sub ITool_OnMouseMove(ByVal Button As Long, ByVal Shift As Long, _
ByVal X As Long, ByVal Y As Long)
'加入Mouse移动时的功能代码
m_pApplication.StatusBar.Message(0) = "ITool_OnMouseMove"
End Sub
Private Sub ITool_OnMouseUp(ByVal Button As Long, ByVal Shift As Long, _
ByVal X As Long, ByVal Y As Long)
'加入释放Mouse时的功能代码
m_pApplication.StatusBar.Message(0) = "ITool_OnMouseUp"
End Sub
Private Sub ITool_Refresh(ByVal hDC As esriCore.OLE_HANDLE)
End Sub
Private Property Get ICommand_Name() As String
ICommand_Name = "MyCustomTool_MyTool"
End Property
Private Sub ICommand_OnClick()
'加入按下按钮时实现的功能代码
MsgBox "Clicked on my command"
End Sub
Private Sub ICommand_OnCreate(ByVal hook As Object)
'获取ArcMAP的Application实例
Set m_pApplication = hook
End Sub
Private Property Get ICommand_Tooltip() As String
ICommand_Tooltip = "MyTool"
End Property
Private Property Get ITool_Cursor() As esriCore.OLE_HANDLE
ITool_Cursor = m_pCursor
End Property
Private Function ITool_Deactivate() As Boolean
'如果ITool_Deactivate设为False,则Tool不可用
ITool_Deactivate = True
End Function
Private Function ITool_OnContextMenu(ByVal X As Long, ByVal Y As Long) As Boolean
'在这里可以加入用户代码,点击Mouse右键时显示一个定制的context menu
End Function
Private Sub ITool_OnDblClick()
'在这里加入Mouse双击时的功能代码
End Sub
Private Sub ITool_OnKeyDown(ByVal keyCode As Long, ByVal Shift As Long)
End Sub
Private Sub ITool_OnKeyUp(ByVal keyCode As Long, ByVal Shift As Long)
End Sub
Private Sub ITool_OnMouseDown(ByVal Button As Long, ByVal Shift As Long, _
ByVal X As Long, ByVal Y As Long)
'加入Mouse单击时的功能代码
If Button = 1 Then
Dim pPoint As IPoint
Dim pMxApplication As IMxApplication
Set pMxApplication = m_pApp
Set pPoint=pMxApplication.Display.DisplayTransformation.ToMapPoint(X, Y)
m_pApplication.StatusBar.Message(0) = Str(pPoint.X) & "," & Str(pPoint.Y)
End If
End Sub
Private Sub ITool_OnMouseMove(ByVal Button As Long, ByVal Shift As Long, _
ByVal X As Long, ByVal Y As Long)
'加入Mouse移动时的功能代码
m_pApplication.StatusBar.Message(0) = "ITool_OnMouseMove"
End Sub
Private Sub ITool_OnMouseUp(ByVal Button As Long, ByVal Shift As Long, _
ByVal X As Long, ByVal Y As Long)
'加入释放Mouse时的功能代码
m_pApplication.StatusBar.Message(0) = "ITool_OnMouseUp"
End Sub
Private Sub ITool_Refresh(ByVal hDC As esriCore.OLE_HANDLE)
End Sub