一. 地图简介
在移动互联网的时代,移动App能进解决用户的很多生活琐事,比如导航,地图等,这些应用均使用到了地图与定位.在iOS开发过程中,想要将应用加入这两大功能则必须在下面两个框架中进行开发.Map Kit用于地图的显示与Core Location用于地理定位.
注: iOS中国大陆地区的终端用户的地图数据使用的是高德地图的数据.
二. 地图定位(CoreLocation框架,地理编码与反地理编码)
地图定位使用步骤.
// 定位控制器
CLLocationManager *manager = [[CLLocationManager alloc] init];
// 每隔多少具体定位一次
manager.distanceFilter = 100;
// 定位精度
manager.desiredAccuracy = kCLLocationAccuracyBest;
// 指定代理
manager.delegate = self;
// 开启定位服务
[manager startUpdatingLocation];
为了在保险起见,开发者不确定用户是否在设置中将其定位功能进行关闭,所以将使用CLLocationManager的一个类方法进行判断用户是否开启了定位服务
+(BOOL)locationServicesEnable;// 返回值为BOOL类型
开发者也可以根据Info.plist添加键值对,用来说明定位服务具体的用处.
// 需要在Info.plist文件中添加相应的键值对来配合该方法的使用
[manager requestAlwaysAuthorization];
Info.plist文件中的键:NSLocationAlwaysUsageDescription
CLLocationManager的代理方法:
获取定位信息的代理方法:
-(void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations;
一般的获得的定位信息在存储在locations数组中,并且,数组中的元素的类型为CLLocation类型
CLLocation类中的coordinate属性为经纬度的结构体(CLLocationCoordinate2D的结构体),信息longitude为经度,latitude维度.
获取定位失败:
-(void)locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error
地理编码与反编码:
使用CLGeocoder类的实例化对象可以将具体地址转化为经纬度信息.地理编码.
// CLGeocoder的实例方法,地理编码(编码完成的信息存放在Block参数中的NSArray中,为CLPlacemark类型,此类型中有很多关于具体地理位置信息的属性)
- (void)reverseGeocodeLocation:(CLLocation *)location completionHandler:(CLGeocodeCompletionHandler)completionHandler;
使用CLGeocoder类的实例化对象可以将经纬度转化为地区的具体地址, 地理反编码.
// CLGeocoder的实例方法,反地理编码(String为所输入的城市获具体地址的名称),通过反地理编码,会将转换过来的经纬度信息存放在Block参数的一个数组中(placemarks)为其中的第一个元素,
- (void)geocodeAddressString:(NSString *)addressString completionHandler:(CLGeocodeCompletionHandler)completionHandler;
CLPlacemark 地标:
中有具体的属性,显示当前位置的具体信息.
三. 地图显示(MapKit框架)
需要导入头文件#import
MKMapView用来显示地图.
MKMapView的实例化对象中有一个属性userTrackingMode用来设置跟踪用户类型.mapType则是设置地图类型.
获取定位,需要设置地图的代理,需要实现代理方法.
四. 自定义大头针
MKAnnotation是一个大头针模型.包括以下属性:
1.title大头针的标题
2.subTitle大头针的子标题
3.coordinate;坐标位置信息.
注意:一般的使用大头针模型,都是用的是其子类,不是其父类.
使用的时候,初始化大头针对象,并设置响应的属性值,重点是:设置大头针的coordinate的属性值,这个为大头针的位置信息,使用CLLocationCoordinate2DMake(x,y);函数确定,函数内的参数为维度,经度.然后通过mapView对象的 addAnnotation方法添加到地图上进行显示.或者使用addAnnotations:(NSArray *)annotations;添加多个大头针.移除大头针的方法也有类似removeAnnotation移除一个大头针,removeAnnotations:(NSArrray *)annotations移除多个大头针.
自定义大头针:
一般的,相关地图的应用程序所使用到的大头针都是通过自定义而生成的特殊样式.通过MKMapView的代理方法来实现.
示例源码:
// 当MapView调用addAnnotation方法的时候,响应此方法,默认返回值为nil为默认大头针样式,通过参数annotation的不同,返回不同的MKAnnotationView的类型.(MKPINAnnotationView:为MKAnnotationView的子类,比其父类多两个属性,pinTintColor大头针的颜色,animatesDrop:从天而降的动画效果)
- (MKAnnotationView *)mapView:(MKMapView *)mapView viewForAnnotation:(id)annotation {
if ([annotation isKindOfClass:[MyAnnonation class]]) {
MKPinAnnotationView *pinAnnotationView = [[MKPinAnnotationView alloc] initWithAnnotation:nil reuseIdentifier:@"reuse"];
pinAnnotationView.canShowCallout = YES;
pinAnnotationView.pinTintColor = [UIColor cyanColor];
pinAnnotationView.animatesDrop = YES;
return pinAnnotationView;
} else {
return nil;
}
}