Подтвердить что ты не робот

Показывать датупиксера при нажатии на текстовое поле

Как я могу отобразить элемент управления datetimepicker при нажатии текстового поля?

У меня есть пользовательский интерфейс с текстовыми полями прилета и вылета, и когда пользователь нажимает на текстовое поле прибытия, он должен вызывать элемент управления datetimepicker вместо клавиатуры и то же самое с текстовым полем отправления.

4b9b3361

Ответ 1

Для этого вы можете использовать свойства inputView и inputAccessoryView для текстового поля. Создайте сборщик дат и установите его в представлениях ввода двух текстовых полей. Также создайте еще один вид кнопки Done, и это станет их вспомогательным видом. Вам понадобится эта кнопка, чтобы отклонить представление ввода.

Кнопка Done должна быть подключена к функции, которая в основном делает это -

if ( [textField1 isFirstResponder] ) {
    [textField1 resignFirstResponder];
} else if ( [textField2 isFirstResponder] ) {
    [textField2 resignFirstResponder];
}

Другим вариантом будет подкласс UITextField и переопределить inputView и inputAccessoryView. Это путь, когда есть грузы из них.

Пример

@interface CustomKeyboardAppDelegate : NSObject <UIApplicationDelegate> {
...

@property (nonatomic, retain) IBOutlet UIWindow *window;
@property (nonatomic, retain) IBOutlet UITextField *textField;
@property (nonatomic, retain) IBOutlet UIToolbar *accessoryView;
@property (nonatomic, retain) IBOutlet UIDatePicker *customInput;

- (IBAction)dateChanged:(id)sender;
- (IBAction)doneEditing:(id)sender;
@end

В XIB вытащите a UIToolbar и a UIDatePicker, но не присоединяйте его к виду. Подключите розетки соответствующим образом. dateChanged: отвечает на изменения в выборе даты и doneEditing: вызывается при нажатии кнопки Done на панели инструментов. Соедините их тоже. Методы реализуются, как указано ниже.

@implementation CustomKeyboardAppDelegate

@synthesize window=_window;
@synthesize textField = _textField;
@synthesize accessoryView = _accessoryView;
@synthesize customInput = _customInput;

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
    self.textField.inputView = self.customInput;
    self.textField.inputAccessoryView = self.accessoryView;
    ...    
}

...

- (IBAction)dateChanged:(id)sender {
    UIDatePicker *picker = (UIDatePicker *)sender;

    self.textField.text = [NSString stringWithFormat:@"%@", picker.date];
}

- (IBAction)doneEditing:(id)sender {
    [self.textField resignFirstResponder];
}
@end

Последние два метода будут раздуваться, поскольку из этого сборщика зависит больше текстовых полей.

Ответ 2

Очень просто, в ViewController.h поместите UITextFieldDelegate после viewDidLoad.

txtFecha.delegate = self;

datePicker = [[UIDatePicker alloc]init];
[datePicker setDatePickerMode:UIDatePickerModeDate];

self.txtFecha.inputView = datePicker;

Ответ 3

В представленииDidLoad ViewController.m

- (void)viewDidLoad {
    [super viewDidLoad];

    UIDatePicker *datePicker = [[UIDatePicker alloc]init];
    [datePicker setDate:[NSDate date]];
    datePicker.datePickerMode = UIDatePickerModeDate;
    [datePicker addTarget:self action:@selector(dateTextField:) forControlEvents:UIControlEventValueChanged];
    [txtFieldBranchYear setInputView:datePicker];
}

Добавьте один метод в свой ViewController

-(void) dateTextField:(id)sender
{
    UIDatePicker *picker = (UIDatePicker*)txtFieldBranchYear.inputView;
    [picker setMaximumDate:[NSDate date]];
    NSDateFormatter *dateFormat = [[NSDateFormatter alloc] init];
    NSDate *eventDate = picker.date;
    [dateFormat setDateFormat:@"dd/MM/yyyy"];

    NSString *dateString = [dateFormat stringFromDate:eventDate];
    txtFieldBranchYear.text = [NSString stringWithFormat:@"%@",dateString];
}

txtFieldBranchYear - это выход UITextField

Ответ 4

Там действительно полезный класс, который я нашел - это сообщение в блоге: http://www.pietrorea.com/2012/07/how-to-hide-the-cursor-in-a-uitextfield/, но в основном использует представление inputView/inputAccessory, Кикер - это то, что UILabel, по крайней мере, для того, что я делал, было именно тем, что мне нужно.

Ответ 5

открыть подборщик дат при нажатии на textField swift 3.0 добавить UITextFieldDelegate и установить делегат в ViewDidload()   tfDate.delegate = self

//MARK:- TextField Delegate
//MARK:-

func textFieldShouldReturn(_ textField: UITextField) -> Bool {
    textField.resignFirstResponder()
    return true
}

//MARK:- DatePicker
//MARK:-

func textFieldDidBeginEditing(_ textField: UITextField) {
     self.callDatePicker(textField: tfDate)
}
func callDatePicker(textField:UITextField){
    let datePickerView  : UIDatePicker = UIDatePicker()
    datePickerView.datePickerMode = UIDatePickerMode.date
    textField.inputView = datePickerView
    datePickerView.addTarget(self, action: #selector(MyViewController.handleDatePicker), for: .valueChanged)
}

var str:String = ""
var str1:String = ""
var strStartDate:Date!
var strEndDate:Date!

func handleDatePicker(sender: UIDatePicker) {

    let dateFormatter = DateFormatter()
    dateFormatter.dateFormat = "dd-MM-yyyy"
    print("Date :: \(dateFormatter.string(from: sender.date))")
    tfDate.text = dateFormatter.string(from: sender.date)


}