views:

738

answers:

2

I'm playing with writing my first iphone app; SDK 3.0. I've got a UITextField, and when text gets entered into that, I want to obtain the doubleValue from the text field and perform some computations and display them in a UITableView.

The delegate for the UITextField adopts the UITextFieldDelegate protocol, and implements both textFieldShouldReturn: and textFieldDidEndEditing: methods. textFieldShouldReturn: resigns first responder status which, according to docs should also trigger textFieldDidEndEditing:, but I never see textFieldDidEndEditing: called.

- (BOOL)textFieldShouldReturn:(UITextField*)theTextField {
    if (theTextField == thresholdValue) {
        [thresholdValue resignFirstResponder];
    }
    return YES;
}

- (void)textFieldDidEndEditing:(UITextField *)textField {
    [self updateThresholdValue:textField];
}

It may be worth noting that I also tried connecting some of the textfield events to the delegate and having the event call updateThresholdValue: directly, but that didn't work either.

A: 

textFieldDidEndEditing is fired when the textfield resigns it's first responder status while textFieldShouldReturn is fired when the return button is pressed.

It sounds like your textfield is never resigning as firstResponder. You can check it pretty easily by putting some debug output (as suggested in the comments) and just navigating out of the textfield with a touch - eg start typing then just touch outside of the field to force it to resign firstResponder.

Not sure if that helps a lot, but it sounds like a strange case you are hitting.

paulthenerd
Thanks for the note. Take a look at the code that I added to the initial question. testFieldShouldReturn: does call resignFirstResponder, and I've confirmed that the resignation line of code executes via the debugger.Does textFieldDidEndEditing: get called as part of resignFirstResponder's execution, or does it occur *after* resignFirstResponder completes execution?Finally, in case it matters, I'm still running in the simulator rather than the actual device. I don't have the magic keys yet.
Chris Cleeland
More info on this...I whipped out HelloWorld demo app--has a textfield, button, and label: type text into field, hit button, label updates. I modified the nib so that the label sends an "Editing Did End" event to the same object and action that the button uses. And it worked. So, I went back to my app described above and did the same thing...and it didn't work. There must be something subtly different, but so far I haven't spotted it.
Chris Cleeland
One other thing I'd check is that the method signature for textFieldDidEndEditing *exactly* matches the signature from the api docs, it looks right to me but if there is any error in that the delegate method won't ever be called. You can actually copy the signature directly out of the API docs to be sure.
paulthenerd
Excellent advice Paul. Unfortunately, I already tried that to no avail. See my followup answer to be added soon.
Chris Cleeland
A: 

As mentioned in one of the comments, I tried replicating a simpler version of what I was trying to do using a HelloWorld app, and it worked on the first try, with no problems, just as expected. Faced with that, I began to wonder a bit.

Somewhere in all the googling I did to try to get an answer to this problem, I ran across a link where a person was having a problem with events not firing from a button, and it turned out that the problem was related to the view in which the button was placed and that view having another subview as a peer to the button, and that subview was somehow eating the events rather than allowing them to go where they'd been directed. The scenario wasn't exactly the same as mine, but it sounded close enough that investigation would be worthwhile. Despite all the excellent advice received here, none had yet borne fruit.

Last night I decided to completely re-create the nib file from scratch (made a copy of what I had first), and I got it to work. The key difference seems to be that I in the original non-working nib file, I had dragged over a TableViewController from the palette, then changed its type to my subclass PZTableViewController. When I did that same thing in my new nib, the events didn't fire. If, on the other hand, I removed the dragged-over TableViewController and instead just dragged over an NSObject and changed its class to PZTableViewController and plumbed everything up, it all "just worked".

I will try to chase down the link that got me started on this line of thinking and post it either as an edit or as a comment.

This is also not a complete answer because I do not yet understand the difference between the from-the-palette TableViewController and my subclass. When I figure that out, I will update this answer via edit or comment.

Chris Cleeland