可以将文章内容翻译成中文,广告屏蔽插件可能会导致该功能失效(如失效,请关闭广告屏蔽插件后再试):
问题:
I'm adding a child view controller to a parent view controller, and everything works as expected, except that child view controller isn't having its usual callbacks triggered. eg, things like viewWillAppear(animated) is never called. I looked into it and thought it may be because I wasn't calling willMoveToParentViewController and didMoveToParentViewController on the child view controller before and after adding it to the parent, respectively. Unfortunately, fixing that has made no difference. Does anyone know how I can wire this up so that when I do addChildViewController and removeChildViewController the regular callbacks are triggered? After adding the childViewController, I also add its view as a subview to the parent view controller's view. At neither point (addChildViewController & addSubview) does the child view controller's viewWillAppear(animated), etc methods get called...
Nick
回答1:
viewWillAppear, viewDIdAppear called automatically when you adding your ViewControler view to a view hierarchy
viewWillDisappear, viewDidDisappear called automatically when you removing your ViewControler view from a view hierarchy
Maybe this methods not called because you are adding sub-controller view before displaying main view controller and, therefore your main view is not in view hiererchy itself?
When your main view controller appears or disappears you should call this methods for childs in corresponding methods.
回答2:
Not sure if this can apply to your situation, but try experimenting with manually sending appearance callback methods to your children.
From apple's view controller containment documentation:
However, sometimes the default behavior may send those events in an
order that doesn’t make sense for your container. For example, if
multiple children are simultaneously changing their view state, you
may want to consolidate the changes so that the appearance callbacks
all happen at the same time in a more logical order. To do this, you
modify your container class to take over responsibility for appearance
or rotation callbacks.
It recommends manually forwarding the appearance callbacks to your children if you want more fine grained control:
// From the container view controller
- (BOOL) shouldAutomaticallyForwardAppearanceMethods
{
return NO;
}
-(void) viewWillAppear:(BOOL)animated
{
[self.child beginAppearanceTransition: YES animated: animated];
}
-(void) viewDidAppear:(BOOL)animated
{
[self.child endAppearanceTransition];
}
-(void) viewWillDisappear:(BOOL)animated
{
[self.child beginAppearanceTransition: NO animated: animated];
}
-(void) viewDidDisappear:(BOOL)animated
{
[self.child endAppearanceTransition];
}
回答3:
Try this one:
childController.willMoveToParentViewController(self)
childController.beginAppearanceTransition(true, animated: true)
after added to your view controller
回答4:
Just tried do the following in viewDidLoad in the parent viewcontroller and it seems to work
ChildExperimentViewController *child = [[ChildExperimentViewController alloc]init];
[self addChildViewController:child];
[self.view addSubview:child.view];
[child didMoveToParentViewController:self];
回答5:
let vc = ChildVC.init()
vc.frame = self.view.bounds
self.addChildViewController(vc)
self.view.addSubview(vc.view)
vc.willMove(toParentViewController: self)
vc.didMove(toParentViewController: self)
回答6:
Chourobin answer in Swift:
override var shouldAutomaticallyForwardAppearanceMethods: Bool {
return false
}
override func viewWillAppear(_ animated: Bool) {
self.childViewControllers[self.segmentView.selectedSegmentIndex].beginAppearanceTransition(true, animated: animated)
}
override func viewDidAppear(_ animated: Bool) {
self.childViewControllers[self.segmentView.selectedSegmentIndex].endAppearanceTransition()
}
override func viewWillDisappear(_ animated: Bool) {
self.childViewControllers[self.segmentView.selectedSegmentIndex].beginAppearanceTransition(false, animated: animated)
}
override func viewDidDisappear(_ animated: Bool) {
self.childViewControllers[self.segmentView.selectedSegmentIndex].endAppearanceTransition()
}
P.S. As I am not keeping the reference to a child VC as a property or a variable. I preferring to access it using the currently selected segment index. SegmentView is a third party UISegmentControl
.
回答7:
You can manual call the child view controller's viewWillAppear in parectViewController,code like this
-(void)viewWillAppear:(BOOL)animated
{
[super viewWillAppear:animated];
[selectedViewController viewWillAppear:animated];
}
if you have add a navigationController as childViewController you can add code like this in navigationController's delegate
-(void)navigationController:(UINavigationController *)navigationController willShowViewController:(UIViewController *)viewController animated:(BOOL)animated
{
[viewController viewWillAppear:animated];
}
if you have add a tabBarController as childViewController you can add code like this in tabBarController's delegate and super view
- (void)viewWillAppear:(BOOL)animated {
[super viewWillAppear:animated];
[self.tabBarController.selectedViewController viewWillAppear:animated];
}
- (void)tabBarController:(UITabBarController *)tabBarController didSelectViewController:(UIViewController *)viewController {
[viewController viewWillAppear:NO];
}
I don't know if this can solve your problem,hope be able to help you.