Базовое расположение не работает с Apple Watch

У меня есть файл GPX, который выглядит так:

<?xml version="1.0" encoding="UTF-8"?>
<gpx
  version="1.0"
  creator="GPSBabel - http://www.gpsbabel.org"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns="http://www.topografix.com/GPX/1/0"
  xsi:schemaLocation="http://www.topografix.com/GPX/1/0 http://www.topografix.com/GPX/1/0/gpx.xsd">
<time>2015-04-03T15:04:33Z</time>
<bounds minlat="32.994533333" minlon="35.573600000" maxlat="33.176883333" maxlon="35.630866667"/>
<trk>
  <name>GNSSALTTRK</name>
  <desc>IGCHDRS~HFFXA035~HFPLTPILOTINCHARGE: pilot~HFCM2CREW2: not recorded~HFGTYGLIDERTYPE:unknown~HFGIDGLIDERID:unknown~HFDTM100GPSDATUM: WGS-1984~HFRFWFIRMWAREVERSION: 1.00~HFRHWHARDWAREVERSION: 2012~HFFTYFRTYPE: ParaWind by Dr. Edgar Bolender~HFGPSGPS:Smartphone~HFPRSPRESSALTSENSOR: Smartphone~HFCIDCOMPETITIONID:~HFCCLCOMPETITIONCLASS:~</desc>
<trkseg>
<trkpt lat="33.060316667" lon="35.625166667">
  <ele>88.000000</ele>
  <time>2014-08-23T03:58:58Z</time>
</trkpt>
<trkpt lat="33.061700000" lon="35.624750000">
  <ele>81.000000</ele>
  <time>2014-08-23T03:59:11Z</time>
</trkpt>
<trkpt lat="33.062650000" lon="35.624250000">
  <ele>83.000000</ele>
  <time>2014-08-23T03:59:21Z</time>
</trkpt>
<trkpt lat="33.064316667" lon="35.624033333">
  <ele>88.000000</ele>
  <time>2014-08-23T03:59:37Z</time>
</trkpt>
<trkpt lat="33.065833333" lon="35.623866667">
  <ele>86.000000</ele>
  <time>2014-08-23T03:59:51Z</time>
</trkpt>
<trkpt lat="33.066983333" lon="35.623500000">
  <ele>84.000000</ele>
  <time>2014-08-23T04:00:02Z</time>
</trkpt>
....

Я добавил его в текущую схему и запустил, но не получил изменения местоположения. Я подозревал, что это связано со старыми временными тегами, но даже после изменения системного времени на время, относящееся к файлу GPX, он не вызывал события местоположения.

Теперь я подозреваю, что я делаю что-то не так с моей моделью, потому что приложение не просит пользователя использовать местоположение (это приложение для часов Apple)

#import "LocationModel.h"
#import <CoreLocation/CoreLocation.h>


@interface LocationModel ()<CLLocationManagerDelegate>
@property (nonatomic, strong) CLLocationManager* locationManager;

@end

@implementation LocationModel
static LocationModel* sharedInstance;
@synthesize locationManager;

#pragma mark - private

- (void)startStandardUpdates
{
    // Create the location manager if this object does not
    // already have one.
    if (nil == locationManager)
    {
        locationManager = [[CLLocationManager alloc] init];
    }

    locationManager.delegate = self;
    locationManager.desiredAccuracy = kCLLocationAccuracyBest;

    // Set a movement threshold for new events.
    locationManager.distanceFilter = 1; // meters

    [locationManager startUpdatingLocation];

    // Start heading updates.
    if ([CLLocationManager headingAvailable]) {
        locationManager.headingFilter = 5;
        [locationManager startUpdatingHeading];
    }
}


#pragma mark - CLLocationManagerDelegate

- (void)locationManager:(CLLocationManager *)manager
     didUpdateLocations:(NSArray *)locations {
    // If it's a relatively recent event, turn off updates to save power.
    CLLocation* location = [locations lastObject];
    NSDate* eventDate = location.timestamp;
    NSTimeInterval howRecent = [eventDate timeIntervalSinceNow];
    if (abs(howRecent) < 15.0) {
        // If the event is recent, do something with it.
        NSLog(@"latitude %+.6f, longitude %+.6f\n",
              location.coordinate.latitude,
              location.coordinate.longitude);
    }
}

- (void)locationManager:(CLLocationManager *)manager didUpdateHeading:(CLHeading *)newHeading {
    if (newHeading.headingAccuracy < 0)
        return;

    // Use the true heading if it is valid.
    CLLocationDirection  theHeading = ((newHeading.trueHeading > 0) ?
                                       newHeading.trueHeading : newHeading.magneticHeading);
    NSLog(@"Heading changed: %f", theHeading);
    //self.currentHeading = theHeading;
    //[self updateHeadingDisplays];
}

#pragma mark - Init

-(id)init
{
    self = [super init];
    if (self) {
        [self startStandardUpdates];
    }
    return self;
}

#pragma mark - public

+(LocationModel*)getSharedInstance
{
    if(!sharedInstance)
    {
        sharedInstance = [[LocationModel alloc] init];
    }
    return sharedInstance;
}

+(void)myInit
{
    sharedInstance = [[LocationModel alloc] init];
}

@end

Я просто вызываю myInit из awakeWithContext интерфейса Controller

1 ответ

Решение

Базовое расположение должно быть реализовано в приложении ios, а не в расширении (как указано в документации). Еще одна вещь, в IOS8 вы должны вызвать requestWhenInUseAuthorization перед вызовом startUpdatingLocation.

// Проверка для iOS 8. Без этой защиты код завершится с "неизвестным селектором" на iOS 7. if ([self.locationManager responsedsToSelector:@selector(requestWhenInUseAuthorization)]) { [self.locationManager requestAlwaysAuthorization]; }

Насчет файла GPX - симулятору, похоже, не понравится. Это просто не играет.

Другие вопросы по тегам