之前有做一个定位的项目,类似嘀嘀打车那样。 需要后台持续定位。
这里选择了百度地图,不过在后台持续定位方面, 之前只是简单的设置如下:
不过经测试发现, 这样设置完,在后台运行大概30分钟,又会被crash掉。 重新打开应用则自动恢复定位。< 喎�"http://www.2cto.com/kf/ware/vc/" target="_blank" class="keylink">vcD48cD48YnIgLz48L3A+PHA+tbHIu6Os1eKyu8rHztLDx8/r0qq1xNCnufujrMv50tTV28zawcvPwqOsyrXP1sHLuvPMqLPW0Pi2qM67oaM8L3A+PHA+19y1xMC0y7WjrL7NysfA+9PDvfjI67rzzKi6887Sw8e/ybLZv9i1xDEwt9bW06OswLTN6rPJ0rvQqcrCx+mhozwvcD48cD7OqrTvtb2z1tD4tqjOu6Osw78xMLfW1tOho9fUtq/W2NDCv6rG9Laozruho9Xi0fm+zb3ivvbOysziwcuhozwvcD48cD48YnIgLz48L3A+PHA+vt/M5cjnz8I6PC9wPjxwPjxiciAvPjwvcD48cD5BcHBEZWxlZ2F0ZS5oPGJyIC8+PC9wPjxwPjxwcmUgY2xhc3M9"brush:java;">@property (nonatomic, unsafe_unretained) UIBackgroundTaskIdentifier bgTask;
AppDelegate.m1234567891011121314151617181920212223242526272829- (
void
)backgroundHandler
{
NSLog(@
"### -->backgroundinghandler"
);
UIApplication* app = [UIApplication sharedApplication];
bgTask = [app beginBackgroundTaskWithExpirationHandler:^{
[app endBackgroundTask:bgTask];
bgTask = UIBackgroundTaskInvalid;
}];
// Start the long-running task
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,
0
), ^{
// 您想做的事情,
// 比如我这里是发送广播, 重新激活定位
// 取得ios系统唯一的全局的广播站 通知中心
NSNotificationCenter *nc = [NSNotificationCenter defaultCenter];
//设置广播内容
NSDictionary *dict = [[NSDictionary alloc]init];
//将内容封装到广播中 给ios系统发送广播
// LocationTheme频道
[nc postNotificationName:@
"LocationTheme"
object:self userInfo:dict];
});
}
123456789101112131415- (
void
)applicationDidEnterBackground:(UIApplication *)application
{
// Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later.
// If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits.
BOOL backgroundAccepted = [[UIApplication sharedApplication] setKeepAliveTimeout:
600
handler:^{ [self backgroundHandler]; }];
if
(backgroundAccepted)
{
NSLog(@
"backgrounding accepted"
);
}
[self backgroundHandler];
}
然后在开启定位的位置,成为广播接收者,并且重新激活定位
12345//初始化BMKLocationService
myLocService = [[BMKLocationService alloc]init];
myLocService.delegate = self;
//启动LocationService
[myLocService startUserLocationService];
1234NSNotificationCenter *nc2 = [NSNotificationCenter defaultCenter];
// 成为听众一旦有广播就来调用self recvBcast:函数
[nc2 addObserver:self selector:
@selector
(activeLocation:) name:@
"LocationTheme"
object:nil];
123456789- (
void
) activeLocation:(NSNotification *)notify
{
[myLocService stopUserLocationService];
//初始化BMKLocationService
myLocService = [[BMKLocationService alloc]init];
myLocService.delegate = self;
//启动LocationService
[myLocService startUserLocationService];
}
当然,上面的方式,可能方法比较渣,代码也写的比较乱。
只是提供一种解决办法而已。