Retired Document
Important: This sample code may not represent best practices for current development. The project may use deprecated symbols and illustrate technologies and techniques that are no longer recommended.
Classes/RootViewController.m
| /* | 
| File: RootViewController.m | 
| Abstract: A table view controller to display a list of names of plays. | 
| Version: 3.1 | 
| Disclaimer: IMPORTANT: This Apple software is supplied to you by Apple | 
|  Inc. ("Apple") in consideration of your agreement to the following | 
| terms, and your use, installation, modification or redistribution of | 
| this Apple software constitutes acceptance of these terms. If you do | 
| not agree with these terms, please do not use, install, modify or | 
| redistribute this Apple software. | 
| In consideration of your agreement to abide by the following terms, and | 
| subject to these terms, Apple grants you a personal, non-exclusive | 
| license, under Apple's copyrights in this original Apple software (the | 
| "Apple Software"), to use, reproduce, modify and redistribute the Apple | 
| Software, with or without modifications, in source and/or binary forms; | 
| provided that if you redistribute the Apple Software in its entirety and | 
| without modifications, you must retain this notice and the following | 
| text and disclaimers in all such redistributions of the Apple Software. | 
| Neither the name, trademarks, service marks or logos of Apple Inc. may | 
| be used to endorse or promote products derived from the Apple Software | 
| without specific prior written permission from Apple. Except as | 
| expressly stated in this notice, no other rights or licenses, express or | 
| implied, are granted by Apple herein, including but not limited to any | 
| patent rights that may be infringed by your derivative works or by other | 
| works in which the Apple Software may be incorporated. | 
| The Apple Software is provided by Apple on an "AS IS" basis. APPLE | 
| MAKES NO WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION | 
| THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS | 
| FOR A PARTICULAR PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS USE AND | 
| OPERATION ALONE OR IN COMBINATION WITH YOUR PRODUCTS. | 
| IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL | 
| OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | 
| SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | 
| INTERRUPTION) ARISING IN ANY WAY OUT OF THE USE, REPRODUCTION, | 
| MODIFICATION AND/OR DISTRIBUTION OF THE APPLE SOFTWARE, HOWEVER CAUSED | 
| AND WHETHER UNDER THEORY OF CONTRACT, TORT (INCLUDING NEGLIGENCE), | 
| STRICT LIABILITY OR OTHERWISE, EVEN IF APPLE HAS BEEN ADVISED OF THE | 
| POSSIBILITY OF SUCH DAMAGE. | 
| Copyright (C) 2012 Apple Inc. All Rights Reserved. | 
| */ | 
| #import "RootViewController.h" | 
| #import "DataController.h" | 
| #import "DetailViewController.h" | 
| #import "Play.h" | 
| @implementation RootViewController | 
| @synthesize dataController; | 
| #pragma mark - | 
| #pragma mark View lifecycle | 
| - (void)viewDidLoad { | 
| [super viewDidLoad]; | 
| self.title = NSLocalizedString(@"Plays", @"Master view navigation title"); | 
| } | 
| #pragma mark - | 
| #pragma mark Table view data source | 
| - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView { | 
| // Only one section. | 
| return 1; | 
| } | 
| - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section { | 
| // Only one section, so return the number of items in the list. | 
| return [dataController countOfList]; | 
| } | 
| - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { | 
| static NSString *CellIdentifier = @"PlayCell"; | 
| UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier]; | 
| // Get the object to display and set the value in the cell. | 
| Play *playAtIndex = [dataController objectInListAtIndex:indexPath.row]; | 
| cell.textLabel.text = playAtIndex.title; | 
| return cell; | 
| } | 
| #pragma mark - | 
| #pragma mark Table view selection | 
| - (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender { | 
| /* | 
| When a row is selected, the segue creates the detail view controller as the destination. | 
| Set the detail view controller's detail item to the item associated with the selected row. | 
| */ | 
|     if ([[segue identifier] isEqualToString:@"ShowSelectedPlay"]) { | 
| NSIndexPath *selectedRowIndex = [self.tableView indexPathForSelectedRow]; | 
| DetailViewController *detailViewController = [segue destinationViewController]; | 
| detailViewController.play = [dataController objectInListAtIndex:selectedRowIndex.row]; | 
| } | 
| } | 
| @end | 
Copyright © 2012 Apple Inc. All Rights Reserved. Terms of Use | Privacy Policy | Updated: 2012-02-28