Witam mam przeszukiwane EditText
i szukam Button
. Kiedy wpisuję wyszukiwany tekst, chciałbym użyć klawisza ENTER na klawiaturze programowej zamiast wyszukiwania, Button
aby aktywować funkcję wyszukiwania.
Z góry dziękuję za pomoc.
android
keyboard
android-softkeyboard
Peter O.
źródło
źródło
android:inputType="text"
xml dla tekstu edycji, aby pokazać klawisz Enter w porównaniu z domyślną klawiaturą, która ma powrót karetki.<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" />
Następnie można nasłuchiwać naciśnięć przycisku akcji, definiując TextView.OnEditorActionListener dla elementu EditText. W odbiorniku odpowiedz na odpowiedni identyfikator akcji IME zdefiniowany w klasie EditorInfo, na przykład IME_ACTION_SEND. Na przykład:
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; } });
Źródło: https://developer.android.com/training/keyboard-input/style.html
źródło
być może możesz dodać atrybut do swojego EditText w ten sposób:
android:imeOptions="actionSearch"
źródło
android:inputType="text"
takżedodaj atrybut do EditText, taki jak android: imeOptions = "actionSearch"
jest to najlepszy sposób wykonania tej funkcji
a imeOptions mają również inne wartości, takie jak „go” 、 „next” 、 „done” itp.
źródło
Możemy również użyć lambdy Kotlin
editText.setOnKeyListener { _, keyCode, keyEvent -> if (keyEvent.action == KeyEvent.ACTION_DOWN && keyCode == KeyEvent.KEYCODE_ENTER) { Log.d("Android view component", "Enter button was pressed") return@setOnKeyListener true } return@setOnKeyListener false }
źródło
Aby uniknąć przechodzenia fokusu do następnego edytowalnego pola (jeśli takie masz), możesz zignorować zdarzenia naciśnięcia klawisza, ale obsłuż te zdarzenia. Wolę też najpierw filtrować na keyCode, zakładając, że byłoby to nieznacznie bardziej wydajne. Nawiasem mówiąc, pamiętaj, że zwrócenie wartości true oznacza, że obsłużyłeś zdarzenie, więc żaden inny słuchacz tego nie zrobi. Tak czy inaczej, oto moja wersja.
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; } } });
źródło
to jest przykład jednej z moich aplikacji
//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; } });
źródło
Najbardziej aktualnym sposobem osiągnięcia tego jest:
Dodaj to do swojego EditText w XML:
android:imeOptions="actionSearch"
Następnie w swojej aktywności / fragmencie:
EditText.setOnEditorActionListener { _, actionId, _ -> if (actionId == EditorInfo.IME_ACTION_SEARCH) { // Do what you want here return@setOnEditorActionListener true } return@setOnEditorActionListener false }
źródło