Отклонение iPad UIPopoverController, когда BarButtonItem продвинут, в то время как это открыто

Используя представление разделения о iPad, у меня есть следующий код:

- (void) splitViewController:(UISplitViewController *)svc willHideViewController:(UIViewController *)aViewController withBarButtonItem:(UIBarButtonItem *)barButtonItem forPopoverController:(UIPopoverController *)pc {
  barButtonItem.title = @"Categories";
  NSMutableArray *items = [[toolbar items] mutableCopy];
  [items insertObject:barButtonItem atIndex:0];
  [toolbar setItems:items animated:YES];
  [items release];
  self.popoverController = pc;
}

Это работает хорошо для показа легкой сдобы при нажатии кнопки. Однако я также хотел бы иметь легкую сдобу, отклоняют, если кнопка нажимается, в то время как это уже открыто для следования хорошим инструкциям. Как я пошел бы о выполнении этого? (т.е. если пользователь неоднократно нажимает эту кнопку, легкая сдоба должна прибыть и скрыть любой хит.)

11
задан Pål Brattberg 10 May 2011 в 21:45
поделиться

6 ответов

При отображении всплывающего окна splitViewController вызывается указанный ниже метод. Просто проверьте, не является ли он nil, а затем отклоните его :)

- (void)splitViewController:(UISplitViewController*)svc popoverController:(UIPopoverController*)pc willPresentViewController:(UIViewController *)aViewController{
  if ([pc isPopoverVisible]) {
     [pc dismissPopoverAnimated:YES];
  }
}
16
ответ дан 3 December 2019 в 03:34
поделиться

Это намного проще, потому что popoverController является свойством. Облегчает ссылки.

if ([self.popoverController isPopoverVisible]) {
    //using the setters and getters "goes thru the proper channels" when accessing objects
    [self.popoverController dismissPopoverAnimated:YES];
} else {
    UIPopoverController *pc = [[UIPopoverController alloc] initWithContentViewController:YOUR_VIEW_CONTROLLER];
    self.popoverController = pc;
    [pc release];

    //get the button instance you set on the toolbar
    UIBarButtonItem *categoryButton = [[toolbar items] objectAtIndex:0];
    [self.popoverController presentPopoverFromBarButtonItem:categoryButton permittedArrowDirections:UIPopoverArrowDirectionAny animated:YES];
}

На самом деле я только что понял, что вы имеете в виду код внутри метода Delegate для отображения viewController по индексу: 0 вашего splitView. Этот ответ не обязательно относится к этому, но применим к любому другому моменту, когда вы получаете доступ и создаете popoverController на iPad. Не проверяя, отображается ли сначала всплывающее окно, вы либо вылетите, либо откроете несколько всплывающих окон.

Спасибо за уделенное время.

3
ответ дан 3 December 2019 в 03:34
поделиться

Код, который я использовал для отображения всплывающего окна в RootViewController.m:

- (IBAction) addCategory:(id)sender {
  AddCategoryViewController *content = [[AddCategoryViewController alloc] init];
  UIPopoverController *aPopover = [[UIPopoverController alloc]
                                   initWithContentViewController:content];

  aPopover.delegate = self;

  // Store the popover in a custom property for later use.
  self.addCategoryPopover = aPopover;
  addCategoryPopover.delegate = self;
  [aPopover release];
  [content release];

  [addCategoryPopover presentPopoverFromBarButtonItem:sender permittedArrowDirections:UIPopoverArrowDirectionUp animated:YES];
}

Я использовал его, чтобы попытаться исключить его из другого класса:

-(IBAction)saveAddCategory:(id)sender {
  rootViewController = [[RootViewController alloc] init];
  [rootViewController dismissPopover];
}

Моя функция dismissPopover выглядит так:

- (void) dismissPopover {
  if ([self.addCategoryPopover isPopoverVisible]) {
    [self.addCategoryPopover dismissPopoverAnimated:YES];
  }
  if (addCategoryPopover.popoverVisible == YES) {
    [addCategoryPopover dismissPopoverAnimated:YES];
  }
}
0
ответ дан 3 December 2019 в 03:34
поделиться

HIG от Apple говорит, что внутри всплывающего окна не должно быть явной кнопки закрытия, но чтобы сделать то, что вы просите, у вас есть два варианта.

1) опубликуйте NSNotification

ИЛИ

2) углубитесь в иерархию представления, пока не получите экземпляр всплывающего окна

1) в каком бы представлении вы ни представляли всплывающее окно, в методе viewDidLoad:

[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(dismissThePopover) name:@"popoverShouldDismiss" object:nil];

создайте метод под названием «dismissThePopover» и в методе dealloc removeObserver

-(void)dismissThePopover {
    [self.popoverController dismissPopoverAnimated:YES];
}

-(void)dealloc {
    [[NSNotificationCenter defaultCenter] removeObserver:self];
}

. В вашем popoverController кнопку «отклонить» введите следующую строку:

[[NSNotificationCenter defaultCenter] postNotificationName:@"popoverShouldDismiss" object:nil];

Выполнение этого отправляет уведомление в приложение, и поскольку вы зарегистрировали свой другой контроллер представления, чтобы его прослушивать, всякий раз, когда он видит это уведомление, он вызывает указанный вами селектор, в данном случае dismissThePopover.

2) углубитесь в свою иерархию представлений, чтобы найти self.popoverController

проверьте это, ваше, конечно, будет другим, но общая идея та же. Начните с вашего AppDelegate, перейдите к первому контроллеру представления, переходите к подпредставлениям, пока не дойдете до своего объекта self.popoverController.

MyAppDelegate *appDelegate = [[UIApplication sharedApplication]delegate];
//appDelegate instance, in this case it's the .m file for your ApplicationDelegate

UISplitViewController *svc = appDelegate.splitViewController;
//In this case the first view inside the appDelegate is a SplitView, svc

UINavigationController *navc = [[svc viewControllers]objectAtIndex:0];
//a navigationController is at index:0 in the SplitView hierarchy. DetailView is at index:1

NSArray *vcs = [navc viewControllers];
//vcs is the array of different viewcontrollers inside the Navigation stack for nvc

iPadRootViewController *rootView = [vcs objectAtIndex:0];
//declare the rootView, which is the .m file that is at index:0 of the view array

UIPopoverController *pc = [rootView popoverController];
//HERE WE GO!!! popoverController is a property of iPadRootViewController's instance rootView, hereby referred to as pc.

[pc dismissPopoverAnimated:YES];
//bye bye, popoverController!

Надеюсь, это поможет

7
ответ дан 3 December 2019 в 03:34
поделиться

Вы можете попробовать следующее

if(![popoverController isPopoverVisible]){
   // Show popover
}
else{
   // close popover
   [popoverController dismissPopoverAnimated:YES];
}
1
ответ дан 3 December 2019 в 03:34
поделиться

Если вы используете стандартную настройку UISplitViewController, то созданная кнопка навигационной панели отображает всплывающее окно вашего RootViewController.

Если вы хотите быть уверенным, что у вас не будет сразу несколько всплывающих окон, вы можете просто отключить всплывающие окна всякий раз, когда появится ваш RootViewController. Вот код, который я использовал для решения этой проблемы:

- (void) viewWillAppear:(BOOL)animated {
  if ([self.popover isPopOverVisible]) {
    [self.popover dismissPopoverAnimated:YES];
  }
  [super viewWillAppear:YES];
}
0
ответ дан 3 December 2019 в 03:34
поделиться
Другие вопросы по тегам:

Похожие вопросы: