2009-10-26 29 views
5

Jak mogę wdrożyć próbnik wyboru modalnego?iPhone SDK: Jak wdrożyć modalny wybór daty?

To, co chcę zrobić, to kiedy użytkownik wchodzi w pole tekstowe, tworzony jest nowy widok z ustawionym wyborem daty. Stamtąd użytkownik może wchodzić w interakcję i wybierać datę. Gdy widok jest zamknięty, powinien jakoś zwrócić datę rozmówcy. czy to możliwe?

BTW, nie mogę ustawić wyboru daty w moim głównym formularzu z powodu spacji.

Z góry dziękuję.

Odpowiedz

12

Skorzystaj z delegata!

Header:

@class DatePickerController; 
@protocol DatePickerControllerDelegate 
- (void) datePickerController:(DatePickerController *)controller didPickDate:(NSDate *)date; 
@end 

@interface DatePickerController : UIViewController { 
    UIDatePicker *datePicker; 
    NSObject <DatePickerControllerDelegate> *delegate; 
} 

@property (nonatomic, retain) UIDatePicker *datePicker; 
@property (nonatomic, assign) NSObject <DatePickerControllerDelegate> *delegate; 
@end 

klasa:

@implementation DatePickerController 
- (void) loadView { 
    self.view = [[[UIView alloc] init] autorelease]; 
    self.datePicker = [[[UIDatePicker alloc] init] autorelease]; 
    [self.view addSubview:self.datePicker]; 
    UIButton *button = [UIButton buttonWithType:UIButtonTypeRoundedRect]; 
    [button setTitle:@"Done" forState:UIControlStateNormal]; 
    button.center = CGPointMake(160,240); 
    [button addTarget:self action:@selector(done) forControlEvents:(UIControlEventTouchUpInside)]; 
    [self.view addSubview:button]; 
} 

- (void) done { 
    [delegate datePickerController:self didPickDate:datePicker.date]; 
} 

- (void) dealloc { 
    [datePicker release]; 
    [super dealloc]; 
} 

@end 

Wszystko to bzdury w loadview można zastąpić w stalówkę, jeśli wolisz. Po prostu upewnij się, że zadeklarujesz datePicker jako IBOutlet. i kiedy chcesz, aby rzeczywiście go używać:

- (void) pickDate { 
    DatePickerController *screen = [[[DatePickerController alloc] init] autorelease]; 
    screen.delegate = self; 
    [self presentModalViewController:screen animated:YES]; 
} 

- (void) datePickerController:(DatePickerController *)controller didPickDate:(NSDate *)date { 
    [self doSomethingWithDate:date]; 
    [controller dismissModalViewControllerAnimated:YES]; 
} 
+0

Świetna odpowiedź, Ed! – typeoneerror

+0

Witaj Ed, trochę początkujący, czy mógłbyś w ogóle dostarczyć działające demo? Myślę, że coś mi brakuje! – jimbo

+0

Pewnie ... co jest nie tak z powyższym kodem? Czy to nie działa? Powinno. –

2

Prostsze rozwiązanie robocze:

W swojej .h:

@property (nonatomic,strong) IBOutlet UIDatePicker *datePicker; 
@property (weak, nonatomic) IBOutlet UITextField *historyDateSelect; 
@property (nonatomic, retain) UIToolbar *dateToolbar; 

W swojej .m:

- (void)viewDidLoad 
{ 
    [super viewDidLoad]; 


    self.datePicker = [[UIDatePicker alloc]init]; 
    [self.datePicker addTarget:self action:@selector(dateChanged) forControlEvents:UIControlEventValueChanged]; 


    UIToolbar *toolbar = [[UIToolbar alloc] initWithFrame:CGRectMake(0, 0, 320, 44)]; 
    UIBarButtonItem *doneButton = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemDone target:nil action:nil];  
    [toolbar setItems:[NSArray arrayWithObject:doneButton]]; 

    self.dateToolbar = toolbar; 

    self.historyDateSelect.inputView = self.datePicker; 
    self.historyDateSelect.inputAccessoryView = self.dateToolbar; 
} 

I to jest to. (Testowałem to lokalnie i działa)

+0

Świetne rozwiązanie. – GuybrushThreepwood