iOS地图----MapKit框架

1.MapKit框架使用前提

①导入框架

②导入主头文件

#import <MapKit/MapKit.h>

③MapKit框架使用须知

  • MapKit框架中所有数据类型的前缀都是MK
  • MapKit有一个比较重要的UI控件,专门用于地图显示

④MapKit框架包含CLLocation

2.设置地图的类型

可以通过设置MKMapView的mapType设置地图类型

typedef enum : NSUInteger {
    MKMapTypeStandard , 标准(默认)
    MKMapTypeSatellite ,卫星
    MKMapTypeHybrid 混合(标准 + 卫星)
    } MKMapType;

3.追踪用户的位置,地图放大显示

  • 注意:在iOS8中, 如果想要追踪用户的位置, 必须自己主动请求隐私权限
  • 在CLLocation框架中CLLocationManager请求授权
  • 利用MapKit获取用户的位置, 可以追踪
    • userTrackingMode
    /*
     typedef NS_ENUM(NSInteger, MKUserTrackingMode) {
     MKUserTrackingModeNone = 0, 不追踪/不准确的
     MKUserTrackingModeFollow, 追踪
     MKUserTrackingModeFollowWithHeading, 追踪并且获取用的方向
     }
     */
    self.mapView.userTrackingMode =  MKUserTrackingModeFollow;

4.设代理,实现代理方法

self.mapView.delegate = self;

代理方法:

①地图的区域改变完成时调用

- 在此方法中可以得到用户的当前位置的mapView的中心点和经纬度跨度
- (void)mapView:(MKMapView *)mapView regionDidChangeAnimated:(BOOL)animated
{
    MKCoordinateRegion region = mapView.region;

    // 经纬度跨度
    MKCoordinateSpan span = region.span;

    NSLog(@"latitudeDelta = %f", span.latitudeDelta);
    NSLog(@"longitudeDelta = %f", span.longitudeDelta);
}

②常见的代理方法有

- (void)mapView:(MKMapView *)mapView didUpdateUserLocation:(MKUserLocation *)userLocation;
//一个位置更改默认只会调用一次,不断监测用户的当前位置
每次调用,都会把用户的最新位置(userLocation参数)传进来

- (void)mapView:(MKMapView *)mapView regionWillChangeAnimated:(BOOL)animated;
//地图的显示区域即将发生改变的时候调用

- (void)mapView:(MKMapView *)mapView regionDidChangeAnimated:(BOOL)animated;
//地图的区域改变完成时调用

设置地图显示区域,和经纬度跨度

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

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

// 设置地图的显示区域
@property (nonatomic) MKCoordinateRegion region;
- (void)setRegion:(MKCoordinateRegion)region animated:(BOOL)animated;

②MKCoordinateRegion

//MKCoordinateRegion是一个用来表示区域的结构体,定义如下
typedef struct {
                      CLLocationCoordinate2D center; // 区域的中心点位置
          MKCoordinateSpan span; // 区域的跨度
} MKCoordinateRegion;

//MKCoordinateSpan的定义
typedef struct {
    CLLocationDegrees latitudeDelta; // 纬度跨度
    CLLocationDegrees longitudeDelta; // 经度跨度
} MKCoordinateSpan;

例:回到当前位置

    // 1.拿到用户的经纬度
    CLLocationCoordinate2D userCoordinate = self.mapView.userLocation.coordinate;

    // 2.设置地图的中心点坐标是用户的经纬度

    // 2.1第一种设置方法
    // [self.mapView setCenterCoordinate:userCoordinate animated:YES];

    // 2.2第二种设置方法
    /*
    span 可以在地图的区域改变完成时调用
    - (void)mapView:(MKMapView *)mapView regionDidChangeAnimated:(BOOL)animated;
    */
    MKCoordinateSpan span = {1.0, 1.0};
    MKCoordinateRegion region = {userCoordinate, span};
    [self.mapView setRegion:region animated:YES];

