我有一个正在加载覆盖控制器的应用程序(显示摄像头以便我可以扫描)。它在iPhone上运行良好,在我第二次调用它后,它在iPad上运行良好。让我解释一下。
我有一个UIButtonBarItem以模态方式加载视图控制器。控制器中有几个控件,大多数按钮(使用笔尖定义)。如果我在iPhone上加载控制器(通过响应UIButtonBarItem操作),它每次都会加载并且所有按钮都能正常工作。
但是......如果我使用UIPopoverController加载相同的视图控制器,第一次加载它时,没有任何按钮会响应。所以,我在控制器外面的某个地方触摸屏幕并关闭控制器。然后,我再次触摸相同的操作按钮,现在当控制器加载时,视图控制器中的所有控件都能很好地工作。真的很啰!
[可能的提示] 当我第一次装入按钮时,按钮被放置在奇怪的位置。每个后续呼叫都有按钮显示在正确的位置。我通过在笔尖中禁用“自动调整子视图”来实现此功能。按钮现在位于正确的位置,但是当我第一次加载此弹出窗口时它们仍然无法响应。
这是我用来响应UIButtonBarItem的代码。
-(void)launchOverlayController:(id)sender
{
if([pickerControllerPopover isPopoverVisible])
{
[pickerControllerPopover dismissPopoverAnimated:YES];
pickerControllerPopover = nil;
return;
}
// Deselect any selected cell
[self.tableView deselectRowAtIndexPath:self.tableView.indexPathForSelectedRow animated:NO];
// Working code that shows the overlay (camera on) but the overlay takes the whole screen
SRSScanVINViewController *scanVINViewController = [[SRSScanVINViewController alloc] init];
[pickerController setOverlay:scanVINViewController];
UINavigationController *navController = [[UINavigationController alloc] initWithRootViewController:scanVINViewController];
[navController setModalPresentationStyle:UIModalPresentationFormSheet];
[navController setModalTransitionStyle:UIModalTransitionStyleFlipHorizontal];
[[UIApplication sharedApplication] setStatusBarHidden:YES];
if([[UIDevice currentDevice] userInterfaceIdiom] == UIUserInterfaceIdiomPad)
{
pickerControllerPopover = [[UIPopoverController alloc] initWithContentViewController:pickerController];
[pickerControllerPopover setDelegate:self];
[pickerControllerPopover setPopoverContentSize:CGSizeMake(320.0f, 460.0f)];
[pickerControllerPopover presentPopoverFromBarButtonItem:sender permittedArrowDirections:UIPopoverArrowDirectionAny animated:YES];
}
else
{
[self presentViewController:pickerController animated:YES completion:nil];
}
}
我完全没有想法。我无法理解为什么每次调用它时,overlaycontroller中的控件都能正常工作,除了第一次。
感谢任何人提前帮助。
答案 0 :(得分:2)
所以答案是超类正在诋毁你的观点。我猜它不是设计为子类,但没有办法确定。它在其中一个'view ..'方法中的作用是用自己的视图覆盖self.view,并使您的视图成为该视图的子视图。第一次绕过它会使视图的框架具有零维度。下次它像以前一样离开它 - 也许是一些持久的旗帜。它还将视图插入其子视图中的不同位置,这看起来很奇怪,但如果您有代码,则可能会看到原因。
Soooo - 问题的解决方案是将视图的子视图移动到superView(子类的视图),然后将视图的框架设置为空框架:
- (void) viewWillAppear:(BOOL)animated
{
[super viewWillAppear:animated]; // StackOverflow says to add this TCL?
// Set the initial scan orientation
[self setLayoutOrientation:self.parentPicker.orientation];
if ([self.parentPicker hasFlash])
{
[flashButton setEnabled:YES];
[flashButton setStyle:UIBarButtonItemStyleBordered];
[self.parentPicker turnFlash:NO];
} else
{
[flashButton setEnabled:NO];
}
textCue.text = @"";
viewHasAppeared = NO;
// move the subviews
while([self.view.subviews count]) [self.view.superview addSubview:[self.view.subviews objectAtIndex:0]];
self.view.frame = CGRectMake(0,0,0,0);
}
PS:请注意你在这里错过了一个superView调用,但它似乎并不重要(你不知道你的复杂超类可能需要哪种方法,所以我一定会把它们发送给你拦截的所有东西。< / p>