0

简单的问题(是的,对!)。我想在我的 iPad 项目的 UISplitViewController 的详细信息页面上添加一个“下一步”按钮。如果单击,这将是前进到页面列表中的下一页的另一种方式。作为奖励,我想突出显示根视图中与您登陆的新视图相对应的正确行。

任何关于去哪里的一般指导和建议都很棒!

更新:感谢下面安娜的建议,这是我用来将所有这些结合在一起的代码。效果很好。谢谢安娜。

在详细信息页面上,我包括了这个:

- (IBAction)goToNext{
    NSLog(@"Going to Next from Welcome");
    [[NSNotificationCenter defaultCenter]
     postNotificationName:@"NextPageRequested" object:nil];

}

在 RootViewController 页面上,我做了:

- (void)viewDidLoad {
    [super viewDidLoad];
    [[NSNotificationCenter defaultCenter]
     addObserver:self selector:@selector(moveOnToNextPage:)
     name:@"NextPageRequested" object:nil];
}

最后在 RootViewController 中:

#pragma mark -
#pragma mark The NEXT Button
// This is the Code used for the Big NEXT button.  basically a Notification Center listener is set up in the view did load and when triggered by any of the buttons, this 
// function is called.  Here, I do 3 things:  1.  advance the highlighted cell of the master table view.  2.  call the didSelectRowAtIndexPath function of the table to 
// advance to the next page.  and 3.  Exchange the "dash" icon with the "check" icon.


-(void)moveOnToNextPage:(NSNotification*)notifications {
    NSIndexPath*    selection = [self.tableView indexPathForSelectedRow]; // grab the row path of the currently highlighted item



// Change the icon in the current row:

    NSString *checkImage = [[NSBundle mainBundle] pathForResource:@"checkGreen" ofType:@"png"];
    UIImage *checkMark = [[[UIImage alloc] initWithContentsOfFile:checkImage] autorelease]; // Grab the checkmark image.
    if (selection) {
        NSLog(@"not nil");
        UITableViewCell *cell1 = [self.tableView cellForRowAtIndexPath:[self.tableView indexPathForSelectedRow]];
        // cell1.accessoryType = UITableViewCellAccessoryCheckmark; // this is yet another way to add the checkmar, but for now, I will use Mine.
        cell1.imageView.image = checkMark; // now set the icon
    } else {
        NSLog(@"must be nil");
        NSUInteger indexArrBlank[] = {0,0}; // now throw this back into the integer set
        NSIndexPath *blankSet = [NSIndexPath indexPathWithIndexes:indexArrBlank length:2]; // create a new index path 
        UITableViewCell *cell0 = [self.tableView cellForRowAtIndexPath:blankSet];
        // cell1.accessoryType = UITableViewCellAccessoryCheckmark; // this is yet another way to add the checkmar, but for now, I will use Mine.
        cell0.imageView.image = checkMark; // now set the icon
    }



// Highlight the new Row
    int nextSelection = selection.row +1; // grab the int value of the row (cuz it actually has both the section and the row {section, row}) and add 1
    NSUInteger indexArr[] = {0,nextSelection}; // now throw this back into the integer set
    NSIndexPath *indexSet = [NSIndexPath indexPathWithIndexes:indexArr length:2]; // create a new index path 
    [self.tableView selectRowAtIndexPath:indexSet animated:YES scrollPosition:UITableViewScrollPositionTop]; // tell the table to highlight the new row

// Move to the new View
    UITableView *newTableView = self.tableView; // create a pointer to a new table View
    [self tableView:newTableView didSelectRowAtIndexPath:indexSet]; // call the didSelectRowAtIndexPath function
    //[newTableView autorelease];  //let the new tableView go.  ok.  this crashes it, so no releasing for now.

}
4

2 回答 2

0

实现这一点的一种方法是使用NSNotificationCenter.

viewDidLoad 中的根视图控制器将调用addObserver:selector:name:object:以使自己成为名为@“NextPageRequested”的通知的观察者。

当点击详细视图上的按钮时,将调用postNotificationName:object:以请求根视图控制器转到下一页。

在根视图控制器中,通知处理程序方法将(假设根视图控制器是 UITableView):

  • 使用 UITableView 获取当前索引路径indexPathForSelectedRow
  • 计算下一个索引路径
  • 调用selectRowAtIndexPath:animated:scrollPosition:以突出显示该行
  • 调用实际更改页面所需的代码(可能通过tableView:didSelectRowAtIndexPath:直接调用)
于 2011-04-27T02:28:40.933 回答
0

给你的 detailviewcontroller 一个父导航控制器,并通过导航项将你的下一个按钮添加到导航栏。按下 Next 将触发一个 pushviewcontroller 到 nav-stack。

或者将顶部工具栏添加到您当前的视图控制器并将按钮放在那里。

于 2011-04-27T02:29:04.963 回答