全国高分辨率土地利用数据服务 土地利用数据服务 土地覆盖数据服务 坡度数据服务 土壤侵蚀数据服务 全国各省市DEM数据服务 耕地资源空间分布数据服务 草地资源空间分布数据服务 林地资源空间分布数据服务 水域资源空间分布数据服务 建设用地空间分布数据服务 地形、地貌、土壤数据服务 分坡度耕地数据服务 全国大宗农作物种植范围空间分布数据服务
多种卫星遥感数据反演植被覆盖度数据服务 地表反照率数据服务 比辐射率数据服务 地表温度数据服务 地表蒸腾与蒸散数据服务 归一化植被指数数据服务 叶面积指数数据服务 净初级生产力数据服务 净生态系统生产力数据服务 生态系统总初级生产力数据服务 生态系统类型分布数据服务 土壤类型质地养分数据服务 生态系统空间分布数据服务 增强型植被指数数据服务
多年平均气温空间分布数据服务 多年平均降水量空间分布数据服务 湿润指数数据服务 大于0℃积温空间分布数据服务 光合有效辐射分量数据服务 显热/潜热信息数据服务 波文比信息数据服务 地表净辐射通量数据服务 光合有效辐射数据服务 温度带分区数据服务 山区小气候因子精细数据服务
全国夜间灯光指数数据服务 全国GDP公里格网数据服务 全国建筑物总面积公里格网数据服务 全国人口密度数据服务 全国县级医院分布数据服务 人口调查空间分布数据服务 收入统计空间分布数据服务 矿山面积统计及分布数据服务 载畜量及空间分布数据服务 农作物种植面积统计数据服务 农田分类面积统计数据服务 农作物长势遥感监测数据服务 医疗资源统计数据服务 教育资源统计数据服务 行政辖区信息数据服务
Landsat 8 高分二号 高分一号 SPOT-6卫星影像 法国Pleiades高分卫星 资源三号卫星 风云3号 中巴资源卫星 NOAA/AVHRR MODIS Landsat TM 环境小卫星 Landsat MSS 天绘一号卫星影像
在上一节中我们实现了一个简单的显示地图的程序。下面我们在它的基础上完善和添加以下新的功能:
1.当框架窗口大小更改时改变地图控件窗口使之随框架窗口增大。
2.增加地图漫游功能:移动、放大、缩小、显示全图
一、更改项目配置、添加引入库代码
在本节中我们将使用AO提供的一些接口,所以需要更改项目配置,以及添加引用AO库的代码。
首先打开上一节所建项目。选择菜单Tools->Options->Directories页在Include files里添加两个路径(如果你的ArcGIS的安装目录在其它盘,需做相应改动):
C:\PROGRAM FILES\ARCGIS\COM
C:\PROGRAM FILES\ARCGIS\BIN
在项目的StdAfx.h中添加如下代码:
// AO引入库
#pragma warning(push)
#pragma warning(disable: 4192)
#pragma warning(disable: 4146)
#import "esriSystem.olb" raw_interfaces_only raw_native_types no_namespace named_guids exclude("OLE_COLOR", "OLE_HANDLE", "VARTYPE", "IStatusBar")
#import "esriSystemUI.olb" raw_interfaces_only, raw_native_types, no_namespace, named_guids exclude("IProgressDialog")
#import "esriGeometry.olb" raw_interfaces_only raw_native_types no_namespace named_guids
#import "esriDisplay.olb" raw_interfaces_only raw_native_types no_namespace named_guids
#import "esriGeoDatabase.olb" raw_interfaces_only raw_native_types no_namespace named_guids
#import "esriCarto.olb" raw_interfaces_only, raw_native_types, no_namespace, named_guids
#import "esriDataSourcesFile.olb" raw_interfaces_only raw_native_types no_namespace named_guids exclude("OLE_COLOR", "OLE_HANDLE")
#import "esriDataSourcesGDB.olb" raw_interfaces_only raw_native_types no_namespace named_guids exclude("OLE_COLOR", "OLE_HANDLE")
#import "ToolbarControl.ocx" raw_interfaces_only raw_native_types no_namespace named_guids
#import "TOCControl.ocx" raw_interfaces_only raw_native_types no_namespace named_guids
#import "MapControl.ocx" raw_interfaces_only raw_native_types no_namespace named_guids
#import "PageLayoutControl.ocx" raw_interfaces_only raw_native_types no_namespace named_guids
#import "ArcReaderControl.ocx" raw_interfaces_only raw_native_types no_namespace named_guids
#pragma warning(pop)
二、添加地图浏览功能,完善地图窗口缩放
1、使MapControl随窗口放大
首先为CAOExStep1View添加一个保护类型的成员变量:
IMapControl3Ptr m_ipMapControl; // 地图控件
该变量保存指向MapContrl的接口指针。然后在类CAOExStep1View的成员函数OnInitialUpdate添加如下代码初始化它(红色部分):
void CAOExStep1View::OnInitialUpdate()
{
…// 此处省略其它代码
// 获取MapControl指针
m_ipMapControl = GetDlgItem(IDC_MAPCONTROL1)->GetControlUnknown();
}
为类CAOExStep1View添加窗口改变大小事件函数,并在里面添加如下代码(红色部分):
void CAOExStep1View::OnSize(UINT nType, int cx, int cy)
{
CFormView::OnSize(nType, cx, cy);
// View窗口改变大小时改变MapControl大小
if(m_ipMapControl!=NULL)
{
CRect rc;
GetClientRect(rc);
GetDlgItem(IDC_MAPCONTROL1)->MoveWindow(rc);
}
}
经过上面的修改,现在重新编译程序,把窗口最大化,你会看到地图窗口随之放大。
2、接下来我们来添加地图漫游功能
首先把项目默认的工具栏按钮全部删除只留下关于按钮。然后添加5个按钮,按钮ID和提示文本如下,按钮的图标可以使用ArcGIS的相应功能的图标(ArcGIS的一些图标保存在按照目录的Bin\Icons\下面,是一系列bmp文件)。
ID_MAP_ARROW "选择状态\n选择状态"
ID_MAP_PAN "地图平移\n地图平移"
ID_MAP_ZOOMIN "地图放大\n地图放大"
ID_MAP_ZOOMOUT "地图缩小\n地图缩小"
ID_MAP_FULLEXTENT "显示全图\n显示全图"
为了处理鼠标事件我们需要为MapControl添加一个onMouseDown事件函数,在类CAOExStep1View里添加上面添加的工具栏按钮的响应函数,另外我们还需要在类CAOExStep1View头文件里添加一个标志当前鼠标操作状态的成员变量:
esriARTool m_ARTool; // 鼠标当前状态
在工具栏响应函数中添加如下代码(红色部分):
// 选择状态
void CAOExStep1View::OnMapArrow()
{
m_ARTool = esriARToolNoneSelected;
m_ipMapControl->put_MousePointer(esriPointerDefault);
}
// 地图平移
void CAOExStep1View::OnMapPan()
{
m_ARTool = esriARToolMapPan;
m_ipMapControl->put_MousePointer(esriPointerPan);
}
// 地图放大
void CAOExStep1View::OnMapZoomin()
{
m_ARTool = esriARToolMapZoomIn;
m_ipMapControl->put_MousePointer(esriPointerZoomIn);
}
// 地图缩小
void CAOExStep1View::OnMapZoomout()
{
m_ARTool = esriARToolMapZoomOut;
m_ipMapControl->put_MousePointer(esriPointerZoomOut);
}
// 显示全图
void CAOExStep1View::OnMapFullextent()
{
IActiveViewPtr ipActiveView;
HRESULT hr=m_ipMapControl->get_ActiveView(&ipActiveView);
if (FAILED(hr)) return;
IEnvelopePtr ipEnvelope;
hr = ipActiveView->get_FullExtent(&ipEnvelope);
if (FAILED(hr)) return;
ipActiveView->put_Extent(ipEnvelope);
ipActiveView->Refresh();
}