title: 位置同步
本篇文档介绍如何实现实时位置同步。
1. 上传位置
持续上传
- startTracingPositionForKey:方法可以根据 Key 向云端持续上传设备的位置,如果 Key 不存在,云端会自动创建。默认为 5s 上传一次位置数据。
[locationService startTracingPositionForKey:@"key"];
- startTracingPositionForKey:withCompletionBlock:方法可以在上传开始后执行一次回调。
[locationService startTracingPositionForKey:@"key" withCompletionBlock:^(NSError * _Nullable error) {NSLog(@"Tracing started!");}];
设置上传频率
你可以根据时间或距离设置上传频率,这种方式需要传入一个WDGAmapLocationProvider实例:
- 根据时间间隔上传,最小间隔 1秒, 最大间隔 300 秒。
例如,每 2 秒 上传一次位置信息:
WDGAMapLocationProvider *locationProvider = [[WDGAMapLocationProvider alloc] initWithTimeInterval:2.0];[locationService startTracingPositionForKey:@"key" withLocationProvider:locationProvider];
- 根据距离间隔上传,最小间隔 0 米 (1秒判断一次),最大间隔 500 米。
例如,每移动 10 米 上传一次位置信息:
WDGAMapLocationProvider *locationProvider = [[WDGAMapLocationProvider alloc] initWithDistanceInterval:10.0];[locationService startTracingPositionForKey:@"key" withLocationProvider:locationProvider];
- startTracingPositionForKey:withLocationProvider:withCompletionBlock:方法可以在上传开始后执行一次回调。
[locationService startTracingPositionForKey:@"key" withLocationProvider:locationProvider withCompletionBlock:^(NSError * _Nullable error) {NSLog(@"Tracing started!");}];
上传自定义属性
除了位置之外,你还可以在上传时附带 JSON 形式的自定义属性。
可以在单次上传中附带属性:
NSDate *timestamp = [NSDate date];NSDictionary *attr = @{@"foo": @"bar"};WDGPosition *customPosition = [[WDGPosition alloc] initWithLatitude:37.0327 longitude:120.5859 timestamp:timestamp customAttributes:attr];[locationService setPosition:customPosition forKey:@"key"];
也可以实现 WDGLocationDelegate 协议中的 - wilddogLocation:willUpdatePosition:ForKey: 方法:
-(WDGPosition *)wilddogLocation:(WDGLocation *)wilddogLocation willUpdatePosition:(WDGPosition *)position ForKey:(NSString *)key {double latitude = position.latitude;double longitude = position.longitude;NSDate *timestamp = position.timestamp;NSDictionary *attr = @{@"foo": @"bar"};WDGPosition *customPosition = [[WDGPosition alloc] initWithLatitude:latitude longitude:longitude timestamp:timestamp customAttributes:attr];return customPosition;}
停止上传
- stopTracingPositionForKey: 方法可以停止指定 Key 的位置上传。
[locationService stopTracingPositionForKey:@"key"];
- stopTracingPositionForKey:withCompletionBlock:方法可以在上传开始后执行一次回调。
[locationService stopTracingPositionForKey:@"key" withCompletionBlock:^(NSError * _Nullable error) {NSLog(@"Tracing stopped!");}];
单次上传
- setPosition:forKey: 方法可以根据 Key 向云端上传一次位置信息,如果 Key 不存在,云端会自动创建。
WDGPosition *position = [[WDGPosition alloc] initWithLatitude:42.0 longitude:100.0];[locationService setPosition:position forKey:@"key"];
- setPosition:forKey:withCompletionBlock:方法可以在上传开始后执行一次回调。
[locationService setPosition:position forKey:@"key" withCompletionBlock:^(NSError * _Nullable error) {NSLog(@"Position updated!");}];
2. 监听位置
持续监听
- observePositionForKey:withBlock: 用于实时获取指定 Key 的最新位置信息。
WilddogHandle handle = [locationService observePositionForKey:@"key" withBlock:^(WDGPosition * _Nullable position, NSError * _Nullable error) {NSLog(@"Current Position: %@", position);}];
取消监听
- removeObserverWithWilddogHandle:用 handle 取消指定的位置监听。
[locationService removeObserverWithHandle:handle];
- removeAllObserverForKey:用于取消对指定 Key 的所有位置监听。
[locationService removeAllObserverForKey:@"key"];
- removeAllObservers用于取消所有的位置监听。
[locationService removeAllObservers];
单次监听
- getPositionForKey:withBlock: 用于获取一次指定 Key 的最新位置信息。
[locationService getPositionForKey:@"key" withBlock:^(WDGPosition * _Nullable position, NSError * _Nullable error) {NSLog(@"Current Position: %@", position);}];
3. 移除位置
- removePositionForKey: 用于删除服务器存储的指定 key 的位置数据。
[locationService removePositionForKey:@"key"];
- removePositionForKey:withCompletionBlock: 可以在删除操作完成后执行一次回调。
[locationService removePositionForKey:@"key" withCompletionBlock:^(NSError * _Nullable error) {NSLog(@"Position deleted!");}];
4. 计算距离
+ distanceBetweenPosition:andPosition:方法用于计算两个坐标点的距离。
WDGPosition *position1 = [[WDGPosition alloc] initWithLatitude:12.34 longitude:56.78];WDGPosition *position2 = [[WDGPosition alloc] initWithLatitude:56.78 longitude:90.12];double distance = [WDGLocation distanceBetweenPosition:position1 andPosition:position2];
通过该方法可以实现实时距离的计算。
例如:持续监听两个 key 的位置,每当它们的位置更新后,计算二者的距离。
WilddogHandle handle1 = [locationService observePositionForKey:@"key1" withBlock:^(WDGPosition * _Nullable position, NSError * _Nullable error) {if (error) {// Handle error herereturn;}self.position1 = position;[self updateDistance];}];WilddogHandle handle2 = [locationService observePositionForKey:@"key2" withBlock:^(WDGPosition * _Nullable position, NSError * _Nullable error) {if (error) {// Handle error herereturn;}self.position2 = position;[self updateDistance];}];
其中, -updateDistance的实现如下:
- (void)updateDistance {self.distance = [WDGLocation distanceBetweenPosition:self.position1 andPosition:self.position2];}
