控件在初始加载时没有在UIPopoverController中响应,但是在后续加载时做了什么?

时间:2012-09-08 23:56:42

标签: ios ipad

我有一个正在加载覆盖控制器的应用程序(显示摄像头以便我可以扫描)。它在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中的控件都能正常工作,除了第一次。

感谢任何人提前帮助。

1 个答案:

答案 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>