我有带有MKUserTrackingModeFollowWithHeading的MKMapView。
但是有些东西将userTrackingMode更改为MKUserTrackingModeFollow或None,
所以我实现了
- (void)mapView:(MKMapView *)mapView didChangeUserTrackingMode:(MKUserTrackingMode)mode animated:(BOOL)animated
{
if ([CLLocationManager locationServicesEnabled]) {
if ([CLLocationManager headingAvailable]) {
[self.myMapView setUserTrackingMode:MKUserTrackingModeFollowWithHeading animated:NO];
}else{
[self.myMapView setUserTrackingMode:MKUserTrackingModeFollow animated:NO];
}
}else{
[self.myMapView setUserTrackingMode:MKUserTrackingModeNone animated:NO];
}
}
一切都很好,但是每次我放大地图到最详细的级别时,该应用都会在上面显示的setUserTrackingMode:MKUserTrackingModeFollowWithHeading行中引起EXC_BAD_ACCESS。
我应该怎么做才能避免崩溃?如果可能的话,我不想使用MKUserTrackingBarButtonItem。
下面是mapViewController的另一部分。
- (void)dealloc
{
self.myMapView.delegate = nil;
}
- (void)viewWillDisappear:(BOOL)animated
{
if ([CLLocationManager locationServicesEnabled]) {
self.myMapView.showsUserLocation = NO;
[_locManager stopUpdatingLocation];
if ([CLLocationManager headingAvailable]) {
[_locManager stopUpdatingHeading];
}
}
[super viewWillDisappear:animated];
}
- (void)viewDidAppear:(BOOL)animated
{
if ([CLLocationManager locationServicesEnabled]) {
self.myMapView.showsUserLocation = YES;
[_locManager startUpdatingLocation];
if ([CLLocationManager headingAvailable]) {
[self.myMapView setUserTrackingMode:MKUserTrackingModeFollowWithHeading animated:NO];
[_locManager startUpdatingHeading];
}else{
[self.myMapView setUserTrackingMode:MKUserTrackingModeFollow animated:NO];
}
}else{
[self.myMapView setUserTrackingMode:MKUserTrackingModeNone animated:NO];
}
}
- (void)viewWillAppear:(BOOL)animated
{
[super viewDidAppear:animated];
self.myMapView.delegate = self;
[self.myMapView setFrame:self.view.frame];
self.locManager = [CLLocationManager new];
[self.locManager setDelegate:self];
[self.locManager setDistanceFilter:kCLDistanceFilterNone];
[self.locManager setDesiredAccuracy:kCLLocationAccuracyBest];
[self.locManager setHeadingFilter:3];
[self.locManager setHeadingOrientation:CLDeviceOrientationPortrait];
}
任何意见的赞赏。先感谢您。
我将最小示例代码上传到github。
最佳答案
我可能建议尝试推迟跟踪模式的设置,例如:
- (void)mapView:(MKMapView *)mapView didChangeUserTrackingMode:(MKUserTrackingMode)mode animated:(BOOL)animated
{
dispatch_async(dispatch_get_main_queue(),^{
if ([CLLocationManager locationServicesEnabled]) {
if ([CLLocationManager headingAvailable]) {
[self.myMapView setUserTrackingMode:MKUserTrackingModeFollowWithHeading animated:NO];
}else{
[self.myMapView setUserTrackingMode:MKUserTrackingModeFollow animated:NO];
}
}else{
[self.myMapView setUserTrackingMode:MKUserTrackingModeNone animated:NO];
}
});
}
我可能还会建议检查以确保
mode
尚未满足您的需要,从而消除了多余的setUserTrackingMode
:- (void)mapView:(MKMapView *)mapView didChangeUserTrackingMode:(MKUserTrackingMode)mode animated:(BOOL)animated
{
MKUserTrackingMode newMode = MKUserTrackingModeNone;
if ([CLLocationManager locationServicesEnabled]) {
if ([CLLocationManager headingAvailable]) {
newMode = MKUserTrackingModeFollowWithHeading;
}else{
newMode = MKUserTrackingModeFollow;
}
}
if (mode != newMode)
{
dispatch_async(dispatch_get_main_queue(), ^{
[self.myMapView setUserTrackingMode:newMode animated:YES];
});
}
}
您也可以将其与
scrollEnabled
结合使用(这应防止用户偶然启动跟踪模式的更改)。