5.大头针

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

①大头针的基本操作

// 添加一个大头针
- (void)addAnnotation:(id <MKAnnotation>)annotation;

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

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

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

(id )annotation参数是什么东西?

大头针模型对象:用来封装大头针的数据,比如大头针的位置、标题、子标题等数据

②大头针模型

  • 遵守协议的任何模型对象
  • 为了改写协议中属性--变量的值,重写这些变量
    • 这里的属性,只是为了定义get和set方法,不是所谓的传统属性
/**
 *  大头针的位置
 */
@property (nonatomic, assign) CLLocationCoordinate2D coordinate;
/**
 *  大头针标题
 */
@property (nonatomic, copy) NSString *title;
/**
 *  大头针的子标题
 */
@property (nonatomic, copy) NSString *subtitle;

③添加大头针

创建大头针模型,给成员变量赋值

 // 创建大头针模型
    YLAnnotation *anno = [[YLAnnotation alloc] init];
    anno.title = @"广东海洋大学";
    anno.subtitle = @"广东省湛江市广东海洋大学";
    CGFloat latitude = 24.00;
    CGFloat longitude = 103.76;
    anno.coordinate = CLLocationCoordinate2DMake(latitude , longitude);

添加大头针到地图上

    [self.customMapView addAnnotation:anno];

6.自定义大头针

①每次添加大头针就会调用(地图上有几个大头针就调用几次)

/*
 *  @param mapView    地图
 *  @param annotation 大头针模型
 *
 *  @return 大头针的view
*/
- (MKAnnotationView *)mapView:(MKMapView *)mapView viewForAnnotation:(id<MKAnnotation>)annotation;
注意: 如果返回nil, 系统会按照自己默认的方式显示
  • return nil;

创建大头针,给大头针附模型属性

  • 类型 tableViewCell
static NSString *identifier = @"anno";
    // 1.从缓存池中取
  MKAnnotationView *annoView = [mapView dequeueReusableAnnotationViewWithIdentifier:identifier];

   // 2.如果缓存池中没有, 创建一个新的
    if (annoView == nil) {
        annoView = [[MKAnnotationView alloc] initWithAnnotation:annotation reuseIdentifier:identifier];

        // 设置大头针标题是否显示
        // 自定义的大头针, 默认情况点击大头针之后是不会显示标题的, 需要我们自己手动设置显示
        annoView.canShowCallout = YES;

        // 设置大头针标题显示的偏移位
        annoView.calloutOffset = CGPointMake(-50, 0);

        // 设置大头针左边的辅助视图
        annoView.leftCalloutAccessoryView = [[UISwitch alloc] init];
        // 设置大头针右边的辅助视图
        annoView.rightCalloutAccessoryView = [UIButton buttonWithType:UIButtonTypeContactAdd];

    }
    // 设置大头针的图片
    annoView.image = [UIImage imageNamed:@"category_4"];

创建另一中大头针

  • MKAnnotationView的子类MKPinAnnotationView
  • 新增加了从天降效果,和
    static NSString *identifier = @"anno";
    // 1.从缓存池中取
        MKPinAnnotationView *annoView = (MKPinAnnotationView *)[mapView dequeueReusableAnnotationViewWithIdentifier:identifier];

    // 2.如果缓存池中没有, 创建一个新的
    if (annoView == nil) {
        annoView = [[MKPinAnnotationView alloc] initWithAnnotation:nil reuseIdentifier:identifier];

        // 设置大头针的颜色
        annoView.pinColor = MKPinAnnotationColorPurple;

        // 设置大头针从天而降
        annoView.animatesDrop = YES;

        // 设置大头针标题是否显示
        // 自定义的大头针, 默认情况点击大头针之后是不会显示标题的, 需要我们自己手动设置显示
        annoView.canShowCallout = YES;

        // 设置大头针标题显示的偏移位
        annoView.calloutOffset = CGPointMake(-50, 0);

        // 设置大头针左边的辅助视图
        annoView.leftCalloutAccessoryView = [[UISwitch alloc] init];
        // 设置大头针右边的辅助视图
        annoView.rightCalloutAccessoryView = [UIButton buttonWithType:UIButtonTypeContactAdd];

    }

    // 设置大头针的图片
    // 注意: 如果你是使用的MKPinAnnotationView创建的自定义大头针, 那么设置图片无效, 因为系统内部会做一些操作, 覆盖掉我们自己的设置
    annoView.image = [UIImage imageNamed:@"category_4"];

    // 4.返回大头针View
    return annoView;

