What's the right way to add a ToolBar to a UITableView?

后端 未结 5 1071
情深已故
情深已故 2021-01-31 04:27

I\'m writing a Navigation-Based iPhone app, and I\'d like to have a UIToolBar docked at the bottom of my screen, with a UITableView scrolling between the tool bar and the naviga

相关标签:
5条回答
  • 2021-01-31 04:53

    Try out this:

    self.navigationController.toolbarHidden = NO;
    

    Hope it helps you.

    0 讨论(0)
  • 2021-01-31 04:54
    //Tool bar
    [self.navigationController setToolbarHidden:NO];
    
    UIBarButtonItem *buttonItem = [[ UIBarButtonItem alloc ] initWithTitle: @"Select All"
                                                    style: UIBarButtonItemStyleBordered
                                                   target: self
                                                   action: @selector(selectAll:) ];
    UIBarButtonItem *buttonNext = [[UIBarButtonItem alloc]initWithTitle:@"Next" style:UIBarButtonItemStyleBordered target:self action:@selector(goNext:)];
    self.toolbarItems = [ NSArray arrayWithObjects: buttonItem, buttonNext, nil ];
    
    [ buttonItem release ];
    [buttonNext release];
    
    0 讨论(0)
  • 2021-01-31 04:55

    All you need do is implement the UITableViewDelegate and UITableViewDatasource methods required for the level of table view functionality you require. These methods can be in any class(es) though said classes should conform to the relevant protocols. The delegate and datasource should be set on the UITableView instance - either programatically or with Interface Builder. According to the docs you will lose some functionality - see the overview section.

    Personally I find that many developers seem to be obsessed with providing all of this functionality in a single monolithic view controller class, and that because they have a table view in their view then a subclass of UITableViewController must be used. However, I like to consider the Single Responsibility Principle and will often break the datasource and delegate into separate classes when the complexity is anything other than simple. The code is also then not tied to a specific UIViewController implementation.

    In situations where I have separate datasource/delegate classes I often construct and wire them up to the table view using Interface Builder and not in code. This approach (to me at least) is in the spirit of Dependency Injection and saves writing some boiler-plate code, and provides some level of decoupling.

    These choices of course are influenced by the complexity of the functionality that you are trying to achieve - for simple implementations I might find myself using UITableViewController.

    0 讨论(0)
  • 2021-01-31 05:02

    Corey Floyd is mostly correct, except that

    [self.navigationController setToolBarHidden:NO];
    

    should be

    [self.navigationController setToolbarHidden:NO];
    

    That is, the "b" in "setToolbarHidden" must be lowercase. Also, method name listed in the iPhone OS Reference is actually

    - (void)setToolbarHidden:(BOOL)hidden animated:(BOOL)animated
    

    though it seems that omitting the animated parameter works too.

    0 讨论(0)
  • 2021-01-31 05:07

    As of OS 3.0 the Navigation Controller has a tool bar built in. To make it appear:

    [self.navigationController setToolbarHidden:NO];
    

    By implmenting:

    - (void)setToolbarItems:(NSArray *)toolbarItems animated:(BOOL)animated
    

    in your view controller, you can configure the items of the tool bar.

    So you no longer have to worry about where the tool bar is located in your hierarchy.

    (corrected typo)

    0 讨论(0)
提交回复
热议问题