每当用户登录时以及在其他几个地方,我都会调用当前位置。每当我这样做时,请求用户许可的警报视图会出现一秒钟左右,然后消失。显然,我不知道位置。每次我提示位置时都会发生这种情况。它不允许用户单击取消或确定。请帮忙
问问题
2399 次
4 回答
19
您可能没有保留 locationManager。结果,当您调用 [CLLocationManager startUpdatingLocation]
警报时,会显示警报,但一旦释放 locationManager,它就会消失。当我在为我的 locationManger 实例创建的属性中输入 assign 而不是 strong 时,曾经发生过这种情况。
于 2012-11-16T14:54:41.310 回答
2
我的项目(swift lang)也面临同样的问题。
试试这个,将CLLocationmanage 变量声明为全局变量并在你想要的地方调用。
前任:
var locManager = CLLocationManager()
override func viewDidLoad()
{
super.viewDidLoad()
let iOS7 = floor(NSFoundationVersionNumber) <= floor(NSFoundationVersionNumber_iOS_7_1)
let iOS8 = floor(NSFoundationVersionNumber) > floor(NSFoundationVersionNumber_iOS_7_1)
locManager.delegate = self
locManager.desiredAccuracy = kCLLocationAccuracyBest
if(iOS8)
{
locManager.requestAlwaysAuthorization()// only support ios 8.0
}
}
于 2015-04-29T04:55:42.463 回答
0
尝试在 startUpdatingLocation 之后移动委托设置器方法。这个对我有用。例子:
CLLocationManager *m = [[CLLocationManager alloc] init];
[m startUpdatingLocation];
m.delegate = self;
哎呀,我的英语很差。
于 2015-05-11T07:51:41.473 回答
0
我无法评论他的帖子,所以我在这里回答。
Gianluca Tranchedone 是对的。我的情况是,我保留了 CLLocationManager。但是:它在显示 AlertView 之后立即触发第一个回调,以告诉委托状态未确定。当收到任何回调时,我犯了释放实例的错误。
这就是该方法现在的样子并且它有效:
-(void)locationManager:(CLLocationManager*)manager didChangeAuthorizationStatus:(CLAuthorizationStatus)status {
switch (status) {
case kCLAuthorizationStatusNotDetermined:
break;
default:
_locationManagerForAuthorizationRequest.delegate = nil;
self.locationManagerForAuthorizationRequest = nil;
}
}
于 2015-06-02T10:09:26.490 回答