定位框一闪而过 iOS Swift
需求:获取经纬度。
方案:我自定义了一个类模块CLLocationModule.swift
备注以下代码里
let IS_IOS8 = (UIDevice.currentDevice().systemVersion as NSString).doubleValue >= 8.0
最开始的代码
import UIKit
import CoreLocation
class CLLocationModule: NSObject ,CLLocationManagerDelegate{
var latitude:Double?
var longitude:Double?
var city:NSString?
func GetLatitudeLongitudeAndCity(){
if CLLocationManager.locationServicesEnabled() == false {
print("此设备不能定位")
return
}
var locManager = CLLocationManager()
locManager.delegate = self
locManager.desiredAccuracy = kCLLocationAccuracyBest
locManager.distanceFilter = 1000.0
//设置定位权限仅ios8有意义
if IS_IOS8 {
locManager.requestWhenInUseAuthorization()// 前台定位
locManager.requestAlwaysAuthorization()
}
locManager.startUpdatingLocation()
}
func locationManager(manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {
for location in locations {
print("纬度:%g",location.coordinate.latitude);
print("经度:%g",location.coordinate.longitude);
latitude = location.coordinate.latitude
longitude = location.coordinate.longitude
self.saveLatitude(latitude!.description)
self.saveLongitude(longitude!.description)
let geocoder: CLGeocoder = CLGeocoder()
geocoder.reverseGeocodeLocation(location) { (placemarks, error) in
if error != nil {
print("reverse geodcode fail: \(error!.localizedDescription)")
return
}
let pm = placemarks! as [CLPlacemark]
if (pm.count > 0){
for placemark :CLPlacemark in placemarks! {
let placemarkDict = placemark.addressDictionary
let placemarkStr = placemarkDict!["State"]
self.city = placemarkStr?.substringToIndex((placemarkStr?.length)!-1)
self.saveCity(self.city!)
}
}else{
print("No Placemarks!")
}
}
}
manager.stopUpdatingLocation()
}
func locationManager(manager:CLLocationManager, didFailWithError error:NSError) {
print("locationManager error");
}
func saveLatitude(latitude: NSString) {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
defaults.setObject(latitude, forKey: "latitude")
defaults.synchronize()
}
func readLatitude() -> NSString {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
let latitude = defaults.objectForKey("latitude") as! NSString
return latitude;
}
func saveLongitude(longitude: NSString) {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
defaults.setObject(longitude, forKey: "longitude")
defaults.synchronize()
}
func readLongitude() -> NSString {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
let longitude = defaults.objectForKey("longitude") as! NSString
return longitude;
}
func saveCity(city: NSString) {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
defaults.setObject(city, forKey: "city")
defaults.synchronize()
}
func readCity() -> NSString {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
let city = defaults.objectForKey("city") as! NSString
return city;
}
}
外部调用是:
CLLocationModule().GetLatitudeLongitudeAndCity()
结果:定位框一闪而过 (允许 不允许那个弹出框) 导致不走代理方法didUpdateLocations 最后查阅网页 知道

(a)locManager没定义为全局变量
(b)自定义的CLLocationModule.swift这个类 由于ARC的缘故 自动释放了
针对以上(a)问题的解决办法为自定义类CLLocationModule.swift中将var locManager = CLLocationManager() 改为全局变量
var locManager: CLLocationManager!
locManager = CLLocationManager()
针对以上(b)问题的解决方案有两种
(1)外部调用时改为:(改为强引用)
var aCLLocationModule = CLLocationModule()
self.aCLLocationModule.GetLatitudeLongitudeAndCity()
(2)自定义的类CLLocationModule.swift改为单例
//单例
private static let aSharedInstance: CLLocationModule = CLLocationModule()
private override init() {}
class func sharedInstance() -> CLLocationModule {
return aSharedInstance
}
外部调用时改为:
CLLocationModule.sharedInstance().GetLatitudeLongitudeAndCity()
成功的代码附上两份
(1)单例
import UIKit
import CoreLocation
class CLLocationModule: NSObject ,CLLocationManagerDelegate{
//单例
private static let aSharedInstance: CLLocationModule = CLLocationModule()
private override init() {}
class func sharedInstance() -> CLLocationModule {
return aSharedInstance
}
var locManager: CLLocationManager!
var latitude:Double?
var longitude:Double?
var city:NSString?
func GetLatitudeLongitudeAndCity(){
if CLLocationManager.locationServicesEnabled() == false {
print("此设备不能定位")
return
}
locManager = CLLocationManager()
locManager.delegate = self
locManager.desiredAccuracy = kCLLocationAccuracyBest
locManager.distanceFilter = 1000.0
//设置定位权限仅ios8有意义
if IS_IOS8 {
locManager.requestWhenInUseAuthorization()// 前台定位
locManager.requestAlwaysAuthorization()
}
locManager.startUpdatingLocation()
}
func locationManager(manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {
for location in locations {
print("纬度:%g",location.coordinate.latitude);
print("经度:%g",location.coordinate.longitude);
latitude = location.coordinate.latitude
longitude = location.coordinate.longitude
self.saveLatitude(latitude!.description)
self.saveLongitude(longitude!.description)
let geocoder: CLGeocoder = CLGeocoder()
geocoder.reverseGeocodeLocation(location) { (placemarks, error) in
if error != nil {
print("reverse geodcode fail: \(error!.localizedDescription)")
return
}
let pm = placemarks! as [CLPlacemark]
if (pm.count > 0){
for placemark :CLPlacemark in placemarks! {
let placemarkDict = placemark.addressDictionary
let placemarkStr = placemarkDict!["State"]
self.city = placemarkStr?.substringToIndex((placemarkStr?.length)!-1)
self.saveCity(self.city!)
}
}else{
print("No Placemarks!")
}
}
}
manager.stopUpdatingLocation()
}
func locationManager(manager:CLLocationManager, didFailWithError error:NSError) {
print("locationManager error");
}
func saveLatitude(latitude: NSString) {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
defaults.setObject(latitude, forKey: "latitude")
defaults.synchronize()
}
func readLatitude() -> NSString {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
let latitude = defaults.objectForKey("latitude") as! NSString
return latitude;
}
func saveLongitude(longitude: NSString) {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
defaults.setObject(longitude, forKey: "longitude")
defaults.synchronize()
}
func readLongitude() -> NSString {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
let longitude = defaults.objectForKey("longitude") as! NSString
return longitude;
}
func saveCity(city: NSString) {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
defaults.setObject(city, forKey: "city")
defaults.synchronize()
}
func readCity() -> NSString {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
let city = defaults.objectForKey("city") as! NSString
return city;
}
}
外部调用:
CLLocationModule.sharedInstance().GetLatitudeLongitudeAndCity()
(2)强引用
import UIKit
import CoreLocation
class CLLocationModule: NSObject ,CLLocationManagerDelegate{
var locManager: CLLocationManager!
var latitude:Double?
var longitude:Double?
var city:NSString?
func GetLatitudeLongitudeAndCity(){
if CLLocationManager.locationServicesEnabled() == false {
print("此设备不能定位")
return
}
locManager = CLLocationManager()
locManager.delegate = self
locManager.desiredAccuracy = kCLLocationAccuracyBest
locManager.distanceFilter = 1000.0
//设置定位权限仅ios8有意义
if IS_IOS8 {
locManager.requestWhenInUseAuthorization()// 前台定位
locManager.requestAlwaysAuthorization()
}
locManager.startUpdatingLocation()
}
func locationManager(manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {
for location in locations {
print("纬度:%g",location.coordinate.latitude);
print("经度:%g",location.coordinate.longitude);
latitude = location.coordinate.latitude
longitude = location.coordinate.longitude
self.saveLatitude(latitude!.description)
self.saveLongitude(longitude!.description)
let geocoder: CLGeocoder = CLGeocoder()
geocoder.reverseGeocodeLocation(location) { (placemarks, error) in
if error != nil {
print("reverse geodcode fail: \(error!.localizedDescription)")
return
}
let pm = placemarks! as [CLPlacemark]
if (pm.count > 0){
for placemark :CLPlacemark in placemarks! {
let placemarkDict = placemark.addressDictionary
let placemarkStr = placemarkDict!["State"]
self.city = placemarkStr?.substringToIndex((placemarkStr?.length)!-1)
self.saveCity(self.city!)
}
}else{
print("No Placemarks!")
}
}
}
manager.stopUpdatingLocation()
}
func locationManager(manager:CLLocationManager, didFailWithError error:NSError) {
print("locationManager error");
}
func saveLatitude(latitude: NSString) {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
defaults.setObject(latitude, forKey: "latitude")
defaults.synchronize()
}
func readLatitude() -> NSString {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
let latitude = defaults.objectForKey("latitude") as! NSString
return latitude;
}
func saveLongitude(longitude: NSString) {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
defaults.setObject(longitude, forKey: "longitude")
defaults.synchronize()
}
func readLongitude() -> NSString {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
let longitude = defaults.objectForKey("longitude") as! NSString
return longitude;
}
func saveCity(city: NSString) {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
defaults.setObject(city, forKey: "city")
defaults.synchronize()
}
func readCity() -> NSString {
let defaults: NSUserDefaults = NSUserDefaults.standardUserDefaults()
let city = defaults.objectForKey("city") as! NSString
return city;
}
}
外部调用:
var aCLLocationModule = CLLocationModule()
self.aCLLocationModule.GetLatitudeLongitudeAndCity()
定位框一闪而过 iOS Swift的更多相关文章
- iOS swift的xcworkspace多项目管理(架构思想)
iOS swift的xcworkspace多项目管理(架构思想) 技术说明: 今天在这里分享 swift下的 xcworkspace多项目管理(架构思想),能为我们在开发中带来哪些便捷?能为我们对整 ...
- iOS Swift 模块练习/swift基础学习
SWIFT项目练习 SWIFT项目练习2 iOS Swift基础知识代码 推荐:Swift学习使用知识代码软件 0.swift中的宏定义(使用方法代替宏) 一.视图 +控件 1.UIImag ...
- ios swift 实现饼状图进度条,swift环形进度条
ios swift 实现饼状图进度条 // // ProgressControl.swift // L02MyProgressControl // // Created by plter on 7/2 ...
- Building gRPC Client iOS Swift Note Taking App
gRPC is an universal remote procedure call framework developed by Google that has been gaining inter ...
- iOS Swift WisdomScanKit图片浏览器功能SDK
iOS Swift WisdomScanKit图片浏览器功能SDK使用 一:简介 WisdomScanKit 由 Swift4.2版编写,完全兼容OC项目调用. WisdomScanKit的 ...
- iOS Swift WisdomScanKit二维码扫码SDK,自定义全屏拍照SDK,系统相册图片浏览,编辑SDK
iOS Swift WisdomScanKit 是一款强大的集二维码扫码,自定义全屏拍照,系统相册图片编辑多选和系统相册图片浏览功能于一身的 Framework SDK [1]前言: 今天给大家 ...
- iOS Swift WisdomHUD 提示界面框架
iOS Swift WisdomHUD 提示界面框架 Framework Use profile(应用简介) 一:WisdomHUD简介 今天给大家介绍一款iOS的界面显示器:WisdomHUD,W ...
- iOS Swift WisdomKeyboardKing 键盘智能管家SDK
iOS Swift WisdomKeyboardKing 键盘智能管家SDK [1]前言: 今天给大家推荐个好用的开源框架:WisdomKeyboardKing,方面iOS日常开发,优点和功能请 ...
- iOS swift项目IM实现,从长连接到数据流解析分析之Socket
iOS swift项目IM实现,从长连接到底层数据解析分析之Socket 一:项目简介: 去年开始接手了一个国企移动项目,项目的需求是实现IM即时通讯功能. * 一期版本功能包括了: ...
随机推荐
- Atitit 软件国际化原理与概论
Atitit 软件国际化原理与概论 语言和文化习俗因地域不同而差别很大.对某一特定的地域的 语言环境称为"locale".它不仅包括语言和货币单位,而且还包括 数字标示格式, 日期 ...
- android清除本应用里的各种数据的方法
public class DataCleanManager { /** * * 清除本应用内部缓存(/data/data/com.xxx.xxx/cache) * * * * @param conte ...
- git基础
1.新的未跟踪文件 新创建的README文件没有进行任何跟踪 $ git status On branch master Untracked files: (use "git add < ...
- SOA服务类项目开发模式
开发模式 以需求用例为基,Cas e&Coding两条线并行,服务(M)&消费(VC)分离,单元.接口.功能.集成四层质量管理,自动化集成.测试.交付全程支持. 3个大阶段(需求分析阶 ...
- Visual Studio 中 Build 和 Rebuild 的区别
因为之前写的程序比较小,编译起来比较快,所以一直都没有太在意 Build 和 Rebuild 之间的区别,后来发现两个还是有很大不同. Build 只针对在上次编译之后更改过的文件进行编译,在项目比较 ...
- Scala变量(三)
变量是一种使用方便的占位符,用于引用计算机内存地址,变量创建后会占用一定的内存空间. 基于变量的数据类型,操作系统会进行内存分配并且决定什么将被储存在保留内存中.因此,通过给变量分配不同的数据类型,你 ...
- SQL SERVER 2008复制数据库时发生执行SQL Server代理作业错误
1. 情况说明 在利用SQL SERVER数据库复制向导,能够很方便的将一个数据库从一台服务器复制到另一台服务器上,具体操作步骤也十分简单. 不过在实际操作过程常发生“执行SQL SERVER代理作业 ...
- 创建docker私人仓库
关于创建docker私人仓库 1.1. 安装步骤 1.1.1. 直接从公共库上面下载register镜像在本地执行 1.1.1.1. ...
- plain framework 商业版 开发总结1 updated
每天对着不同的计划,多多少少有一种无形的压力.特别是对技术不好的我来说,过程中遇到的问题实在不少,时常纠结良久.时间慢慢流逝,最后虽然感觉有些不足,但是也不至于差强人意.商业版的PF核心已经升级到1. ...
- USACO . Friday the Thirteenth
Friday the Thirteenth Is Friday the 13th really an unusual event? That is, does the 13th of the mont ...