iOS无法在前台再次找到iBeacon

时间:2015-01-15 10:41:13

标签: ios ibeacon

嗨〜我正在学习使用CLLocationManager来检测iBeacon。我读了这篇文章: http://developer.radiusnetworks.com/2013/11/13/ibeacon-monitoring-in-the-background-and-foreground.html  它说startRangingBeaconsInRegion将每秒进行系统扫描信标。我测试并且没错。

但是如果程序只在不使用startRangingBeaconsInRegion的情况下执行startMonitoringForRegion,则会出现问题。

我的程序可以在第一次启动信标硬件时找到信标,并且在我停止信标之后调用函数didExitRegion。但是在我第二次启动信标之后,程序根本找不到它(执行didEnterRegion)。我等了1个小时。

我用于测试的硬件是带有iOS 8.1.2和radBeacon USB的iPhone 5s。 这是我的代码。

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

@interface ViewController () <CLLocationManagerDelegate>
@property (retain, nonatomic) IBOutlet UITextView *textView;
@property (strong, nonatomic) NSMutableString *myLog;
@property (strong, nonatomic) CLLocationManager *locationManager;
@property (strong, nonatomic) CLBeaconRegion *beaconRegion;
@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    [self startBeaconMonitoring];
}

- (void)startBeaconMonitoring {
    _locationManager = [[CLLocationManager alloc] init];
    _locationManager.desiredAccuracy = kCLLocationAccuracyNearestTenMeters;
    _locationManager.delegate = self;

    [_locationManager performSelector:@selector(requestAlwaysAuthorization)];

    [self userGeofencingPreferencesWereUpdatedWithNotification:nil];

    [self updateLogWithString:@"start the app"];
}

- (void) userGeofencingPreferencesWereUpdatedWithNotification: (NSNotification *) notification
{
    if (1) {
        NSUUID *proximityUUID = [[NSUUID UUID] initWithUUIDString:@"EEF45689-BBE5-4FB6-9E80-41B78F6578E2"];
        _beaconRegion = [[CLBeaconRegion alloc]
                         initWithProximityUUID:proximityUUID
                         identifier:@"1"];
        _beaconRegion.notifyEntryStateOnDisplay = YES;
        [_locationManager startMonitoringForRegion:_beaconRegion];
        //[_locationManager startRangingBeaconsInRegion:beaconRegion];
        //[_locationManager stopUpdatingLocation];
    }
}

- (void) locationManager:(CLLocationManager *)manager didEnterRegion:(CLRegion *)region
{
    [self updateLogWithString:@"enter"];
    NSLog(@"enter");
}

- (void) locationManager:(CLLocationManager *)manager didExitRegion:(CLRegion *)region
{
    [self updateLogWithString:@"exit"];
    NSLog(@"exit");
}

- (void)locationManager:(CLLocationManager *)manager
        didRangeBeacons:(NSArray *)beacons
               inRegion:(CLBeaconRegion *)region {
    //NSLog(@"range");
}

- (void)dealloc {
    [_textView release];
    [_myLog release];
    [_locationManager release];
    [_beaconRegion release];
    [super dealloc];
}

- (NSMutableString *)myLog {
    if (!_myLog) {
        _myLog = [[NSMutableString alloc] init];
    }
    return _myLog;
}

- (void) updateLogWithString:(NSString*)newLog {
    NSDate *now = [NSDate date];
    NSDateFormatter *dateFormatter = [[NSDateFormatter alloc] init];
    dateFormatter.dateFormat = @"hh:mm:ss";
    [dateFormatter setTimeZone:[NSTimeZone systemTimeZone]];
    NSString * logWithTime = [NSString stringWithFormat:@"%@---%@\n",[dateFormatter stringFromDate:now], newLog];
    [self.myLog appendString:logWithTime];
    self.textView.text = self.myLog;
    [dateFormatter release];
}
@end

1 个答案:

答案 0 :(得分:0)

我偶然发现了一些东西,这解决了我的问题。当我使用名为Broadcaster的iOS APP来模拟iBeacon时,它会非常快速地触发iBeacon检测APP,无论是在前景,背景还是屏幕关闭,它都会在另一台iOS设备上运行。 当我使用Rad Beacon USB时,仍然失败。我测试了所有4个Rad Beacon USB,同样的事情发生了。 似乎Rad Beacon USB发送的BLE消息与iOS模拟的有点不同(我刚刚尝试过APP Broadcaster)。 iOS8对待它们 在某些情况下有所不同。

我的Rad Beacon USB是版本2.0。