自定义AnnotationView

  • 类型自定义Cell
  • 继承MKAnnotationView
// 每次添加大头针就会调用此方法
- (MKAnnotationView *)mapView:(MKMapView *)mapView viewForAnnotation:(id<MKAnnotation>)annotation
{
//    NSLog(@"%s", __func__);
    NSLog(@"annotation === %@", annotation);
    // 对用户当前的位置的大头针特殊处理
    if ([annotation isKindOfClass:[HMAnnotation class]] == NO) {
        return nil;
    }
 // 1.创建自定义大头针
    YLAnnotationView *annoView = [YLAnnotationView annotationViewWithMap:mapView];
    // 2.设置模型(可以不赋值,系统也会自动执行这个方法)
//    annoView.annotation = annotation;

    // 3.返回大头针
    return annoView;
}

自定义的AnnotationView中得方法

// 初始化方法
+ (instancetype)annotationViewWithMap:(MKMapView *)mapView
{
    static NSString *identifier = @"anno";

    // 1.从缓存池中取
    YLAnnotationView *annoView = (YLAnnotationView *)[mapView dequeueReusableAnnotationViewWithIdentifier:identifier];
    // 2.如果缓存池中没有, 创建一个新的
    if (annoView == nil) {

// 参数传 nil 是因为 setAnnotation: 方法会赋值给Annotation模型
        annoView = [[YLAnnotationView alloc] initWithAnnotation:nil reuseIdentifier:identifier];
    }

    return annoView;
}

//- (void)setAnnotation:(id<MKAnnotation>)annotation
// 此方法是重写set方法
- (void)setAnnotation:(YLAnnotation *)annotation
{
    [super setAnnotation:annotation];

//     处理自己特有的操作
    self.image = [UIImage imageNamed:annotation.icon];

}
时间: 2025-01-14 06:11:08

iOS地图----MapKit框架的相关文章

IOS中MapKit框架使用地图的显示

1.导入主头文件 #import <MapKit/MapKit.h> MapKit框架使用须知 MapKit框架中所有数据类型的前缀都是MK MapKit有一个比较重要的UI控件 :MKMapView,专门用于地图显示 2. 设置MKMapView的userTrackingMode属性可以跟踪显示用户的当前位置 MKUserTrackingModeNone :不跟踪用户的位置 MKUserTrackingModeFollow :跟踪并在地图上显示用户的当前位置 MKUserTrackingMo

iOS学习笔记20-地图(二)MapKit框架

一.地图开发介绍 从iOS6.0开始地图数据不再由谷歌驱动,而是改用自家地图,当然在国内它的数据是由高德地图提供的. 在iOS中进行地图开发主要有三种方式: 利用MapKit框架进行地图开发,利用这种方式可以对地图进行精准的控制 调用苹果官方自带的地图应用,主要用于一些简单的地图应用,无法精确控制 使用第三方地图开发SDK库 用得最多的还是MapKit,所以这节就只讲MapKit的使用. 二.MapKit核心类 MapKit的核心类为地图展示控件MKMapView,以下是常用的属性.对象方法以及

iOS地图开发MapKit

