亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS中的地理位置的獲取及plist設置方法

2020-07-26 02:30:35
字體:
來源:轉載
供稿:網友

1、在前臺的時候獲取地理位置信息

ios 8/9

在info.plist中配置NSLocationWhenInUseUsageDescription的值,否則上面的方法無效

調用.requestWhenInUseAuthorization()獲取前臺獲取地理位置權限

調用.startUpdatingLocation()

代碼示例

class ViewController: UIViewController { lazy var locateM : CLLocationManager = {  let locate = CLLocationManager()  locate.delegate = self  locate.requestWhenInUseAuthorization()  return locate }() override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?) {  self.locateM.startUpdatingLocation() }}extension ViewController : CLLocationManagerDelegate{ func locationManager(manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {  print("位置信息已經更新") }}

2、前后臺獲取,但是后臺獲取的時候,屏幕上方有藍框提示用戶正在后臺獲取

ios8

調用.requestWhenInUseAuthorization()獲取前臺獲取地理位置權限

在info.plist中配置NSLocationWhenInUseUsageDescription的值,否則上面的方法無效

設置Capabilities>BackgroundModes>Location Updates 打對勾

調用.startUpdatingLocation()

ios9

調用.requestWhenInUseAuthorization()獲取前臺獲取地理位置權限

設置 .allowsBackgroundLocationUpdates = true (ios 9需要執行)

在info.plist中配置NSLocationWhenInUseUsageDescription的值,否則上面的方法無效

設置Capabilities>BackgroundModes>Location Updates 打對勾 (如果第二步做了,此步沒做,直接crash)

調用.startUpdatingLocation()

ios8/ios9可以后臺藍框定位的代碼示例:

class ViewController: UIViewController { lazy var locateM : CLLocationManager = {  let locate = CLLocationManager()  locate.delegate = self  locate.requestWhenInUseAuthorization()  if #available(iOS 9.0, *) {   locate.allowsBackgroundLocationUpdates = true  }  return locate }() override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?) {  self.locateM.startUpdatingLocation() }}extension ViewController : CLLocationManagerDelegate{ func locationManager(manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {  print("位置信息已經更新") }}

3、后臺獲取,后臺獲取的時候,屏幕上方無藍框提示

調用.requestAlwaysAuthorization()獲取前臺獲取地理位置權限

在info.plist中配置NSLocationAlwaysUsageDescription的值,否則上面的方法無效

設置 .allowsBackgroundLocationUpdates = true (ios 9需要執行)

設置Capabilities>BackgroundModes>Location Updates 打對勾 (本步驟在ios 8中可以不做設置,但是在ios9中如果第三步做了,而此步沒有做,直接crash)

調用.startUpdatingLocation()

代碼示例

class ViewController: UIViewController { lazy var locateM : CLLocationManager = {  let locate = CLLocationManager()  locate.delegate = self  locate.requestAlwaysAuthorization()  if #available(iOS 9.0, *) {   locate.allowsBackgroundLocationUpdates = true  }  return locate }() override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?) {  self.locateM.startUpdatingLocation() }}extension ViewController : CLLocationManagerDelegate{ func locationManager(manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {  print("位置信息已經更新") }}

4、權限改變的通知

注意:在Denied或者NotDetermined的狀態下startUpdatingLocation,開始監聽之后,當狀態改變成允許的狀態時,會直接進入監聽狀態,不必再次調用startUpdateingLocation

func locationManager(manager: CLLocationManager, didChangeAuthorizationStatus status: CLAuthorizationStatus) {  switch status {  case .AuthorizedAlways:   print("始終")  case .AuthorizedWhenInUse:   print("使用的時候")  case .Denied:   print("拒絕")   if CLLocationManager.locationServicesEnabled() {    print("真拒絕了")   }else{    print("是關閉了定位服務")   }  case .NotDetermined:   print("第一次,尚未決定")  case .Restricted:   print("沒有權限的")  } }

5、過濾距離

很多時候我們需要監聽函數只調用一次來獲取用戶當前的位置

在監聽函數中停止監聽

設置監聽的過濾距離

//如果監聽器已經開啟,此值修改之后立即生效self.locateM.distanceFilter = 100 //每100米,調用一次監聽

6、精度

注意:越精確越耗電,定位的時間越長,如果要定位城市,沒有必要選最精確的

self.locateM.desiredAccuracy = kCLLocationAccuracyBest //kCLLocationAccuracyBestForNavigation //kCLLocationAccuracyBest //kCLLocationAccuracyNearestTenMeters //kCLLocationAccuracyHundredMeters //kCLLocationAccuracyKilometer //kCLLocationAccuracyThreeKilometers

7.CLLocation詳解

public var coordinate: CLLocationCoordinate2D { get }  //經緯度public var altitude: CLLocationDistance { get }   //海拔public var horizontalAccuracy: CLLocationAccuracy { get } //位置信息是否有效,如果為負數,則無效 public var verticalAccuracy: CLLocationAccuracy { get } //海拔數據是否有效,如果為負數,則無效 public var course: CLLocationDirection { get }   //當前的角度(0-359.9)public var speed: CLLocationSpeed { get }     //當前的速度  public var timestamp: NSDate { get }      //位置確定的時間戳  public var floor: CLFloor? { get }      //樓層(前提是已經注冊的建筑),如果沒有為nil  //計算兩個經緯度之間的距離  public func distanceFromLocation(location: CLLocation) -> CLLocationDistance

8、指南針小例子

class ViewController: UIViewController { @IBOutlet weak var mImageView: UIImageView! lazy var locateM : CLLocationManager = {  let locate = CLLocationManager()  locate.delegate = self  locate.requestAlwaysAuthorization()  if #available(iOS 9.0, *) {   locate.allowsBackgroundLocationUpdates = true  }  return locate }() override func viewDidLoad() {  super.viewDidLoad()  if(CLLocationManager.headingAvailable()){   self.locateM.startUpdatingHeading()  }else{   print("當前磁力計有問題")  }  }}extension ViewController : CLLocationManagerDelegate{ func locationManager(manager: CLLocationManager, didUpdateHeading newHeading: CLHeading) {  //1.拿到當前設備對正朝向的角度  let angle = newHeading.magneticHeading  //2.把角度轉換成弧度  let hudu = CGFloat(angle / 180 * M_PI)  //3.反向旋轉照片  UIView.animateWithDuration(0.5) {    self.mImageView.transform = CGAffineTransformMakeRotation(-hudu)  } }}

9、區域的監聽

class ViewController: UIViewController { lazy var locateM : CLLocationManager = {  let locate = CLLocationManager()  locate.delegate = self  locate.requestAlwaysAuthorization()  if #available(iOS 9.0, *) {   locate.allowsBackgroundLocationUpdates = true  }  return locate }() override func viewDidLoad() {  super.viewDidLoad()  //首先應該判斷當前是否可以監聽某個區域  if CLLocationManager.isMonitoringAvailableForClass(CLCircularRegion){   //1.創建區域   let center = CLLocationCoordinate2DMake(21.123, 121.345)   var distance : CLLocationDistance = 1000   //限制監聽的范圍不能超過最大的范圍   if distance < locateM.maximumRegionMonitoringDistance{    distance = locateM.maximumRegionMonitoringDistance   }   let region = CLCircularRegion(center: center, radius: distance, identifier: "xiaoxiao")   //2.監聽區域   self.locateM.startMonitoringForRegion(region)   //3.判斷當前狀態是否是在區域內還是區域外,   //在`didDetermineState`代理方法中獲得結果   self.locateM.requestStateForRegion(region)  } }}extension ViewController : CLLocationManagerDelegate{ func locationManager(manager: CLLocationManager, didEnterRegion region: CLRegion) {  print("進入了區域"+region.identifier) } func locationManager(manager: CLLocationManager, didExitRegion region: CLRegion) {  print("出了區域"+region.identifier) } func locationManager(manager: CLLocationManager, didDetermineState state: CLRegionState, forRegion region: CLRegion) {  //獲取剛開始是否在區域內或者區域外  if region.identifier == "xiaoxiao"{   switch state {   case .Inside:    print("已經是區域內的")   case .Outside:    print("沒有在區域內")   case .Unknown:    print("不清楚")   }  } }}

10、地理編碼與反地理編碼

地理編碼

let geoCoder = CLGeocoder()geoCoder.geocodeAddressString("廣州") { (pls:[CLPlacemark]?, error : NSError?) in if error == nil{  print("地址編碼成功")  print(pls?.last?.location) }else{  print("錯誤 /(error)") }  }

打印

地址編碼成功

Optional(<+23.12517800,+113.28063700> +/- 100.00m (speed -1.00 mps / course -1.00) @ 8/14/16, 9:49:22 PM China Standard Time)

反地理編碼

let geoCoder = CLGeocoder()geoCoder.reverseGeocodeLocation(CLLocation(latitude:23.125,longitude: 113.280)) { (pls:[CLPlacemark]?, error:NSError?) in   if error == nil{    print("地址反編碼成功 城市:/(pls?.last?.locality)")    print(pls?.last?.addressDictionary)   }else{    print("錯誤 /(error)")   }  }

打印

地址反編碼成功 城市:Optional("Guangzhou")

Optional([SubLocality: Yuexiu, Street: Yunhai Tongjin No.11, State: Guangdong, CountryCode: CN, Thoroughfare: Yunhai Tongjin No.11, Name: Luo Sangmeidi, Country: China, FormattedAddressLines: <__NSArrayM 0x7ff1da5652d0>(Yunhai Tongjin No.11 Yuexiu,Guangzhou,Guangdong China), City: Guangzhou])

注意同一個CLGeocoder對象,不能同時編碼與反編碼

比如

let geoCoder = CLGeocoder()geoCoder.geocodeAddressString("廣州") { (pls:[CLPlacemark]?, error : NSError?) in ...}geoCoder.reverseGeocodeLocation(CLLocation(latitude:23.125,longitude: 113.280)) { (pls:[CLPlacemark]?, error:NSError?) in ... }

這樣只會打印第一個編碼成功的結果

11、CLPlacemark對象詳解

@NSCopying public var location: CLLocation? { get }    //經緯度@NSCopying public var region: CLRegion? { get }     //所關聯的地理區域@available(iOS 9.0, *)@NSCopying public var timeZone: NSTimeZone? { get }    //時間域public var addressDictionary: [NSObject : AnyObject]? { get } //詳細地址信息//addressDictionary中的屬性public var name: String? { get }     //名字 public var thoroughfare: String? { get }   //街道名字public var subThoroughfare: String? { get }  //子街道名字public var locality: String? { get }    //城市名稱public var subLocality: String? { get }   //鄰城市名稱public var administrativeArea: String? { get }  //行政區域 比如:CApublic var subAdministrativeArea: String? { get } //子行政區域public var postalCode: String? { get }    //郵政編碼public var ISOcountryCode: String? { get }   //國家代碼表public var country: String? { get }    //國家public var inlandWater: String? { get }   //內陸水域public var ocean: String? { get }     //海洋public var areasOfInterest: [String]? { get }  //興趣點

以上這篇iOS中的地理位置的獲取及plist設置方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久亚洲国产成人| 亚洲欧美日韩中文在线制服| 97精品国产97久久久久久| 色噜噜狠狠狠综合曰曰曰| 伊人久久男人天堂| 清纯唯美亚洲综合| 这里只有精品在线观看| 亚洲精品国产精品久久清纯直播| 神马久久桃色视频| 国产精品自产拍在线观看| 欧美黄色片免费观看| 日韩av第一页| 亚洲第一福利在线观看| 欧美精品18videos性欧美| 久久久久久综合网天天| 欧美日韩中文字幕综合视频| 92裸体在线视频网站| 日韩亚洲成人av在线| 欧美精品18videos性欧| 欧美激情亚洲自拍| 疯狂做受xxxx欧美肥白少妇| 91精品综合久久久久久五月天| 成人h视频在线观看播放| 91精品国产91久久久久| www.日韩不卡电影av| 日本高清视频精品| 最近2019中文字幕大全第二页| 日韩视频永久免费观看| 欧美日韩另类视频| 欧美在线免费视频| 久久人91精品久久久久久不卡| 成人在线精品视频| 国产精品久久久久久婷婷天堂| 欧美特黄级在线| 国产99久久精品一区二区 夜夜躁日日躁| 久久成人精品视频| 亚洲国产精品视频在线观看| 中文字幕九色91在线| 热99精品里视频精品| 日韩av中文字幕在线| 国产精品普通话| 国产精品精品久久久久久| 欧美成人h版在线观看| 8090成年在线看片午夜| 日韩在线视频线视频免费网站| 国产在线播放不卡| 亚洲欧洲av一区二区| 91成人福利在线| 欧美福利视频在线| 69av成年福利视频| 欧美性xxxx在线播放| 在线观看欧美www| 国产精品精品视频一区二区三区| 国产精品电影网站| 97国产精品久久| 亚洲欧美制服综合另类| 久久久免费观看| 午夜精品一区二区三区在线| 欧美激情亚洲国产| 欧美日韩电影在线观看| 精品国产区一区二区三区在线观看| 91亚洲国产精品| 亚洲国产小视频| 欧美性极品xxxx做受| 国产69精品久久久久99| 欧美性受xxxx黑人猛交| 色综合久久精品亚洲国产| 久久高清视频免费| 中文字幕最新精品| 欧美在线观看网站| 2019中文在线观看| 国模视频一区二区三区| 亚洲精品mp4| 亚洲精品乱码久久久久久金桔影视| 久久在线精品视频| 精品亚洲一区二区| 4438全国成人免费| 在线看日韩欧美| 黑人巨大精品欧美一区二区三区| 欧美激情性做爰免费视频| 欧美亚州一区二区三区| 日韩欧美精品中文字幕| 亚洲精品xxx| 国产mv久久久| 精品久久久久久中文字幕| 日韩三级成人av网| 欧美—级高清免费播放| 欧美成人四级hd版| 亚洲欧美日韩网| 亚洲春色另类小说| 欧美最近摘花xxxx摘花| 北条麻妃一区二区三区中文字幕| 日韩av三级在线观看| 日韩av日韩在线观看| 亚洲国产精品高清久久久| 亚洲第一级黄色片| 午夜精品一区二区三区在线视频| 96精品视频在线| 欧美视频在线观看免费网址| 性欧美长视频免费观看不卡| 国产午夜精品麻豆| 国产999精品视频| 中文字幕视频一区二区在线有码| 国产v综合ⅴ日韩v欧美大片| 国产成人高清激情视频在线观看| 日本成人在线视频网址| 欧美日韩激情视频| 午夜精品在线视频| 久久久精品在线| 久久久久成人网| 成人激情电影一区二区| 久久精品国产一区二区三区| 日韩电影免费在线观看中文字幕| 精品成人69xx.xyz| 2019中文字幕在线观看| 欧美午夜视频在线观看| 国产精品视频精品视频| 97婷婷涩涩精品一区| 国产精品成人v| 亚洲一级黄色av| 国产综合久久久久| 91精品国产色综合久久不卡98口| 久久艳片www.17c.com| 在线观看视频亚洲| 欧美一级电影免费在线观看| 亚洲一区二区三区四区在线播放| 国产日韩av在线播放| 国产日韩在线一区| 成人国产精品免费视频| 国产精品极品美女粉嫩高清在线| 国产日韩欧美电影在线观看| 欧美性xxxx18| 成人久久一区二区三区| 亚洲自拍av在线| 国产精品免费久久久久影院| 97在线视频一区| 欧美成年人在线观看| 久久精品亚洲精品| 欧美激情视频网| 国产一区二区欧美日韩| 国产精品激情av电影在线观看| 亚洲视频免费一区| 日韩欧美亚洲范冰冰与中字| 国产精品美女主播| 欧美黑人又粗大| 欧美日韩亚洲激情| 亚洲人成亚洲人成在线观看| 国产精品无码专区在线观看| 国产精品久久二区| www.久久草.com| 亚洲精品wwww| 91免费看片网站| 国产精品第3页| 精品网站999www| 欧美与欧洲交xxxx免费观看| 欧美黑人巨大xxx极品| 国产男女猛烈无遮挡91| 国产精品香蕉在线观看| 久久天天躁狠狠躁夜夜躁| 日韩视频一区在线| 91国产高清在线| 国产噜噜噜噜噜久久久久久久久| 日韩精品在线视频观看| 亚洲字幕在线观看|