MapKit框架

一、MapKit框架使用前提

  1. 导入MapKit框架
  2. 导入MapKit的主头文件
    #import <MapKit/MapKit.h>
  3. 如果是storyboard中用到了地图,必须手动导入MapKit框架,否则会报下面的错误:
    Terminating app due to uncaught exception 'NSInvalidUnarchiveOperationException', reason: 'Could not instantiate class named MKMapView'
  4. MapKit框架中所有的数据类型的前缀都是以MK开头;MapKit有一个非常重要的UI控件:MKMapView,专门用于地图显示。

二、追踪显示用户的位置

在CoreLocation框架中,使用startUpdatingLocation方法,来定位用户。而在MapKit框架中,设置MapView的userTrackingMode属性跟踪显示用户的当前位置。
如果在iOS8中,想要定位必须设置用户主动要求用户授权,而且必须在info.plist文件中配置一项属性才能弹出允许授权的窗口。
在iOS7中,直接设置MapView的userTrackingMode属性就可以跟踪显示用户的当前位置。

  • MkUserTrackingModeNone:不跟踪用户的位置
  • MKUserTrackingModeFollow:跟踪并在地图上显示用户的当前位置。
  • MKUserTrackingModeFollowWithHeading:跟踪并在地图上显示用户的当前位置,地图会随用户的前进方向进行旋转。

三、设置地图类型

可以设置MKMapView的mapViewType(枚举)设置地图类型

  • MKMapTypeStandard:普通地图(默认)
  • MKMapTypeSatellite:卫星云图
  • MKMapTypeHybrid:普通地图覆盖与卫星云图之上。

四、MKMapView的常见代理方法

MKMapView可以设置一个代理对象,用来监听地图的相关行为。

/
 *  每次更新到用户的位置就会调用(调用不频繁, 只有位置改变才会调用)
 *
 *  @param mapView      促发事件的控件
 *  @param userLocation 大头针模型
 */
- (void)mapView:(MKMapView *)mapView didUpdateUserLocation:(MKUserLocation *)userLocation {
     /*
      地图上蓝色的点就称之为大头针
      大头针可以拥有标题/子标题/位置信息
      大头针上显示什么内容由大头针模型确定(MKUserLocation)
    */
    // 利用反地理编码获取位置之后设置标题
    [self.geocoder reverseGeocodeLocation:userLocation.location completionHandler:^(NSArray *placemarks, NSError *error) {
        CLPlacemark *placemark = [placemarks firstObject];
        NSLog(@"获取地理位置成功 name = %@ locality = %@",placemark.name, placemark.locality);
        userLocation.title = placemark.name;
        userLocation.subtitle = placemark.locality;
  }];
    // 移动地图到当前用户所在位置
    // 获取用户当前所在位置的经纬度, 并且设置为地图的中心点
  [self.customMapView setCenterCoordinate:userLocation.location.coordinate
animated:YES];
    // 设置地图显示的区域
    // 获取用户的位置
    CLLocationCoordinate2D center = userLocation.location.coordinate;

    // 指定经纬度的跨度
    MKCoordinateSpan span = MKCoordinateSpanMake(0.009310,0.007812);
    // 将用户当前的位置作为显示区域的中心点, 并且指定需要显示的跨度范围
    MKCoordinateRegion region = MKCoordinateRegionMake(center, span);
    // 设置显示区域
    [self.customMapView setRegion:region animated:YES];
}


/**
 *  地图的区域即将改变时调用
- (void)mapView:(MKMapView *)mapView regionWillChangeAnimated:(BOOL)animated {
  NSLog(@"地图的区域即将改变时调用");
}


/**
 *  地图的区域改变完成时调用
 */
- (void)mapView:(MKMapView *)mapView regionDidChangeAnimated:(BOOL)animated {
    NSLog(@"地图的区域改变完成时调用");
    NSLog(@"%f %f", self.customMapView.region.span.latitudeDelta, self.customMapView.region.span.longitudeDelta);
}

五、设置地图的显示

