iOS8苹果地图开发实例

2016-7-21 14:44:08 0人评论 552次浏览 分类:技术文章

从苹果设备IOS6以后,苹果就不再使用旧版地图,而且自行开发了一款苹果全新的地图软件,但是API编程接口没有太大的变化。开发人员不需要再学习很多新东西就能开发地图应用。

iOS应用程序中使用Map Kit API开发地图应用程序。 其核心是MKMapView类使用。我们可以设置地图显示方式、控制地图,可以在地图上添加标注。

显示地图

在Map Kit API中显示地图的视图是MKMapView,它的委托协议是MKMapViewDelegate。Map Kit API使用需要导入MapKit框架。

下面我们通过一个案例介绍一下面我们介绍一下Map Kit API的使用。这个案例在“输入查询地点关键字”文本框中输入关键字,点击“查询”按钮,先进行地理信息编码查询,查询获得地标信息后,在地图上标注出来。

1

首先添加框架MapKit.framework。然后在工程中打开MainStoryboard.storyboard的IB设计,从对象库中拖拽Map View到设计画面中。

2

调整它的位置和大小使得Map View尽可能填出画面下面的空白部分,然后为Map View定义输入出口。下面我们看看主视图控制器ViewController.h代码:

  1. #import <UIKit/UIKit.h>  
  2.   
  3. #import <MapKit/MapKit.h>  
  4.   
  5. #import ”MapLocation.h”  
  6.   
  7.    
  8.   
  9. @interface ViewController : UIViewController <MKMapViewDelegate>  
  10.   
  11.    
  12.   
  13. @property (weak, nonatomic) IBOutlet UITextField *txtQueryKey;  
  14.   
  15.    
  16.   
  17. @property (weak, nonatomic) IBOutlet MKMapView *mapView;  
  18.   
  19.    
  20.   
  21. - (IBAction)geocodeQuery:(id)sender;  
  22.   
  23.    
  24.   
  25. @end  


由于使用Map Kit API,需要引入头文件<MapKit/MapKit.h>,头文件”MapLocation.h”是我们自己定义的描述地图标注点类。在定义ViewController时,还需要声明实现MKMapViewDelegate协议。txtQueryKey属性是查询关键字文本框,mapView属性是MKMapView类型,它与画面对应。点击查询按钮触发geocodeQuery:方法,它处理查询并在地图上做标注。

下面我看看ViewController.m的viewDidLoad方法代码:

  1. - (void)viewDidLoad  
  2.   
  3. {  
  4.   
  5. [super viewDidLoad];  
  6.   
  7. _mapView.mapType = MKMapTypeStandard;  
  8.   
  9. _mapView.delegate = self;  
  10.   
  11. }  


在viewDidLoad方法中设置地图的类型,它的类型有3种:

MKMapTypeStandard 标注地图类型。

MKMapTypeSatellite 卫星地图类型。在卫星地图中没有街道名称等信息;

MKMapTypeHybrid 混合地图类型。在混合地图是在卫星地图上标注出街道等信息;

3 4 5

viewDidLoad方法的_mapView.delegate = self语句是当前视图控制器赋值给地图视图的delegate属性,这样地图视图在需要的时候就会回调ViewController,如果失败,回调下面的失败方法:

  1. - (void)mapViewDidFailLoadingMap:(MKMapView *)theMapView withError:(NSError *)error {  
  2.   
  3. NSLog(@”error : %@”,[error description]);  
  4.   
  5. }  


跟踪用户位置变化

MapKit提供了跟踪用户位置和方向变化的API,我们不用自己编写定位服务代码。开启地图视图的showsUserLocation属性,并设置方法setUserTrackingMode:就可以了,代码如下:

  1. - (void)viewDidLoad  
  2.   
  3. {  
  4.   
  5. [super viewDidLoad];  
  6.   
  7. if ([CLLocationManager locationServicesEnabled])  
  8.   
  9. {  
  10.   
  11. _mapView.mapType = MKMapTypeStandard;  
  12.   
  13. _mapView.delegate = self;  
  14.   
  15. _mapView.showsUserLocation = YES;  
  16.   
  17. [_mapView setUserTrackingMode:MKUserTrackingModeFollow animated:YES];  
  18.   
  19. }  
  20.   
  21. }  


其中代码_mapView.showsUserLocation = YES,允许跟踪显示用户位置信息。在iOS设备中显示用户位置方式是一个发亮的蓝色小圆点。

7

[_mapView setUserTrackingMode:MKUserTrackingModeFollow animated:YES]语句设置用户跟踪模式,用户跟踪模式有3种:

MKUserTrackingModeNone 。没有用户跟踪模式;

MKUserTrackingModeFollow 。可以跟踪用户的位置变化;

MKUserTrackingModeFollowWithHeading 。可以跟踪用户的位置和方向变化;

然后,我们还需要实现地图视图委托方法mapView:didUpdateUserLocation:,它的代码如下:

  1. - (void)mapView:(MKMapView *)mapView didUpdateUserLocation:(MKUserLocation *)userLocation  
  2.   
  3. {  
  4.   
  5. _mapView.centerCoordinate = userLocation.location.coordinate;  
  6.   
  7. }  


该委托方法在定位服务更新完成用户位置时候回调该方法,我们在该方法中重新调整地图的中心点为当前用户的中心点,其中_mapView.centerCoordinate = userLocation.location.coordinate语句就是实现该目的。

这几行代码就可以跟踪用户位置的变化了,但是为了这样一个小的案例拿着iPhone在外面跑一圈进行测试没有必要。可以使用模拟器测试,模拟器有几个固定的模式可以发出连续变化的数据。测试运行在画面中会有一个小圆圈,它按照我们设定的速度一直运行。

8

附件下载

相关资讯

  • Autodesk 3ds Max 2012 安装破解图文教程

    用万地图下载器下载的谷歌地球高程数据,除了可以在电力、水利、通信、石油、国土、农业、林业、环保、环评、矿山、海洋、物探、规划设计、数字城市、道路勘测等GIS行业中使用外,还可以用于在3DS Max中制作三维地形图。Autodesk 3ds Max 2012 安装包请从以下地址下载:http:/…

    2017-11-24 13:53:37
  • 初识地图发布中间件

    如果需要发布海量影像数据快速构建全国离线二维GIS地理信息系统或全球离线三维地球触摸GIS系统,则需要由硬件、软件、数据和GIS平台四部分组成。

    2017-11-14 11:09:17
  • 中间件的项目应用案例 ——《金风科技全球监控中心》

    《水经注地图发布服务中间件》适合所有需要构建全国或全球地图数据服务器并发布海量影像数据的行业,主要包括考古、电力、水利、通信、物流、石油、国土、农业、林业、环保、环评、矿山、海洋、物探、规划设计、数字城市、数字城管、综合应急、智能交通、公共卫生、园林设计、…

    2017-11-13 14:44:15
  • 如何在内网(局域网中)发布OpenLayers地图平台

    这里以中间件作为谷歌地球(GoogleEarth)卫星地图发布引挚,杭州市4到14级谷歌地球卫星地图(WGS84经纬度投影)作为中间件的地图发布数据源,OpenLayers开源平台作为加载中间件发布的卫星影像数据平台,说明如何在内网(局域网)中构建一套基于OpenLayers开发平台的离线WebGIS地理信…

    2017-11-10 10:54:25

共有访客发表了评论 网友评论

验证码: 看不清楚?