回答:
まず、次のようにUITextFieldDelegate
View / ViewControllerのヘッダーファイルのプロトコルに準拠する必要があります。
@interface YourViewController : UIViewController <UITextFieldDelegate>
次に、.mファイルに次のUITextFieldDelegate
プロトコルメソッドを実装する必要があります。
- (BOOL)textFieldShouldReturn:(UITextField *)textField
{
[textField resignFirstResponder];
return YES;
}
[textField resignFirstResponder];
キーボードが閉じていることを確認します。
.mでテキストフィールドを初期化した後、ビュー/ビューコントローラーをUITextFieldのデリゲートに設定していることを確認してください:
yourTextField = [[UITextField alloc] initWithFrame:yourFrame];
//....
//....
//Setting the textField's properties
//....
//The next line is important!!
yourTextField.delegate = self; //self references the viewcontroller or view your textField is on
このトピックの詳細については、キーボードの管理を参照してください。
UITextFieldsにはデリゲートオブジェクト(UITextFieldDelegate)が必要です。デリゲートで次のコードを使用して、キーボードを非表示にします。
- (BOOL)textFieldShouldReturn:(UITextField *)textField {
[textField resignFirstResponder];
}
これまでに動作するはずです...
かなりの時間をかけて何か意味のあるものを探し出した後、これを組み合わせて魅力のように機能しました。
.h
//
// ViewController.h
// demoKeyboardScrolling
//
// Created by Chris Cantley on 11/14/13.
// Copyright (c) 2013 Chris Cantley. All rights reserved.
//
#import <UIKit/UIKit.h>
@interface ViewController : UIViewController <UITextFieldDelegate>
// Connect your text field to this the below property.
@property (weak, nonatomic) IBOutlet UITextField *theTextField;
@end
.m
//
// ViewController.m
// demoKeyboardScrolling
//
// Created by Chris Cantley on 11/14/13.
// Copyright (c) 2013 Chris Cantley. All rights reserved.
//
#import "ViewController.h"
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad
{
[super viewDidLoad];
// _theTextField is the name of the parameter designated in the .h file.
_theTextField.returnKeyType = UIReturnKeyDone;
[_theTextField setDelegate:self];
}
// This part is more dynamic as it closes the keyboard regardless of what text field
// is being used when pressing return.
// You might want to control every single text field separately but that isn't
// what this code do.
-(void)textFieldShouldReturn:(UITextField *)textField
{
[textField resignFirstResponder];
}
@end
お役に立てれば!
事前定義されたクラスの代わりにこれを追加します
class ViewController: UIViewController, UITextFieldDelegate {
キーボードの外側をクリックしたときにキーボードを削除するには
override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?) {
self.view.endEditing(true)
}
Enterキーを押したときにキーボードを削除するには
この行をviewDidLoad()に追加します
inputFieldは、使用されるtextFieldの名前です。
self.inputField.delegate = self
この関数を追加します
func textFieldShouldReturn(textField: UITextField) -> Bool {
textField.resignFirstResponder()
return true
}
スウィフト2:
これがあらゆることをするために行われたことです!
Done
ボタンまたはTouch outSide
でキーボードを閉じ、Next
次の入力に進みます。
StoryBoardでTextFiled Return Key
を最初に変更Next
します。
override func viewDidLoad() {
txtBillIdentifier.delegate = self
txtBillIdentifier.tag = 1
txtPayIdentifier.delegate = self
txtPayIdentifier.tag = 2
let tap = UITapGestureRecognizer(target: self, action: "onTouchGesture")
self.view.addGestureRecognizer(tap)
}
func textFieldShouldReturn(textField: UITextField) -> Bool {
if(textField.returnKeyType == UIReturnKeyType.Default) {
if let next = textField.superview?.viewWithTag(textField.tag+1) as? UITextField {
next.becomeFirstResponder()
return false
}
}
textField.resignFirstResponder()
return false
}
func onTouchGesture(){
self.view.endEditing(true)
}
迅速にあなたはUITextfieldDelegateを委譲する必要があります、その重要なことは忘れないでください、viewControllerのように:
class MyViewController: UITextfieldDelegate{
mytextfield.delegate = self
func textFieldShouldReturn(textField: UITextField) -> Bool {
textField.resignFirstResponder()
}
}
テキストの条件を設定してUIReturnKeyを動的に変更できるこのUITextfieldサブクラスを試すことができます:https :
//github.com/codeinteractiveapps/OBReturnKeyTextField