3

我现在拼命尝试 2 小时来在我的代码中找到一个错误,这导致我没有显示我已经实现的 SplitViewController。奇怪的是,没有显示编译错误,并且所有链接和依赖项似乎都是正确的。

首次加载时屏幕上没有显示任何内容。但是当我旋转设备时,我看到了正确的视图。但是当启动时,根本没有视图,即使所有视图都已连接。

我只是让它的一部分工作......我用调试器发现,第一个视图控制器在启动时没有加载。所以拆分视图的视图控制器数组没有填充初始视图控制器......我该如何解决这个问题?

我检查的第一部分是我的 AppDelegate:

#import "AppDelegate.h"
#import "RootViewController.h"

@implementation AppDelegate

@synthesize window = _window;
@synthesize splitViewController = _splitViewController;

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
    NSLog(@"%s %d", __PRETTY_FUNCTION__, __LINE__);
    [[self window] addSubview:self.splitViewController.view];
    [self.window makeKeyAndVisible];

    return YES;
}



@end

第一个视图控制器

#import "FirstViewController.h"

@implementation FirstViewController
@synthesize toolbar;


#pragma mark -
#pragma mark View Lifecycle

- (void)viewDidUnload
{
    [super viewDidUnload];
    self.toolbar = nil;
}


#pragma mark -
#pragma mark Managing the Popover

- (void)showRootPopoverButtonItem:(UIBarButtonItem *)barButtonItem
{
    NSMutableArray *itemsArray = [toolbar.items mutableCopy];
    [itemsArray insertObject:barButtonItem atIndex:0];
    [toolbar setItems:itemsArray animated:NO];
}

- (void)invalidateRootPopoverButtonItem:(UIBarButtonItem *)barButtonItem
{
    NSMutableArray *itemsArray = [toolbar.items mutableCopy];
    [itemsArray removeObject:barButtonItem];
    [toolbar setItems:itemsArray animated:NO];
}

#pragma mark -
#pragma mark Rotation support

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation {
    return YES;
}


@end

我检查的第二部分是我的 RootViewController。问题是,当您单击 tableView 条目时,应加载并显示一个新的视图控制器。所以我没有在我的应用程序 Delegate 中实例化 VC,而是在“选择行”表视图委托方法中实例化 VC。

这是根视图控制器:

#import "RootViewController.h"
#import "FirstViewController.h"
#import "SecondViewController.h"

@implementation RootViewController
@synthesize popoverController, splitViewController, rootPopoverButtonItem;


#pragma mark -
#pragma mark View Lifecycle

- (void)viewDidLoad
{
    NSLog(@"%s %d", __PRETTY_FUNCTION__, __LINE__);
    [super viewDidLoad];
    self.contentSizeForViewInPopover = CGSizeMake(310.0, self.tableView.rowHeight * 2.0);
}

- (void)viewDidUnload
{
    NSLog(@"%s %d", __PRETTY_FUNCTION__, __LINE__);
    [super viewDidUnload];
    self.splitViewController = nil;
    self.rootPopoverButtonItem = nil;
}


#pragma mark -
#pragma mark Rotation support

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)toInterfaceOrientation
{
    NSLog(@"%s %d", __PRETTY_FUNCTION__, __LINE__);
    return YES;
}


#pragma mark -
#pragma mark SplitViewController delegates

- (void)splitViewController:(UISplitViewController *)svc willHideViewController:(UIViewController *)aViewController withBarButtonItem:(UIBarButtonItem *)barButtonItem forPopoverController:(UIPopoverController *)pc
{
    NSLog(@"%s %d", __PRETTY_FUNCTION__, __LINE__);
    barButtonItem.title = @"PolyCube Prototypes";

    self.popoverController = pc;
    self.rootPopoverButtonItem = barButtonItem;

    UIViewController <SubstitutableDetailViewController> *detailViewController = [splitViewController.viewControllers objectAtIndex:1];
    [detailViewController showRootPopoverButtonItem:rootPopoverButtonItem];
}

