У меня есть вид карты, который я добавляю и удаляю annotations
с помощью переключателя в popovercontroller
. Когда я прикасаюсь за пределами popover
, он корректно отклоняется и вызывает метод delegate
popoverControllerDidDismissPopover:
. Проблема, с которой я столкнулась, заключается в том, что когда я переключаю переключатель в popover
(касаясь в представлении popover), если я я удаляю annotations
с карты, которая ведет себя корректно, а popover остается видимым, но если я добавляю annotations
к представлению карты, то popover
исчезает, а метод delegate
не вызывается. Кто-нибудь сталкивался с этим поведением раньше?
Единственное различие между кодом включения и выключения коммутатора заключается в том, что вы удаляете annotations
из массива, а другой добавляет annotations
. Это только проблема при добавлении annotations
к виду карты. Любая помощь или предложения будут оценены.
Вот как отображается popover
:
-(IBAction)toggleMapFiltersView:(id)sender
{
LayerPopoverViewController *popOverViewController = [[LayerPopoverViewController alloc] init];
[popOverViewController setDelegate:self];
[popOverViewController setBranchesShowing:branchesShowing];
[popOverViewController setSchoolsShowing:schoolsShowing];
[layersButton setSelected:YES];
popoverController = [[UIPopoverController alloc] initWithContentViewController:popOverViewController];
[popoverController setDelegate:self];
[popOverViewController release];
[popoverController presentPopoverFromRect:layersButton.frame
inView:[self view]
permittedArrowDirections:UIPopoverArrowDirectionAny
animated:YES];
}
Это метод, который вызывается из представления popover:
-(IBAction)toggleSchools:(id)sender
{
if ([self.delegate respondsToSelector:@selector(didChangeSchoolsDisplaySettingWithVisible:)])
{
if ([schoolsSwitch isOn])
{
[self.delegate didChangeSchoolsDisplaySettingWithVisible:YES];
self.schoolsShowing = YES;
}
else
{
[self.delegate didChangeSchoolsDisplaySettingWithVisible:NO];
self.schoolsShowing = NO;
}
}
}
и это метод, который он имеет в виду:
-(void)didChangeSchoolsDisplaySettingWithVisible:(BOOL)visible
{
if (visible == YES)
{
schoolsShowing = YES;
if (self.schoolArray != nil && [self.schoolArray count] > 0)
{
for (MySchool *school in self.schoolArray)
{
[mapView addAnnotation:school];
}
}
}
else
{
schoolsShowing = NO;
for (id<MKAnnotation> annotation in mapView.annotations)
{
if ([annotation isKindOfClass:[MySchool class]])
{
[mapView removeAnnotation:annotation];
}
}
}
}