回答:
をに設定することでそれをOnKeyListener
行いますEditText
。
これが私のコードのサンプルです。私がいるEditText
という名前のaddCourseText
関数を呼び出しますされ、addCourseFromTextBox
いずれかのキー入力やDパッドがクリックされたとき。
addCourseText = (EditText) findViewById(R.id.clEtAddCourse);
addCourseText.setOnKeyListener(new OnKeyListener()
{
public boolean onKey(View v, int keyCode, KeyEvent event)
{
if (event.getAction() == KeyEvent.ACTION_DOWN)
{
switch (keyCode)
{
case KeyEvent.KEYCODE_DPAD_CENTER:
case KeyEvent.KEYCODE_ENTER:
addCourseFromTextBox();
return true;
default:
break;
}
}
return false;
}
});
android:inputType="text"
では、エディットテキストのxmlを設定して、Enterキーとキャリッジリターンのあるデフォルトのキーボードを表示できます。
<EditText
android:id="@+id/search"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:hint="@string/search_hint"
android:inputType="text"
android:imeOptions="actionSend" />
その後、EditText要素のTextView.OnEditorActionListenerを定義することにより、アクションボタンの押下をリッスンできます。リスナーで、IME_ACTION_SENDなど、EditorInfoクラスで定義された適切なIMEアクションIDに応答します。例えば:
EditText editText = (EditText) findViewById(R.id.search);
editText.setOnEditorActionListener(new OnEditorActionListener() {
@Override
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
boolean handled = false;
if (actionId == EditorInfo.IME_ACTION_SEND) {
sendMessage();
handled = true;
}
return handled;
}
});
ソース:https : //developer.android.com/training/keyboard-input/style.html
次のようにEditTextに属性を追加できます。
android:imeOptions="actionSearch"
android:inputType="text"
同様に設定する必要があります
フォーカスが次の編集可能なフィールド(ある場合)に進むのを避けるために、キーダウンイベントを無視して、キーアップイベントを処理することができます。私はまた、それがわずかに効率的であると仮定して、最初にkeyCodeでフィルタリングすることを好みます。ちなみに、trueを返すと、イベントを処理したことになるので、他のリスナーは処理を行わないことに注意してください。とにかく、これが私のバージョンです。
ETFind.setOnKeyListener(new OnKeyListener()
{
public boolean onKey(View v, int keyCode, KeyEvent event)
{
if (keyCode == KeyEvent.KEYCODE_DPAD_CENTER
|| keyCode == KeyEvent.KEYCODE_ENTER) {
if (event.getAction() == KeyEvent.ACTION_DOWN) {
// do nothing yet
} else if (event.getAction() == KeyEvent.ACTION_UP) {
findForward();
} // is there any other option here?...
// Regardless of what we did above,
// we do not want to propagate the Enter key up
// since it was our task to handle it.
return true;
} else {
// it is not an Enter key - let others handle the event
return false;
}
}
});
これは私のアプリのサンプルです
//searching for the Edit Text in the view
final EditText myEditText =(EditText)view.findViewById(R.id.myEditText);
myEditText.setOnKeyListener(new View.OnKeyListener() {
public boolean onKey(View v, int keyCode, KeyEvent event) {
if (event.getAction() == KeyEvent.ACTION_DOWN)
if ((keyCode == KeyEvent.KEYCODE_DPAD_CENTER) ||
(keyCode == KeyEvent.KEYCODE_ENTER)) {
//do something
//true because you handle the event
return true;
}
return false;
}
});
これを達成するための最も更新された方法は次のとおりです。
これをXMLのEditTextに追加します。
android:imeOptions="actionSearch"
次に、アクティビティ/フラグメントで:
EditText.setOnEditorActionListener { _, actionId, _ ->
if (actionId == EditorInfo.IME_ACTION_SEARCH) {
// Do what you want here
return@setOnEditorActionListener true
}
return@setOnEditorActionListener false
}