2013-12-09 3 views
0

Я пытаюсь найти местоположения пользователей на переднем плане & фон. Мне нужно вызвать api после обновления локации. Для работы в фоновом режиме я хочу использовать метод «Отсрочка». Я следил за тем же процессом, как описано в Apple WWDC. Я проверяю приложение на iPhone 5 (iOS 7). Он работает нормально, когда я нахожусь на переднем плане, но не дал мне обновления после отправки приложения в фоновом режиме. Ниже приведен код, который я использую, чтобы получить местоположение в фоновом режиме.deffered Обновления местоположения не доступны

#import "AppDelegate.h" 
@implementation AppDelegate 

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions 

{ 
    self.locationArray = [[NSMutableArray alloc] init]; 

    self.locationErrorArray = [[NSMutableArray alloc] init]; 
    self.manager_loc = [[CLLocationManager alloc] init]; 

    self.manager_loc.activityType = CLActivityTypeFitness; 

    self.manager_loc.delegate = self; 

    [self.manager_loc setDesiredAccuracy:kCLLocationAccuracyBest]; 

    [self.manager_loc startUpdatingLocation]; 
return YES; 

} 

- (void)applicationWillResignActive:(UIApplication *)application 

{ 
    // Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state. 

    // Use this method to pause ongoing tasks, disable timers, and throttle down OpenGL ES frame rates. Games should use this method to pause the game. 

} 

- (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. 

} 



- (void)applicationWillEnterForeground:(UIApplication *)application 

{ 

    // Called as part of the transition from the background to the inactive state; here you can undo many of the changes made on entering the background. 

} 

- (void)applicationDidBecomeActive:(UIApplication *)application 

{ 

    // Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface. 

} 

- (void)applicationWillTerminate:(UIApplication *)application 

{ 

    // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:. 

} 


#pragma mark - Location Manager Delgate 
-(void)locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error 

{ 
    NSLog(@"update failed"); 
} 


-(void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations 

{ 

    [self.locationArray addObject:locations]; 

    NSLog(@"udate locations %f %f", manager.location.coordinate.latitude, manager.location.coordinate.longitude); 



    if (!self.deferredStatus) 

    { 

     self.deferredStatus = YES; 

     [self.manager_loc allowDeferredLocationUpdatesUntilTraveled:100 timeout:30]; 

    } 
[self.manager_loc stopUpdatingLocation]; 

} 



-(void)locationManager:(CLLocationManager *)manager didFinishDeferredUpdatesWithError:(NSError *)error 

{if (manager.location != nil) 

    { [self.locationArray addObject:manager.location]; 

    } 


    if (error != nil) 

    { 

     [self.locationErrorArray addObject:error.description]; 

    } 

    self.deferredStatus = NO; 



    NSLog(@"deffered success %f %f", manager.location.coordinate.latitude, manager.location.coordinate.longitude); 

} 

@end 

Если я не остановить обновление местоположения в didUpdateToLocations делегатом затем местоположение стрелка (в строке состояния) не идут. В этом случае он дает мне места contionusly. Я хочу обновление местоположения по истечении определенного времени или пройденного расстояния, чтобы я мог поразить сервер с помощью локаций пользователя. Пожалуйста помоги мне с этим.

ответ

0

Использование LocationManger distanceFilter Имущество для размещения обновлений на определенном расстоянии.

self.manager_loc.distanceFilter= 100;// In meters 
0

Если вы хотите, чтобы местоположение было обновлено в Backggriound, зарегистрируйтесь для получения обновлений для фона. Youca может сделать это в plist.

Установить менеджер места для:

if ([self.locationManager respondsToSelector:@selector(pausesLocationUpdatesAutomatically)]) { 
     self.locationManager.pausesLocationUpdatesAutomatically = NO; 
} 

Тогда Если вы хотите место обновляемого через некоторое время или расстояние, то используйте:

- (void)allowDeferredLocationUpdatesUntilTraveled:(CLLocationDistance)distance 
         timeout:(NSTimeInterval)timeout // No guaranty it will work exactly or not 

Если вы хотите местоположение обновляется на основе расстояния вы можете использовать Желаемая точность и свойство distanceFilter.

self.locationManager.desiredAccuracy = kCLLocationAccuracyThreeKilometers;// Use other accurarcy as your need 
self.locationManager.distanceFilter = 3000; //100, 200, etc 

Если установить тип активности в CLActivityTypeFitness будет перекрытая все выше настройки, а менеджер местоположения обновляется в соответствии с этой деятельностью, которая, как мне известно будет есть аккумулятор.

При использовании диспетчера CLLocation одна вещь, которую вы должны принять, не даст всем обновлениям точность 100%.

+0

В iOS7 [locationmanager startupdatinglocation] не работает в фоновом режиме. Если я запускаю диспетчер местоположений на переднем плане и не останавливаю его в updateToLocations: делегат, то знак стрелки (в строке состояния) не исчезает. В этом сценарии я получаю местоположение после того, как я путешествовал на определенном расстоянии, но он очень быстро разряжает батарею. Можете ли вы предоставить мне альтернативный код для достижения желаемой цели. – user3073979

0

Смотрите мой ответ на этот пост: StartUpdateLocations in Background, didUpdatingToLocation only called 10-20 times

Если вам нужно геоданных в фоновом режиме под прошивкой 7, вы должны вызвать startUpdatingLocation в то время как ваше приложение находится на переднем плане. Вы больше не можете этого делать, пока ваше приложение находится в фоновом режиме, поэтому вы больше не можете регистрировать обновления местоположений только тогда, когда они вам понадобятся, и в то время как они вам нужны. Вы вынуждены регистрироваться для них в течение всего времени работы вашего приложения (на переднем плане и в фоновом режиме), и поэтому вы вынуждены тратить много энергии.

Вы можете немного уменьшить заряд батареи, установив точность в kCLLocationAccuracyThreeKilometers, когда вам не нужны обновления местоположения и установите их в kCLLocationAccuracyBest только тогда, когда вам нужны обновления. Но это, тем не менее, разряжает аккумулятор быстрее, чем ожидалось.

Пожалуйста, напишите отчет об ошибке Apple и попросите «старое» поведение iOS 4,5 и 6, где вы можете называть «startUpdatingLocation» в фоновом режиме, а также получать обновления местоположения в фоновом режиме. достаточно запросов на изменение этого поведения до того, как он был реализован в iOS 5/6, тем более вероятно, что Apple изменит это значение.

Ситуация с токами действительно плохая.Плохо для разработчиков, которые вынуждены тратить энергию или отказываться от своих приложений, что плохо для пользователя, чье устройство необходимо подключить к источнику питания намного раньше или кто больше не может использовать определенные приложения.

Смежные вопросы