소스..
This section shows project code that inserts a row in a table view. Instead of using the insertion control as the trigger for inserting a row, it uses an Add button (visually a plus sign) in the navigation bar above the table view. This code also is based on the navigation controller and view controller architecture. In its loadView method implementation, the view controller assigns the Add button as the right-side item of the navigation bar using the code shown in Listing 7-4.
Listing 7-4 Adding an Add button to the navigation bar
addButton = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemAdd target:self action:@selector(addItem:)];
self.navigationItem.rightBarButtonItem = addButton;
Note that the view controller sets the control states for the title as well as the action selector and the target object. When the user taps the Add button, the addItem: message is sent to the target (the view controller). It responds as shown in Listing 7-5. It creates a navigation controller with a single view controller whose view is put onscreen modally—it animates upward to overlay the table view. The presentModalViewController:animated: method to do this.
Listing 7-5 Responding to a tap on the Add button
- (void)addItem:sender {
if (itemInputController == nil) {
itemInputController = [[ItemInputController alloc] init];
}
UINavigationController *navigationController = [[UINavigationController alloc] initWithRootViewController:itemInputController];
[[self navigationController] presentModalViewController:navigationController animated:YES];
[navigationController release];
}
The modal, or overlay, view consists of a single custom text field. The user enters text for the new table-view item and then taps a Save button. This button sends a save: action message to its target: the view controller for the modal view. As shown in Listing 7-6, the view controller extracts the string value from the text field and updates the application’s data-model array with it.
Listing 7-6 Adding the new item to the data-model array
- (void)save:sender {
UITextField *textField = [(EditableTableViewTextField *)[tableView cellForRowAtIndexPath:[NSIndexPath indexPathForRow:0 inSection:0]] textField];
SimpleEditableListAppDelegate *controller = (SimpleEditableListAppDelegate *)[[UIApplication sharedApplication] delegate];
NSString *newItem = textField.text;
if (newItem != nil) {
[controller insertObject:newItem inListAtIndex:[controller countOfList]];
}
[self dismissModalViewControllerAnimated:YES];
}
After the modal view is dismissed the table view is reloaded, and it now reflects the added item.
5.2.2 ~ 5 fin : 14th
6.1 : 15th, 16th
6.2~ 6fin : 17th
7th : 18th
[BiKE]
1. Fri Seminar => Paper..
- 14th ~ 19th
- make kn file..
- find previous works
- define my theory..?
- 20th
- and meeting.
- make kn file.
2. SNA Paper / 8th ~ 18th
3. iPhone App / 7th ~ 18th
- make layout and Twitter information / 7th ~ 11th
- link to url / ~18th
4. Eng SNA Paper / 18th ~ 28th
[SSM]
1. Test(16,17) 14th ~ 17th
2. SNA Seminar 11th ~ 13th
3. prepare interview 14th ~
[Car]
1. 10th day..