Vidéo: Oculus Quest Basics Tutorial 2025
Parce que vous pouvez remplacer le contrôleur de vue de votre application iOS par un nouveau - bien que celui de la même classe de base - le nouveau contrôleur de vue a pas d'accès au bouton qu'il doit afficher ou au popover qu'il doit ignorer. Heureusement, les gens chez Apple fournissent un endroit parfait pour faire cela.
Lorsqu'un segue est déclenché - ce que vous faites lorsque vous appuyez sur une entrée de table - mais avant que le nouveau contrôleur glisse sa vue, le runtime du storyboard appelle la méthode du contrôleur de vue actuel pour transmettre des données au contrôleur de vue sur le point d'être affiché.
Cela signifie que vous pouvez transmettre les informations du bouton au nouveau contrôleur de vue avant même qu'il ne soit lancé. Ensuite, prepareForSegue: sender:, affectera le bouton à utiliser dans viewDidLoad et fermera également le contrôleur de vue.
prepareForSegue: sender: est une méthode de contrôleur de vue qui avertit un contrôleur de vue qu'un segue est sur le point d'être effectué. segue est l'objet UIStoryboadSegue, et il contient des informations sur les contrôleurs de vue impliqués dans la section.
Bien que l'implémentation par défaut de cette méthode ne fasse rien, les sous-classes UIViewController peuvent la surcharger et transmettre des données au contrôleur de vue sur le point d'être affiché. L'objet segue possède des propriétés qui pointent vers le contrôleur de vue source ainsi que vers le contrôleur de vue de destination. Le segue est le seul objet qui connaît simultanément les contrôleurs de vue source et destination.
l'expéditeur est l'objet qui a provoqué le segue, mais vous n'aurez pas besoin de l'utiliser ici.
Vous ajoutez le code à la méthode prepareForSegue: sender: pour que le composant DestinationController soit le délégué UISplitViewController et que vous affectiez les propriétés popOverButton et masterPopoverController.
Vous pourrez également ignorer le popover lorsqu'il est présent afin que l'utilisateur n'ait pas à toucher la vue pour s'en débarrasser.
Pour faire tout cela, ajoutez ce code à MasterViewController. m.
- (void) prepareForSegue: (UIStoryboardSegue *) sgue expéditeur: (id) expéditeur {if ([[UIDevice currentDevice] userInterfaceIdiom] == UIUserInterfaceIdiomPad) {DetailViewController * currentDetailViewController; if ([[Self.GoldViewController.ViewControllers dernier_objet] isKindOfClass: [Classe UINavigationController]]) currentDetailViewController = (ContrôleurColorContact *) ((UINavigationController *) [self.ControlViewController.ViewControllers lastObject]). topViewController; else currentDetailViewController = [self.splitViewController. viewControllers lastObject]; if (currentDetailViewController, masterPopover Controller! = nil) [currentDetailViewController. masterPopover Controller dismissPopoverAnimated: OUI]; DetailViewController * destinationDetailViewController; if ([segue.controllerViewViewController isKindOfClass: [classe UINavigationController]]) destinationDetailViewController = (Contrôleur de détail *) ((UINavigationController *) segue.ControllerViewController). topViewController; else destinationDetailViewController = segue. destinationViewController; soi. splitViewController. délégué = destinationDetailViewCon troller; destinationDetailViewController. popOverButton = currentDetailViewController. popOverButton; destinationDetailViewController. masterPopoverController = currentDetailViewController. masterPopoverController;}}
Vous commencez par trouver le contrôleur de détail en cours car il possède les propriétés de bouton et de survol dont le nouveau contrôleur de vue a besoin.
Ce code semble plus compliqué qu'il ne l'est. Vous vérifiez d'abord si vous utilisez un iPad. Si vous l'êtes, vous obtenez le contrôleur de détail en cours en accédant à la liste des contrôleurs de vue dans le tableau viewController de splitViewController. Heureusement, la classe UIViewController a une propriété splitViewController pour vous faciliter la tâche.
Vous vérifiez ensuite si un contrôleur de navigation est dans la matrice viewControllers et, s'il y en a un, vous obtenez le topViewController du contrôleur de navigation (le contrôleur de vue actuel); sinon, vous utilisez simplement le contrôleur dans le tableau. (Vous remarquerez que beaucoup de casting se passe ici)
if ([[self.screenViewController. ViewControllers & # x2028; dernierObjet]isKindOfClass: [UINavigationController & # x2028; class]])
currentDetailViewController = (RTDetailViewController *)
(UINavigationController *)
[self. splitViewController. viewControllers
lastObject]). topViewController; else
currentDetailViewController = & # x2028; [soi. splitViewController. viewControllers
lastObject];
Ensuite, si vous voyez un popover, vous voulez le rejeter. Vous vérifiez pour voir si un contrôleur de popover (c'est pourquoi vous deviez rendre la propriété accessible en le déplaçant dans le fichier d'en-tête.
if (currentDetailViewController.masterPopoverController! = Nil)
[currentDetailViewController.maitrePopoverController > dismissPopoverAnimated: YES];
Ensuite, vous trouvez le nouveau contrôleur de destination (celui qui est transféré) en utilisant une logique similaire à la logique que vous avez utilisée pour trouver le contrôleur Detail View actuel.
if ([segue. & # x2028; isKindOfClass: [classe UINavigationController
]]) destinationDetailViewController =(DetailViewController *) ((UINavigationController *)
segue.ControllerController) topViewController; else
destinationDetailViewController =
destinationviewController;
Ensuite, il vous suffit de définir le délégué Split View Controller sur le nouveau contrôleur de vue, de sorte qu'il recevra le splitViewController: willHideViewController: withBarButtonItem: forPopoverController: un d splitViewController: willShowViewController: invalidatingBarButtonItem: messages.
soi-même. splitViewController. delegate = destinationDetailViewController;
Enfin, vous affectez les propriétés popOverButton et masterPopOverController dans le nouveau contrôleur de vue.
destinationDetailViewController. popOverButton =
currentDetailViewController. popOverButton;
destinationDetailViewController. masterPopoverController =currentDetailViewController. masterPopoverController;
Certes, cela supprime simplement le popover et assigne les propriétés, mais ne fait rien pour afficher le bouton. Cela se fait réellement dans viewDidLoad.
Vous pouvez également spécifier la taille de la fenêtre contextuelle en affectant une valeur à la propriété prefferedContentSize. Vous devez savoir que la taille réelle peut être réduite afin que le popover s'ajuste à l'écran et que le popover ne chevauche pas un clavier lorsqu'un clavier est présenté. Vous pouvez voir le code qui fait cela dans la méthode awakeFromNib de MasterViewController.
- (void) awakeFromNib {if ([[UIDevice currentDevice]
userInterfaceIdiom] == UIUserInterfaceIdiomPad)
& # x2028; {soi. clearsSelectionOnViewWillAppear = NON;soi-même. preferredContentSize = CGSizeMake
(320. 0, 600. 0);} [super awakeFromNib];}
Le message awakeFromNib est envoyé à un objet qui a été instancié à partir du storyboard après que tous les objets ont été chargés et initialisés. Lorsque le message est envoyé, toutes ses connexions de sortie et d'action ont été définies.
Si vous décidez d'ignorer le conseil ici et ne pas ignorer le contrôleur popover, appuyez sur à l'extérieur de la fenêtre popover pour que le popover soit rejeté. Vous pouvez toutefois autoriser l'utilisateur à interagir avec les vues spécifiées et ne pas ignorer le popover, en utilisant la propriété passthroughViews (même si vous ne le ferez pas ici). Vous devriez alors rejeter le popover vous-même.
