swiftSwift首页投稿(暂停使用,暂停投稿)

iOS-- 带上你的CLLocation出发

2016-04-12  本文已影响398人  奇董

目前打市面上大部分的‘爱啪啪’很多都用到了定位功能,对于我们这群开发🐶来说,定位属于必备技能了。

单纯的获取位置

使用苹果自家封装好的定位SDK,可以很快的获取到的当前手机的位置。
1.首先iOS8开始定位需要用户授权,在SDK中也多了两个授权的方法。
相应的在项目中的info文件中加上这两个键值对。NSLocationAlwaysUsageDescriptionNSLocationWhenInUseUsageDescription

2A1EA873-15EB-43B5-B27E-5BEB9CE5098B.png
key是苹果规定的, value 使我们自己设置的 用来显示询问授权时提示的文字。两对键值对 对应 两种模式。
import UIKit
import CoreLocation

class ViewController: UIViewController,CLLocationManagerDelegate {

    var locationManager = CLLocationManager()

    override func viewDidLoad() {
        super.viewDidLoad()
        locationManager.delegate = self
        if (Double(UIDevice.currentDevice().systemVersion) > 8.0) {
            //ios8 以后获取定位要获取授权的授权(2中授权模式)

            locationManager.requestAlwaysAuthorization()
//            locationManager.requestWhenInUseAuthorization()
        }
        locationManager.startUpdatingLocation()


    }
    func locationManager(manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {
        //更新的位置地点是一个数组,一般情况下 我们只需要获取最新的地点
        let larestLocation = locations.last
        print("x\(larestLocation?.coordinate.latitude)   y\(larestLocation?.coordinate.longitude)")
    }
}

单纯的获取定位其实很简单 就上面的代码介个步骤。可是苹果的定位SDK可不只是这么简单。

详细探讨苹果自家的CL

64902C5C-B3DA-4D9D-A2DD-1E22326DA16C.png

首先我们来看CL暴露出来的公共API
首先我们 来分析一些常用的接口吧。

Beacon

是iOS7出来的功能,主要基于蓝牙定位。我们知道在某个封闭的空间中其实GPS信号是非常弱的,这个时候就可以选择Beacon定位。可是徐泽Beacond定位需要在这个封闭的空间空间中布置大量的物理设备(蓝牙设备)来辅助定位。一般来说国内估计国内用的不多。这个比较有意思的,可以用两台手机来测试的,只要移动一定的距离,我们就可以知道。还是挺好玩的。
这里不详细讲解 给一扇传送门,有兴趣的童鞋 可以好好看一看。
http://www.cocoachina.com/industry/20140512/8377.html

Location

D0E67697-AAC1-41B1-88B9-7B18D7DA5F49.png
location有上面这么多属性。
其实在iOS8之后location 还有有一个Floor 的东西,可以知道你当前的设备处于哪一个楼层。可是这个东西,只有在苹果注册的应用能用到,不然只能返回nil
有很多外国童鞋,也遇到这个问题,大家可以可了解一下
http://stackoverflow.com/questions/24345840/clfloor-returning-nil-in-ios-8

Region

8A35BD5A-9C93-45C1-B5B0-5F2BCB6B99A1.png

描述范围区域,有这么一个类,这个类还是很常用的。

Heading

这个判定方向的一个类 也是location的一个属性

21E965FD-A9B9-432E-8E57-6376365B92D6.png

Geocoder 和 Placemark

地理编码器 和 地标信息

4A1E7C94-CA1C-4467-9984-CF6E89DB408A.png

看代码:

        //地理编码
        geocoder.geocodeAddressString("通州") { (placemarks,error) in
            let placemark: CLPlacemark = placemarks![0]
            print("\(placemark.addressDictionary)")

        }
        //反地理编码
        geocoder.reverseGeocodeLocation(CLLocation(latitude: 33.33,longitude: 88.3333)) { (placemarks, error) in
            if(placemarks?.count != 0) {
                let placemark: CLPlacemark = placemarks![0]
                print(placemark.name)
            }
        }

地理编码还有其他的两个更具体的方法
根据自身情况使用

    public func geocodeAddressDictionary(addressDictionary: [NSObject : AnyObject], completionHandler: CLGeocodeCompletionHandler)
    public func geocodeAddressString(addressString: String, inRegion region: CLRegion?, completionHandler: CLGeocodeCompletionHandler)

visit

这边引用NS上面的话:
很多应用程序,使用位置监控的原因是确定用户是否在某个确定的地方。概念上讲,你在想的是诸如“地方”或“访问”的名词术语,而不是原始的 GPS 坐标。
然而,除非你可以得益于使用区域监视(被限制在一个相对小的数量的区域)或室内定位( iBeacon )测距(这要求把室内定位硬件真正安装在一个空间内),否则用 Core Location 的后台监控工具并不是非常适合。开发一个登记应用或像 Moves 这样的全面的日志应用,位置监控和花费很多时间做特定处理一般意味着消耗大量的电量。
在 iOS 8 里, Apple 曾试图通过引进CLVisit
来解决这个问题, 这是一种新型的后台位置的监控。一个CLVisit
表示该用户已经处于某个位置的时间长度,包括一个坐标和开始/结束的时间戳。
理论上讲,使用访问监控并不比任何其他后台定位跟踪做更多的事。简单地调用manager.startMonitoringVisits()
将启用后台访问跟踪,假设用户同意授权你的应用程序“始终”的使用权限。一旦启动,你的应用程序将在有位置更新的时候在后台被唤醒,不像基本的定位监控,如果系统有个访问更新的队列(通常可以使更新延迟),你的 delegate 方法将被调用多次,每个单一的访问调用一次,而不是一个包含 CLLocation 对象的数组调用locationManager:didReceiveUpdates:
。调用manager.stopMonitoringVisits()
会停止跟踪。

更新

iOS9 后台定位需要

locationManager.allowsBackgroundLocationUpdates = YES;
A3D109DD-86D7-464A-8AF7-6851686DDC6E.png 3A4D9952-1FE0-40E9-8585-CF85D7105FF0.png
上一篇 下一篇

猜你喜欢

热点阅读