一. 地圖簡介
在移動互聯(lián)網(wǎng)的時代,移動App能進(jìn)解決用戶的很多生活瑣事,比如導(dǎo)航,地圖等,這些應(yīng)用均使用到了地圖與定位.在iOS開發(fā)過程中,想要將應(yīng)用加入這兩大功能則必須在下面兩個框架中進(jìn)行開發(fā).Map Kit用于地圖的顯示與Core Location用于地理定位.
注: iOS中國大陸地區(qū)的終端用戶的地圖數(shù)據(jù)使用的是高德地圖的數(shù)據(jù).
二. 地圖定位(CoreLocation框架,地理編碼與反地理編碼)
地圖定位使用步驟.
// 定位控制器
CLLocationManager *manager = [[CLLocationManager alloc] init];
// 每隔多少具體定位一次
manager.distanceFilter = 100;
// 定位精度
manager.desiredAccuracy = kCLLocationAccuracyBest;
// 指定代理
manager.delegate = self;
// 開啟定位服務(wù)
[manager startUpdatingLocation];
為了在保險起見,開發(fā)者不確定用戶是否在設(shè)置中將其定位功能進(jìn)行關(guān)閉,所以將使用CLLocationManager的一個類方法進(jìn)行判斷用戶是否開啟了定位服務(wù)
+(BOOL)locationServicesEnable;// 返回值為BOOL類型
開發(fā)者也可以根據(jù)Info.plist添加鍵值對,用來說明定位服務(wù)具體的用處.
// 需要在Info.plist文件中添加相應(yīng)的鍵值對來配合該方法的使用
[manager requestAlwaysAuthorization];
Info.plist文件中的鍵:NSLocationAlwaysUsageDescription
CLLocationManager的代理方法:
獲取定位信息的代理方法:
-(void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray<CLLocation *> *)locations;
一般的獲得的定位信息在存儲在locations數(shù)組中,并且,數(shù)組中的元素的類型為CLLocation類型
CLLocation類中的coordinate屬性為經(jīng)緯度的結(jié)構(gòu)體(CLLocationCoordinate2D的結(jié)構(gòu)體),信息longitude為經(jīng)度,latitude維度.
獲取定位失敗:
-(void)locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error
地理編碼與反編碼:
使用CLGeocoder類的實例化對象可以將具體地址轉(zhuǎn)化為經(jīng)緯度信息.地理編碼.
// CLGeocoder的實例方法,地理編碼(編碼完成的信息存放在Block參數(shù)中的NSArray中,為CLPlacemark類型,此類型中有很多關(guān)于具體地理位置信息的屬性)
- (void)reverseGeocodeLocation:(CLLocation *)location completionHandler:(CLGeocodeCompletionHandler)completionHandler;
使用CLGeocoder類的實例化對象可以將經(jīng)緯度轉(zhuǎn)化為地區(qū)的具體地址, 地理反編碼.
// CLGeocoder的實例方法,反地理編碼(String為所輸入的城市獲具體地址的名稱),通過反地理編碼,會將轉(zhuǎn)換過來的經(jīng)緯度信息存放在Block參數(shù)的一個數(shù)組中(placemarks)為其中的第一個元素,
- (void)geocodeAddressString:(NSString *)addressString completionHandler:(CLGeocodeCompletionHandler)completionHandler;
CLPlacemark 地標(biāo):
中有具體的屬性,顯示當(dāng)前位置的具體信息.
三. 地圖顯示(MapKit框架)
需要導(dǎo)入頭文件#import<MapKit/MapKit.h>
MKMapView用來顯示地圖.
MKMapView的實例化對象中有一個屬性userTrackingMode用來設(shè)置跟蹤用戶類型.mapType則是設(shè)置地圖類型.
獲取定位,需要設(shè)置地圖的代理,需要實現(xiàn)代理方法.
四. 自定義大頭針
MKAnnotation是一個大頭針模型.包括以下屬性:
1.title大頭針的標(biāo)題
2.subTitle大頭針的子標(biāo)題
3.coordinate;坐標(biāo)位置信息.
注意:一般的使用大頭針模型,都是用的是其子類,不是其父類.
使用的時候,初始化大頭針對象,并設(shè)置響應(yīng)的屬性值,重點是:設(shè)置大頭針的coordinate的屬性值,這個為大頭針的位置信息,使用CLLocationCoordinate2DMake(x,y);函數(shù)確定,函數(shù)內(nèi)的參數(shù)為維度,經(jīng)度.然后通過mapView對象的 addAnnotation方法添加到地圖上進(jìn)行顯示.或者使用addAnnotations:(NSArray *)annotations;添加多個大頭針.移除大頭針的方法也有類似removeAnnotation移除一個大頭針,removeAnnotations:(NSArrray *)annotations移除多個大頭針.
自定義大頭針:
一般的,相關(guān)地圖的應(yīng)用程序所使用到的大頭針都是通過自定義而生成的特殊樣式.通過MKMapView的代理方法來實現(xiàn).
示例源碼:
// 當(dāng)MapView調(diào)用addAnnotation方法的時候,響應(yīng)此方法,默認(rèn)返回值為nil為默認(rèn)大頭針樣式,通過參數(shù)annotation的不同,返回不同的MKAnnotationView的類型.(MKPINAnnotationView:為MKAnnotationView的子類,比其父類多兩個屬性,pinTintColor大頭針的顏色,animatesDrop:從天而降的動畫效果)
- (MKAnnotationView *)mapView:(MKMapView *)mapView viewForAnnotation:(id<MKAnnotation>)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;
}
}