Iphone MKMapView setRegion:奇怪的行为?

Iphone MKMapView setRegion:奇怪的行为?,iphone,Iphone,我正在开发一个3个标签的iPhone应用程序,我希望每个标签的视图看起来像是共享同一张地图。所以现在,我只是想弄清楚,当你点击一个新标签时,如何重置每个视图的MKMapView区域。[换句话说,如果您在选项卡1上,并在一个点上一直放大,然后单击选项卡2,我希望它显示相同的放大地图。] 要做到这一点,我在应用程序委托中有一个MKCoordinateRegion,每个视图在消失之前保存到该区域,每个新视图在被查看之前读取 [换句话说,我的应用程序代理是我的TabBarControllerDelega

我正在开发一个3个标签的iPhone应用程序,我希望每个标签的视图看起来像是共享同一张地图。所以现在,我只是想弄清楚,当你点击一个新标签时,如何重置每个视图的MKMapView区域。[换句话说,如果您在选项卡1上,并在一个点上一直放大,然后单击选项卡2,我希望它显示相同的放大地图。]

要做到这一点,我在应用程序委托中有一个MKCoordinateRegion,每个视图在消失之前保存到该区域,每个新视图在被查看之前读取

[换句话说,我的应用程序代理是我的TabBarControllerDelegate,我已覆盖tabBarController:shouldSelectViewController:。有人单击选项卡按钮后,在新选项卡的视图出现之前调用此函数:调用函数。因此,在该函数中,我将当前视图的区域保存到我的AppDelegate::MKCoordinateRegion变量,然后让新视图的ViewWillDisplay:(或viewDidLoad:)被调用。然后,在新视图的ViewWillDisplay:,我从应用程序委托中获取mkCoordinaterRegion,并将其分配给新视图的区域。]

然而,来自MKMapKit::setRegion:的值似乎不一致,我不知道我是否只是做错了什么,完全遗漏了什么,或者是否还有其他事情正在发生

我只做了大约两周的iPhone开发(和Obj-c等),所以这很可能是一个新的错误。如果是这样,我会继续道歉,因为浪费了你的时间。不过,这里有一些代码(我在我使用的评论中留下了…以防你自己尝试运行它):

iphonestappdelegate.h

...
@interface iPhoneTestAppDelegate : NSObject  
{
    UIWindow* _window;
    UITabBarController* _tabBarController;
    SubViewController* _subViewController;

    MKCoordinateRegion _mapRegion;
}

@property (nonatomic, retain) IBOutlet UIWindow* window;
@property (nonatomic, retain) IBOutlet UITabBarController* tabBarController;
@property (nonatomic, retain) IBOutlet SubViewController* subViewController;
@property (nonatomic, assign) MKCoordinateRegion mapRegion;

@end 
iPhoneAppDelegate.m

...
static CLLocationDegrees INITIAL_LATITUDE = 40.754019;
static CLLocationDegrees INITIAL_LONGITUDE = -73.973351;
static CLLocationDegrees INITIAL_SPAN_LAT_DEG = .10767;
static CLLocationDegrees INITIAL_SPAN_LONG_DEG = .109863;
...
- (void)applicationDidFinishLaunching:(UIApplication *)application 
{
    NSLog(@"Begin");
    // initialize the delegate's region
    MKCoordinateRegion region = {{0.0f, 0.0f}, {0.0f, 0.0f}};
    region.center.latitude = INITIAL_LATITUDE;
    region.center.longitude = INITIAL_LONGITUDE;
    region.span.latitudeDelta = INITIAL_SPAN_LAT_DEG;
    region.span.longitudeDelta = INITIAL_SPAN_LONG_DEG;
    self.mapRegion = region;

    self.tabBarController.delegate = self;
    [self.window addSubview:self.tabBarController.view];
}

- (BOOL)tabBarController:(UITabBarController *)tabBarController
 shouldSelectViewController:(UIViewController *)viewController
{
 NSLog(@"in UITabBarControllerDelegate: shouldSelectViewController:");

 if([tabBarController.viewControllers indexOfObject:viewController] !=
  [tabBarController selectedIndex])
 {
  NSLog(@"different view selected");
  BaseViewController* currView = (BaseViewController *)[tabBarController selectedViewController];

  NSLog(@"%f %f %f %f", 
     self.mapRegion.center.latitude, self.mapRegion.center.longitude, 
     self.mapRegion.span.latitudeDelta, self.mapRegion.span.longitudeDelta);
  NSLog(@"%f %f %f %f", 
     currView.mapView.region.center.latitude, currView.mapView.region.center.longitude, 
     currView.mapView.region.span.latitudeDelta, currView.mapView.region.span.longitudeDelta);
  self.mapRegion = currView.mapView.region;
  NSLog(@"%f %f %f %f", 
     self.mapRegion.center.latitude, self.mapRegion.center.longitude, 
     self.mapRegion.span.latitudeDelta, self.mapRegion.span.longitudeDelta);
 }
 else
  NSLog(@"same view selected");

 return YES;
}
BaseViewController.m

...
- (void)viewDidLoad 
{
    [super viewDidLoad];
 NSLog(@"Base: viewDidLoad");

 iPhoneTestAppDelegate* appDelegate = (iPhoneTestAppDelegate *)
  [[UIApplication sharedApplication] delegate];
 [self.mapView setDelegate:self];
    //[self.mapView setRegion:appDelegate.mapRegion animated:YES];
 [self.mapView setRegion:[self.mapView regionThatFits:appDelegate.mapRegion]];

 NSLog(@"---------------------");
 NSLog(@"%f %f %f %f", 
    appDelegate.mapRegion.center.latitude, appDelegate.mapRegion.center.longitude, 
    appDelegate.mapRegion.span.latitudeDelta, appDelegate.mapRegion.span.longitudeDelta);
 NSLog(@"---------------------");
 NSLog(@"%f %f %f %f", 
    self.mapView.region.center.latitude, self.mapView.region.center.longitude, 
    self.mapView.region.span.latitudeDelta, self.mapView.region.span.longitudeDelta);
 NSLog(@"---------------------");  
}

- (void)viewWillAppear:(BOOL)animated
{
 [super viewWillAppear:animated];
 NSLog(@"Base: viewWillAppear");

 iPhoneTestAppDelegate* appDelegate = (iPhoneTestAppDelegate *)
  [[UIApplication sharedApplication] delegate];  
 //[self.mapView setRegion:appDelegate.mapRegion animated:YES];
 [self.mapView setRegion:[self.mapView regionThatFits:appDelegate.mapRegion]];

 NSLog(@"*********************");
 NSLog(@"%f %f %f %f", 
    appDelegate.mapRegion.center.latitude, appDelegate.mapRegion.center.longitude, 
    appDelegate.mapRegion.span.latitudeDelta, appDelegate.mapRegion.span.longitudeDelta);
 NSLog(@"*********************");
 NSLog(@"%f %f %f %f", 
    self.mapView.region.center.latitude, self.mapView.region.center.longitude, 
    self.mapView.region.span.latitudeDelta, self.mapView.region.span.longitudeDelta);
 NSLog(@"*********************");
}
...
现在,我在运行此命令时注意到的第一件事是,当调用初始视图的viewDidLoad:时,代理的区域和新视图的区域是相同的(在调用setRegion:之后)。但是,在ViewWillAspect:中调用setRegion:后,我的视图的MKMapView的区域不再等于代理。不知何故,viewDidLoad:中完全相同的代码在ViewWillAspect:中运行时会产生不同的结果!不应该是这样吗?为什么从ViewWillAspect:调用setRegion:会更改我的视图的MKMapVi的值ew的地区?这和地区有什么关系吗

但是,我认为如果我能解决这一部分,我可能会解决其他问题;因此,我不会在这里深入讨论更多细节。但是,如果你制作一个快速应用程序。使用这些功能并运行它,你会看到问题。主要是,视图的地图偶尔会同步,但随着你的缩放和移动(并在选项卡之间来回切换),范围开始缩小,每次按下新的选项卡都会使我越来越远

注意:我只是在模拟器(3.0)上运行这个(我还没有硬件),所以我不知道这是否与它有关。但是,我有点怀疑它


无论如何,感谢您提供的任何帮助。我真的非常感谢。

我正在解决一个类似的问题,即围绕一组点实施缩放以适应功能。目前我能给您的唯一帮助是,是的,RegionAtFits:实际上是在内部调用的。我正在使用一个精确适合所有点的区域调用setRegions、 因此,应该有一个点正好位于每边的边缘,以及可视区域内的点。地图视图在调用setRegion后实际拥有的区域是不同的,但与调用RegionAtfits时得到的区域完全相同:与我要使用的区域相同。该区域通常比韩:我想要什么

我一直在研究这个问题,理论上说RegionAtfits只是试图捕捉纵横比,并将纵横比校正搞砸了。然而,有两件事似乎表明这不是唯一的事情:首先,RegionAtfits返回的区域纵横比与地图视图的纵横比不同。Se其次,当我使用我自己的纵横比校正代码来获得RegionAtfits输出的完全相同的纵横比时,我仍然从RegionAtfits(和mapView)中获得错误的大区域

到目前为止,MapKit相当令人愤怒