通过MKMapView的下列方法,可以设置地图显示的位置和区域:

  1. 设置地图的中心点位置
@property (nonatomic) CLLocationCoordinate2D centerCoordinate;
-(void)setCenterCoordinate(CLLocationCoordinate2D)coordinate animated (BOOL)animated;

2.设置地图的显示区域

@property (nonatomic) MKCoordinateRegion region;
- (void)setRegion:(MKCoordinateRegion)region animated:(BOOL)animated;

MKCoordinateRegion是一个用来表示区域的结构体,定义如下:

typedef struct {

  CLLocationCoordinate2D center; // 区域的中心点位置

  MKCoordinateSpan span; // 区域的跨度

} MKCoordinateRegion;

MKCoordinateSpan的定义:

typedef struct {

    CLLocationDegrees latitudeDelta; // 纬度跨度

    CLLocationDegrees longitudeDelta; // 经度跨度

} MKCoordinateSpan;

六、大头针

钉在某个具体位置,用来标识这个位置上有特定的事物(比如这个位置上有家餐馆)。

  1. 大头针的基本操作
添加一个大头针
- (void)addAnnotation:(id <MKAnnotation>)annotation;

添加多个大头针
- (void)addAnnotations:(NSArray *)annotations;

移除一个大头针
- (void)removeAnnotation:(id<MKAnnotation>)annotation;

移除多个大头针
- (void)removeAnnotations:(NSArray *)annotations;

注意:(id <MKAnnotation>)annotation参数是指:大头针模型对象,用来封装大头针的数据,比如大头针的位置、标题、子标题等数据。

2.自定义大头针
很多情况下,需要自定义大头针的显示样式,比如显示一张图片。
设置MKMapView的代理,实现下面的代理方法,返回大头针控件。

- (MKAnnotationView *)mapView:(MKMapView *)mapView viewForAnnotation:(id <MKAnnotation>)annotation;

根据传进来的(id <MKAnnotation>)annotation参数创建并返回对应的大头针控件。

注意:

  • 每次在地图上添加一个大头针就会调用一次。
  • 如果自定义大头针控件返回nil,系统会按照自己默认的方式显示。
  • 自定义大头针控件的方式和自定义表格创建的方式一样,都是刚开始的时候从缓冲池中读取,如果缓存池中没有,就会创建出一个新的。
  • 不能把模型写死,因为annotationView == nil调用有限,每次都会从缓存池中获取。
  • 默认情况下,MKAnnotationView是不能显示的,如果想自定义大头针可以使用MKAnnotationView的子类MKPinAnnotationView。
  • 对用户当前位置的大头针特殊处理,如果不是自定义的大头针控件,就返回nil。
  • 如果你是使用的MKPinAnnotationView创建的大头针,那么设置的图片无效,因为系统会做一些操作,覆盖掉我们自己的设置
  • 标识用户位置的蓝色发光圆点,它也是一个大头针,当显示这个大头针时,也会调用代理方法,因此,需要在代理方法中分清楚(id <MKAnnotation>)annotation参数代表自定义的大头针还是蓝色发光圆点

3.MKAnnotationView
地图上的大头针控件是MKAnnotationView

@property (nonatomic, strong) id <MKAnnotation> annotation; // 大头针模型

@property (nonatomic, strong) UIImage *image; // 显示的图片

@property (nonatomic) BOOL canShowCallout; // 是否显示标注

@property (nonatomic) CGPoint calloutOffset; // 标注的偏移量

@property (strong, nonatomic) UIView *rightCalloutAccessoryView; // 标注右边显示什么控件

@property (strong, nonatomic) UIView *leftCalloutAccessoryView; // 标注左边显示什么控件

4.MKPinAnnotationView
MKPinAnnotationView是MKAnnotationView的子类。
MKPinAnnotationView比MKAnnotationView多了2个属性。

@property (nonatomic) MKPinAnnotationColor pinColor;// 大头针颜色

@property (nonatomic) BOOL animatesDrop; // 大头针第一次显示时是否从天而降

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容