11

每当用户登录时以及在其他几个地方,我都会调用当前位置。每当我这样做时,请求用户许可的警报视图会出现一秒钟左右,然后消失。显然,我不知道位置。每次我提示位置时都会发生这种情况。它不允许用户单击取消或确定。请帮忙

4

4 回答 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 回答