I have some problems with iOS and gefencing...
//
// ViewController.m
//
//
// Created by me on 14.05.13.
// Copyright (c) 2013 me. All rights reserved.
//
#import "ViewController.h"
@interface ViewController ()<CLLocationManagerDelegate>
{
CLLocationManager *locationManager;
CLRegion *testRegion;
}
#define METERS_PER_MILE 1609.344
@end
@implementation ViewController
- (void)viewDidLoad
{
[super viewDidLoad];
[self initlocationManager];
// [self startlocationManager];
}
// init location Manager Object, set delegation, result and accurate
- (void)initlocationManager {
//create location manager object
locationManager = [[CLLocationManager alloc]init];
//this instance send its messages to our AppDelegate
[locationManager setDelegate:self];
//to get all results from the location manager
[locationManager setDistanceFilter:kCLDistanceFilterNone];
//be accurate as possible
[locationManager setDesiredAccuracy:kCLLocationAccuracyBest];
}
- (void)viewWillAppear:(BOOL)animated {
CLLocationCoordinate2D startLocation;
startLocation.latitude = +52.53753000;
startLocation.longitude= +13.35971000;
MKPointAnnotation *newLocation = [[MKPointAnnotation alloc] init];
newLocation.coordinate = startLocation;
newLocation.title = @"great title";
newLocation.subtitle = @"great subtitle";
MKCoordinateRegion startingRegion = MKCoordinateRegionMakeWithDistance(startLocation, 0.5*METERS_PER_MILE, 0.5*METERS_PER_MILE);
testRegion = [[CLRegion alloc] initCircularRegionWithCenter:startLocation radius:500 identifier:@"TEST"];
[_mapView addAnnotation:newLocation];
[_mapView setRegion:startingRegion animated:YES];
[locationManager startMonitoringForRegion:testRegion];
NSLog(@"%@",locationManager.monitoredRegions);
}
- (void)locationManager:(CLLocationManager *)manager didFailWithError:(NSError *)error {
NSLog(@"Error : %@",error);
}
- (void)locationManager:(CLLocationManager *)manager monitoringDidFailForRegion:(CLRegion *)region withError:(NSError *)error
{
NSLog(@"Region monitoring failed with error: %@", [error localizedDescription]);
}
- (void)locationManager:(CLLocationManager *)manager didEnterRegion:(CLRegion *)region {
NSLog(@"Entered Region - %@", region.identifier);
// [self showRegionAlert:@"Entering Region" forRegion:testRegion.identifier];
}
- (void)locationManager:(CLLocationManager *)manager didStartMonitoringForRegion:(CLRegion *)region {
NSLog(@"Started monitoring %@ region", region.identifier);
}
- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
@end
The Terminal give me the following messages:
2013-05-15 00:24:47.739 [8712:13d03] {(
(identifier TEST) <+52.53753000,+13.35972000> radius 500.00m
)}
2013-05-15 00:24:47.972 [8712:13d03] Started monitoring TEST region
So the region were successfully created and the monitoring start too
but thedidEnterRegion
function never called.
Help would be great!
Edit:
at the moment i'm using that gpx file in the iphone simulator and it works fine. only didEnterRegion
never get called.
<?xml version="1.0" encoding="UTF-8" standalone="no" ?>
<gpx version="1.1" creator="http://www.geoplaner.com" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.topografix.com/GPX/1/1" xsi:schemaLocation="http://www.topografix.com/GPX/1/1 http://www.topografix.com/GPX/1/1/gpx.xsd">
<wpt lat="52.53856" lon="13.3515">
<ele>36.6</ele>
<name>WP04-D</name>
</wpt>
<wpt lat="52.53753" lon="13.35972">
<ele>35.1</ele>
<name>WP05-E</name>
</wpt>
<wpt lat="52.538" lon="13.35788">
<ele>34.1</ele>
<name>WP06-F</name>
</wpt>
<wpt lat="52.53844" lon="13.35633">
<ele>33.6</ele>
<name>WP07-G</name>
</wpt>
<wpt lat="52.53895" lon="13.35392">
<ele>34.7</ele>
<name>WP08-H</name>
</wpt>
<wpt lat="52.53813" lon="13.34925">
<ele>36</ele>
<name>WP09-I</name>
</wpt>
<wpt lat="52.53794" lon="13.34667">
<ele>36.3</ele>
<name>WP10-J</name>
</wpt>
<wpt lat="52.53815" lon="13.34504">
<ele>37.1</ele>
<name>WP11-K</name>
</wpt>
<wpt lat="52.5369" lon="13.35938">
<ele>39.3</ele>
<name>WP12-L</name>
</wpt>
<wpt lat="52.53619" lon="13.35792">
<ele>33.3</ele>
<name>WP13-M</name>
</wpt>
<wpt lat="52.53468" lon="13.35508">
<ele>37.3</ele>
<name>WP14-N</name>
</wpt>
<wpt lat="52.53398" lon="13.35367">
<ele>37</ele>
<name>WP15-O</name>
</wpt>
<wpt lat="52.53781" lon="13.35862">
<ele>33.7</ele>
<name>WP16-P</name>
</wpt>
</gpx>
Your code looks fine. Just ensure that locationManager is retained/strongly-held.
Test your region code using the iPhone simulator. On the 'debug' menu chose a location from the 'location' submenu. Changing different locations will exercise your code.
I just tested your code using the iPhone Simulator and by choosing locations from the submenu. I entered your code's lat/long numbers for 'custom location'. Here was the output:
2013-05-15 07:42:50.885 Location[69277:c07] {(
(identifier home) <+37.26917400,-119.30660700> radius 100.00m
)}
2013-05-15 07:42:50.932 Location[69277:c07] Started monitoring TEST region
2013-05-15 07:44:01.103 Location[69277:c07] Entered Region - TEST
2013-05-15 07:44:59.573 Location[69277:c07] Entered Region - TEST
The 'entered region' output occurred when I chose the 'custom location'. The only changes I made from your code were: 1) commented out the 'mapView' lines and 2) declared the ViewController interface as shown below. You had used a class extension.
@interface ViewController : UIViewController
<CLLocationManagerDelegate>
{
CLLocationManager *locationManager;
CLRegion *testRegion;
}
@end
Ensure that location services are enabled for your app.