- (void)splitViewController:(UISplitViewController *)svc willShowViewController:(UIViewController *)aViewController invalidatingBarButtonItem:(UIBarButtonItem *)barButtonItem
{
    NSLog(@"%s %d", __PRETTY_FUNCTION__, __LINE__);
    self.popoverController = nil;
    self.rootPopoverButtonItem = nil;

    UIViewController <SubstitutableDetailViewController> *detailViewController = [splitViewController.viewControllers objectAtIndex:1];
    [detailViewController invalidateRootPopoverButtonItem:rootPopoverButtonItem];
}



#pragma mark -
#pragma mark Table View Data Source

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    NSLog(@"%s %d", __PRETTY_FUNCTION__, __LINE__);
    return 2;
}

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    NSLog(@"%s %d", __PRETTY_FUNCTION__, __LINE__);
    static NSString *CellIdentifier = @"RootViewControllerIdentifier";

    UITableViewCell *cell = [self.tableView dequeueReusableCellWithIdentifier:CellIdentifier];

    if (cell == nil) {
        cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier];
    }

    if (indexPath.row == 0) {
        cell.textLabel.text = @"PolyCube 1";
    }
    else {
        cell.textLabel.text = @"PolyCube 2";
    }

    return cell;
}


#pragma mark -
#pragma mark - Table View Selection

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
    NSLog(@"%s %d", __PRETTY_FUNCTION__, __LINE__);
    NSUInteger row = indexPath.row;

    UIViewController <SubstitutableDetailViewController> *detailViewController = nil;

    if (row == 0) {
        FirstViewController *newDetailViewController = [[FirstViewController alloc] initWithNibName:@"FirstDetailView" bundle:nil];
        detailViewController = newDetailViewController;
    }


    if (row == 1) {
        SecondViewController *newDetailViewController = [[SecondViewController alloc] initWithNibName:@"SecondDetailView" bundle:nil];
        detailViewController = newDetailViewController;
    }


    NSArray *vcs = [[NSArray alloc] initWithObjects:self.navigationController, detailViewController, nil];
    splitViewController.viewControllers = vcs;

    if (popoverController != nil) {
        [popoverController dismissPopoverAnimated:YES];
    }

    if (rootPopoverButtonItem != nil) {
        [detailViewController showRootPopoverButtonItem:self.rootPopoverButtonItem];
    }
}

@end

我真的很感激伸出援助之手……我不知道该去哪里找了。我什至检查了所有 IB 连接......我认为没有错。但仍然只有一个白屏。

非常感谢塞巴斯蒂安

4

1 回答 1

0

这种行为是意料之中的。如果您不设置 UISplitViewController 的委托,则主视图在纵向模式下将不可见。您的主视图永远不会加载,您看到的白屏是您的详细视图。

因此,您需要实现自己的 UISplitViewController(创建一个新的 UIViewController 并将其更改为 UISplitViewControlle。不要忘记在 Storyboard 中将其分配给您的拆分视图)

同样在接口中,使其实现,并在 viewDidLoad 方法中将委托设置为 self。

这个协议将告诉把主表放在哪里。你想要它像分割模式一样,分割窗口吗?或者也许你想要一个按钮(通常在标签栏中),当你按下它时,主窗口会弹出?

例如,实现这个家伙让主视图始终可见:

界面:

#import <UIKit/UIKit.h>

@interface SplitViewController : UISplitViewController <UISplitViewControllerDelegate>

@end

执行

#import "SplitViewController.h"

@interface SplitViewController ()

@end

@implementation SplitViewController


- (void)viewDidLoad
{
    [super viewDidLoad];
    [self setDelegate:self];
}

- (void)viewDidUnload
{
    [super viewDidUnload];
    // Release any retained subviews of the main view.
}

- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation
{
    return YES;
}

-(BOOL)splitViewController:(UISplitViewController *)svc shouldHideViewController:(UIViewController *)vc inOrientation:(UIInterfaceOrientation)orientation{
    return NO;
}


@end

如果您不想实现自己的 UISplitViewController 来处理委托,您还可以让您的任何主控制器或细节控制器来实现它并在情节提要中分配它(尝试 ctrl 并从拆分视图拖动到您的任何控制器并将其设置为委托,不要忘记先实现协议)

于 2012-05-19T22:07:01.887 回答