现在O2O应用非常火,因为基于地理的社交和电子商务应用都有非常广阔的前景 二O2O的移动载体就是手机了(平板基本忽略不计),所以会点手机上Map开发还是不错的 首先苹果已经封装了一套地图框架供我们使用,首先要使用苹果提供的地图框架需要导入MapKit框架 导入完成后即可使用 首先在你的视图里拖入一个MapView, 然后运行就行了~这是你就会看到地图(如果用的是真机最好,模拟器有点蛋疼) 但是现实的是一个大大的地图,赶脚没什么用,我们需要的是一个比较精准的地图,这时进入MKMapView.h文件

iOS核心笔记—MapKit框架-基础

1.MapKit框架简介: ?了解:MapKit框架使用须知:①.MapKit框架中所有的数据类型的前缀都是MK:②.需要导入#import <MapKit/MapKit.h>头文件:③.MapKit框架中有一个非常重要的UI控件:MKMapView,专门用于地图显示,例如:大头针.路线.覆盖层展示等(着重界面展示). 1-1.地图设置: 1-1-1.设置地图显示类型: 地图类型: 地图枚举 地图类型 MKMapTypeStandard 普通地图 MKMapTypeSatellite 卫星云图

iOS 地图开发MapKit和CLLocation

1,iOS 定位服务 现在对iOS下的定组件建进行如下分类: 1>,无限蜂窝定位,根据移动设备距离基站的位置来实现定位的. 2>,GPS定位,也就是所谓的卫星定位,定位精确度较高,但是受遮盖环境影响较大, 3>,无线wifi定位,根据定位路由器的位置,实现定位, 4>,蓝牙beacon定位,定位精确度高,但是要求在外设的覆盖区域内 下面我们主要讲讲iOS下面的定位吧,主要框架CoreLocation.framework,主要对象CLLocationManager,主要代理CLLoc

【高德API】如何利用MapKit开发全英文检索的iOS地图

原文:[高德API]如何利用MapKit开发全英文检索的iOS地图 制作全英文地图的展示并不困难,但是要制作全英文的数据检索列表,全英文的信息窗口,你就没办法了吧.告诉你,我有妙招!使用iOS自带的MapKit来展示全球英文底图,结合上高德API的中英文检索功能,就能打造POI数据最丰富,英文展示全方位的纯英文地图啦!看看截图,是不是浑然天成? ----------------------------------------------------------------------------

iOS的基本框架

在iOS中框架是一个目录,包含了共享资源库,用于访问该资源库中储存的代码的头文件,以及图像.声音文件等其他资源.共享资源库定义应用程序可以调用的函数和方法.    iOS为应用程序开发提供了许多可使用的框架,并构成IOS操作系统的层次架构,分为四层,从上到下依次为:Cocoa Touch Layer(触摸UI层).MediaLayer(媒体层).Core Services Layer(核心服务层).Core OS Layer(核心OS层). 低层次框架提供IOS的基本服务和技术,高层次框架建立在

iOS地图的显示(大头针)

1 1.导入主头文件 2 #import <MapKit/MapKit.h> 3 MapKit框架使用须知 4 MapKit框架中所有数据类型的前缀都是MK 5 MapKit有一个比较重要的UI控件:MKMapView,专门用于地图显示 6 7 2.跟踪显示用户的位置 8 9 设置MKMapView的userTrackingMode属性可以跟踪显示用户的当前位置 10 MKUserTrackingModeNone :不跟踪用户的位置 11 MKUserTrackingModeFollow :跟

iOS地图定位(Map)

1.地图的简介 在移动互联网时代,移动app能解决用户的很多生活琐事,比如    导航:去任意陌生的地方    周边:找餐馆.找酒店.找银行.找电影院    手机软件:微信摇一摇.QQ附近的人.微博.支付宝等 在上述应用中,都用到了地图和定位功能,在iOS开发中,要想加入这两大功能,必须基于两个框架进行开发    Map Kit :用于地图展示    Core Location :用于地理定位 地图定位(CoreLocation框架,地理编码与反地理编码)地图显示(MapKit框架)自定义大头针