0

我有一个正在加载覆盖控制器的应用程序(显示相机以便我可以扫描)。它在 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];
}

 }

我完全没有想法。我不明白为什么覆盖控制器中的控件在我每次调用它时都能正常工作,除了第一次。

提前感谢任何人的帮助。

4

1 回答 1

2

所以答案是超类与您的观点相左。我猜它不是为子类而设计的,但无法确定。它在“视图..”方法之一中所做的是用自己的视图覆盖 self.view,并使您的视图成为该视图的子视图。第一次使您的视图框架具有零尺寸。下一次它像以前一样离开它 - 也许是一些持久的标志。它还在其子视图的不同位置插入视图,这看起来很奇怪,但如果您有代码,您可能会明白原因。

Soooo - 问题的解决方案是将视图的子视图移动到超级视图(子类的视图),然后将视图的框架设置为空框架:

- (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 调用,但这似乎并不重要(您不知道您的复杂超类可能需要哪种方法,所以我一定会向他们发送您拦截的所有内容。

于 2012-09-12T19:05:34.127 回答