使用MapKit框架

地图显示

最简单显示地图的代码:

//
// RootViewController.m
// CoreLocation
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "RootViewController.h"
#import <MapKit/MapKit.h> @interface RootViewController () @end @implementation RootViewController - (void)viewDidLoad
{
[super viewDidLoad]; // 初始化地图控件
MKMapView *mapView = [[MKMapView alloc] initWithFrame:self.view.bounds]; // 地图的类型
mapView.mapType = MKMapTypeStandard; // 视图的宽度和高度将和父视图的宽度一起成比例变化
mapView.autoresizingMask = \
UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; // 显示地图
[self.view addSubview:mapView];
} @end

RootViewController

注意:使用地图之前是需要引入MapKit框架的哦.

autoresizingMask是干什么用的呢(实际上,我看过后还是不懂)?

UIViewAutoresizingNone

这个常量如果被设置,视图将不进行自动尺寸调整。

UIViewAutoresizingFlexibleHeight

这个常量如果被设置,视图的高度将和父视图的高度一起成比例变化。否则,视图的高度将保持不变。

UIViewAutoresizingFlexibleWidth

这个常量如果被设置,视图的宽度将和父视图的宽度一起成比例变化。否则,视图的宽度将保持不变。

UIViewAutoresizingFlexibleLeftMargin

这个常量如果被设置,视图的左边界将随着父视图宽度的变化而按比例进行调整。否则,视图和其父视图的左边界的相对位置将保持不变。

UIViewAutoresizingFlexibleRightMargin

这个常量如果被设置,视图的右边界将随着父视图宽度的变化而按比例进行调整。否则,视图和其父视图的右边界的相对位置将保持不变。

UIViewAutoresizingFlexibleBottomMargin

这个常量如果被设置,视图的底边界将随着父视图高度的变化而按比例进行调整。否则,视图和其父视图的底边界的相对位置将保持不变。

UIViewAutoresizingFlexibleTopMargin

这个常量如果被设置,视图的上边界将随着父视图高度的变化而按比例进行调整。否则,视图和其父视图的上边界的相对位置将保持不变。

//
// RootViewController.m
// CoreLocation
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "RootViewController.h"
#import <MapKit/MapKit.h> @interface RootViewController () @end @implementation RootViewController - (void)viewDidLoad
{
[super viewDidLoad]; // 初始化地图控件
MKMapView *mapView = [[MKMapView alloc] initWithFrame:self.view.bounds]; // 地图的类型
mapView.mapType = MKMapTypeStandard; // 视图的宽度和高度将和父视图的宽度一起成比例变化
mapView.autoresizingMask = \
UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; // 显示用户所在位置(此处系统会询问你是否使用当前位置)
mapView.showsUserLocation = YES; // 经纬度坐标(河南南阳)
CLLocationCoordinate2D coor2d = {33.00, 112.52}; // 地图缩放级别
MKCoordinateSpan span = {, }; // 被显示的区域
MKCoordinateRegion region = {coor2d, span}; // 设置显示的区域
[mapView setRegion:region]; // 显示地图
[self.view addSubview:mapView]; } @end

RootViewController.m

位置定位

//
// RootViewController.m
// CoreLocation
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "RootViewController.h"
#import <MapKit/MapKit.h> @interface RootViewController ()<CLLocationManagerDelegate> @property (nonatomic, strong) CLLocationManager *locationManager; @end @implementation RootViewController - (void)viewDidLoad
{
[super viewDidLoad]; // 判断定位功能是否可以使用
if([CLLocationManager locationServicesEnabled])
{
// 初始化定位管理器
_locationManager = [[CLLocationManager alloc] init];
_locationManager.delegate = self; // 开始定位
[_locationManager startUpdatingLocation];
}
else
{
NSLog(@"定位功能不可用");
}
} - (void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations
{
CLLocation *newLocation = [locations lastObject];
NSLog(@"%@", newLocation); // 定位结束
[manager stopUpdatingLocation];
} - (void)locationManager:(CLLocationManager *)manager
didFailWithError:(NSError *)error
{
NSLog(@"%@", error); // 定位结束
[manager stopUpdatingLocation];
} @end

RootViewController.m

为什么需要判断定位功能可不可用呢?下图可以看出为什么了.

打印信息:

2014-05-15 09:25:11.883 CoreLocation[17610:60b] <+37.78583400,-122.40641700> +/- 5.00m (speed -1.00 mps / course -1.00) @ 5/15/14, 9:25:11 AM China Standard Time

本人将这个代理定位的方式改写成了可以使用block的方式:

YXLocation.h

//
// YXLocation.h
// CoreLocation
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import <Foundation/Foundation.h>
#import <MapKit/MapKit.h> @protocol YXLocationProtocol <NSObject> @optional
- (void)currentLocation:(CLLocation *)location sucess:(BOOL)sucess; @end typedef void (^locationBlock_t)(CLLocation *currentLocation, BOOL sucess); @interface YXLocation : NSObject @property (nonatomic, copy, readwrite) locationBlock_t locationBlock;
@property (nonatomic, assign, readwrite) id<YXLocationProtocol> protocol; @property (nonatomic, strong, readonly) CLLocation *location; - (void)start; @end

Code

YXLocation.m

//
// YXLocation.m
// CoreLocation
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "YXLocation.h" @interface YXLocation ()<CLLocationManagerDelegate> @property (nonatomic, strong) CLLocationManager *locationManager; @end @implementation YXLocation - (instancetype)init
{
self = [super init];
if (self)
{
_locationManager = [[CLLocationManager alloc] init];
_locationManager.delegate = self;
}
return self;
} - (void)start
{
if([CLLocationManager locationServicesEnabled])
{
[_locationManager startUpdatingLocation];
}
else
{
NSLog(@"定位功能没有开启"); if (_locationBlock)
{
_locationBlock(nil, NO);
} if (_protocol)
{
[_protocol currentLocation:nil sucess:NO];
}
}
} - (void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations
{
CLLocation *newLocation = [locations lastObject]; _location = newLocation; if (_locationBlock)
{
_locationBlock(newLocation, YES);
} if (_protocol)
{
[_protocol currentLocation:newLocation sucess:YES];
} [_locationManager stopUpdatingLocation];
} - (void)locationManager:(CLLocationManager *)manager
didFailWithError:(NSError *)error
{
NSLog(@"定位功能出错"); if (_locationBlock)
{
_locationBlock(nil, NO);
} if (_protocol)
{
[_protocol currentLocation:nil sucess:NO];
}
} @end

Code

将经纬度转换为有意义的地址

//
// RootViewController.m
// CoreLocation
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "RootViewController.h"
#import <MapKit/MapKit.h> @interface RootViewController ()<CLLocationManagerDelegate> @property (nonatomic, strong) CLLocationManager *locationManager;
@property (nonatomic, strong) CLGeocoder *geocoder; @end @implementation RootViewController - (void)viewDidLoad
{
[super viewDidLoad]; // 判断定位功能是否可以使用
if([CLLocationManager locationServicesEnabled])
{
// 初始化定位管理器
_locationManager = [[CLLocationManager alloc] init];
_locationManager.delegate = self; // 开始定位
[_locationManager startUpdatingLocation];
}
else
{
NSLog(@"定位功能不可用");
}
} - (void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations
{
CLLocation *newLocation = [locations lastObject]; // 初始化经纬度解析器
_geocoder = [[CLGeocoder alloc] init]; // 解析经纬度值
[_geocoder reverseGeocodeLocation:newLocation
completionHandler:^(NSArray *placemarks, NSError *error) {
CLPlacemark *placemark = [placemarks objectAtIndex:]; // 将字典信息拼接起来
NSString *locatedAt = \
[[placemark.addressDictionary valueForKey:@"FormattedAddressLines"] componentsJoinedByString:@", "]; // 打印信息
NSLog(@"我在 %@",locatedAt); NSLog(@"国家代码 %@",placemark.ISOcountryCode);
NSLog(@"国家 %@",placemark.country);
NSLog(@"邮政编码 %@",placemark.postalCode);
NSLog(@"administrativeArea %@",placemark.administrativeArea);
NSLog(@"locality %@",placemark.locality);
NSLog(@"subLocality %@",placemark.subLocality);
NSLog(@"subThoroughfare %@",placemark.subThoroughfare);
}]; // 定位结束
[manager stopUpdatingLocation];
} - (void)locationManager:(CLLocationManager *)manager
didFailWithError:(NSError *)error
{
NSLog(@"%@", error); // 定位结束
[manager stopUpdatingLocation];
} @end

RootViewController.m

打印信息如下:

2014-05-15 09:40:13.982 CoreLocation[2482:60b] 我在 中国北京市东城区东四街道东四朝阳门北小街2-1号
2014-05-15 09:40:13.986 CoreLocation[2482:60b] 国家代码 CN
2014-05-15 09:40:13.987 CoreLocation[2482:60b] 国家    中国
2014-05-15 09:40:13.988 CoreLocation[2482:60b] 邮政编码 (null)
2014-05-15 09:40:13.989 CoreLocation[2482:60b] administrativeArea 北京市
2014-05-15 09:40:13.991 CoreLocation[2482:60b] locality (null)
2014-05-15 09:40:13.992 CoreLocation[2482:60b] subLocality 东城区
2014-05-15 09:40:13.993 CoreLocation[2482:60b] subThoroughfare 2-1号

将有意义的地址转换为经纬度

//
// RootViewController.m
// CoreLocation
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "RootViewController.h"
#import <MapKit/MapKit.h> @interface RootViewController ()<CLLocationManagerDelegate> @property (nonatomic, strong) CLGeocoder *geocoder; @end @implementation RootViewController - (void)viewDidLoad
{
[super viewDidLoad]; _geocoder = [[CLGeocoder alloc] init]; [_geocoder geocodeAddressString:@"中国北京市东城区东四街道东四朝阳门北小街2-1号"
completionHandler:^(NSArray *placemarks, NSError *error)
{ if([placemarks count] > && error == nil)
{ NSLog(@"发现了 %lu placemark(s).",(unsigned long)[placemarks count]); CLPlacemark *firstPlacemark = [placemarks objectAtIndex:]; NSLog(@"经度 = %f",firstPlacemark.location.coordinate.longitude);
NSLog(@"纬度 = %f",firstPlacemark.location.coordinate.latitude); }
else if ([placemarks count] == && error == nil)
{
NSLog(@"没有找到 placemarks."); }
else if (error != nil)
{
NSLog(@"错误 = %@",error);
}
}];
} @end

RootViewController.m

打印信息:

2014-05-15 09:51:15.270 CoreLocation[2525:60b] 发现了 2 placemark(s).
2014-05-15 09:51:15.274 CoreLocation[2525:60b] 经度 = 116.425960
2014-05-15 09:51:15.275 CoreLocation[2525:60b] 纬度 = 39.931609

直接显示用户当前位置

//
// RootViewController.m
// CoreLocation
//
// Copyright (c) 2014年 Y.X. All rights reserved.
// #import "RootViewController.h"
#import <MapKit/MapKit.h> @interface RootViewController ()<CLLocationManagerDelegate> @property (nonatomic, strong) CLLocationManager *locationManager; @end @implementation RootViewController - (void)viewDidLoad
{
[super viewDidLoad]; // 判断定位功能是否可以使用
if([CLLocationManager locationServicesEnabled])
{
// 初始化定位管理器
_locationManager = [[CLLocationManager alloc] init];
_locationManager.delegate = self; // 开始定位
[_locationManager startUpdatingLocation];
}
else
{
NSLog(@"定位功能不可用");
}
} - (void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations
{
// 获取坐标信息
CLLocation *newLocation = [locations lastObject]; // 定位结束
[manager stopUpdatingLocation]; // 初始化地图控件
MKMapView *mapView = [[MKMapView alloc] initWithFrame:self.view.bounds]; // 地图的类型
mapView.mapType = MKMapTypeStandard; // 视图的宽度和高度将和父视图的宽度一起成比例变化
mapView.autoresizingMask = \
UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; // 显示用户所在位置(此处系统会询问你是否使用当前位置)
mapView.showsUserLocation = YES; // 地图缩放级别
MKCoordinateSpan span = {0.02, 0.02}; // 被显示的区域
MKCoordinateRegion region = {newLocation.coordinate, span}; // 设置显示的区域
[mapView setRegion:region]; // 显示地图
[self.view addSubview:mapView];
} - (void)locationManager:(CLLocationManager *)manager
didFailWithError:(NSError *)error
{
NSLog(@"%@", error); // 定位结束
[manager stopUpdatingLocation];
} @end

RootViewController.m

使用MapKit框架(持续更新)的更多相关文章

  1. iOS之github第三方框架(持续更新)

    1.MBProgressHUD MBProgressHUD是一个开源项目,实现了很多种样式的提示框 使用上简单.方便,并且可以对显示的内容进行自定义,功能很强大,很多项目中都有使用到. 到Github ...

  2. 收集前端UI框架 持续更新中....

    1. elementUI 饿了么出品 基于Vue2 http://element.eleme.io/#/zh-CN 2. ZUI 开源HTML5跨屏框架  (2018年1月4日更新)一个基于 Boot ...

  3. ECLIPSE/JAVAWEB (二)三大框架之Hibernate框架 持续更新中...

    (一)发展历史 在Struts框架中使用jdbc连接来读写数据库,我们最常见的就是打开数据库连接.使用复杂的sql语句进行读写.关闭连接,获得的数据又需要转换或封装后往外传,这是一个非常繁琐的过程. ...

  4. Eclipse/JavaWeb (三)三大框架之Spring框架 持续更新中...

    (一)发展历史 现在我们有三个层了,可是每层之间的调用是怎样的呢?比如显示层的struts需要调用一个业务类,就需要new一个业务类出来,然后使用:业务层需要调用持久层的类,也需要new一个持久层类出 ...

  5. Eclipse/JavaWeb (一)三大框架之struts框架 持续更新中...

    最近主要把javaweb的三大框架过一遍. (一)发展历史 传统的Java Web应用程序是采用JSP+Servlet+Javabean来实现的,这种模式实现了最基本的MVC分层,使得程序分为几层,有 ...

  6. iOS开发常用第三方开源框架 持续更新中...

    键盘管理 TPKeyboardAvoiding IQKeyboardManager(1.2.8) 弹窗HUD MBProgressHUD(0.9.2) SVProgressHUD UIView+Toa ...

  7. iOS开发系列文章(持续更新……)

    iOS开发系列的文章,内容循序渐进,包含C语言.ObjC.iOS开发以及日后要写的游戏开发和Swift编程几部分内容.文章会持续更新,希望大家多多关注,如果文章对你有帮助请点赞支持,多谢! 为了方便大 ...

  8. 我的敏捷、需求分析、UML、软件设计电子书 - 下载(持续更新中)

    我将所有我的电子书汇总在一起,方便大家下载!(持续更新) 文档保存在我的网站——软件知识原创基地上(www.umlonline.org),请放心下载. 1)软件设计是怎样炼成的?(2014-4-1 发 ...

  9. 干货!IT小伙伴们实用的网站及工具大集合!持续更新!

    1.Git 还在担心自己辛辛苦苦写的代码被误删了吗?还在担心自己改错了代码不能挽回吗?还在苦恼于多人开发合作找不到一个好的工具吗?那么用Git就对 了,Git是一个开源的分布式版本控制系统,用以有效. ...

随机推荐

  1. JAVA学习6:用Maven创建Spring3 MVC项目

    一.      环境 spring-framework-3.2.4.RELEASE jdk1.7.0_11 Maven3.0.5 eclipse-jee-juno-SR2-win32 二.      ...

  2. dubbo序列化hibernate.LazyInitializationException could not initialize proxy - no Session懒加载异常的解决

    dubbo序列化,hibernate.LazyInitializationException could not initialize proxy - no Session懒加载异常的解决 转载声明: ...

  3. CentOS下MySQL的安装过程

    1 查看 CentOS 自带的 mysql 输入命令: rpm -qa | grep mysql 2 将自带的MySQL卸载了 输入命令: rpm -e --nodeps mysql-libs-5.1 ...

  4. Hibernate 一对一映射(惟一外键)

  5. 自定义控件如何给特殊类型的属性添加默认值 z(转)

    自定义控件如何给特殊类型的属性添加默认值 z 定义控件如何给特殊类型的属性添加默认值了,附自定义GroupBox一枚 标题有点那啥,但确实能表达我掌握此法后的心情. 写自定义控件时往往会有一个需求,就 ...

  6. org.springframework.web.util.NestedServletException: Request processing failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [org.jboss.resteasy.plug

    之前做的项目是resteasy的上传,代码没有问题,断点都不进来呢. 我以为可以直接移植到SpringMVC,但是SpringMVC不支持MultipartFormDataInput , 用Multi ...

  7. ActiveMQ - 入门指南

    首先需要下载ActiveMQ,下面的链接给我们列出了所有版本: http://activemq.apache.org/download-archives.html 每个版本为不同的OS提供了链接: 公 ...

  8. DataGridView初始化,加载数据

    1,创建winform窗体应用程序 2,在界面上拖入DataGridView控件 3,添加相应的列如图: 4,开始编写后面的代码: private DataTable CountryDt = new ...

  9. MyBatis 学习(一)

    一.MyBatis 1.MyBatis 介绍(百度) MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数 ...

  10. 5、springboot之修改端口号

    在resources中加入application.properties文件,里面加入 servier.port = 端口号 访问的时候,就用localhost:端口号 完事