Ответ 1
Мы не можем отключить кнопку действия на клавиатуре Android. Вам нужно будет установить проверку пустой строки в прослушивателе действий редактора.
Я создаю опцию поиска в приложении для Android.
После нажатия "Поиск" на экранной клавиатуре запускаются триггеры событий, которые отправляют запрос на сервер.
Я хочу, чтобы отключить кнопку "Поиск" на экранной клавиатуре, когда в ней не был введен текст, соответствующий EditText
.
Я добавил это к EditText
:
android:imeOptions="actionSearch"
Итак, почему клавиатура имеет кнопку "Поиск" вместо стандартного "enter"/ "done". (На всякий случай, когда вам интересно).
Мы не можем отключить кнопку действия на клавиатуре Android. Вам нужно будет установить проверку пустой строки в прослушивателе действий редактора.
setOnEditorActionListener(new TextView.OnEditorActionListener() {
if (txtView.getText().toString().trim().length() == 0) {
Toast.makeText(getApplicationContext(), "Please Enter some text to search",
Toast.Short).show();
return true; // returning true will keep the keyboard on
}
else search();
попробуйте это (возможно, это не тот точный результат, который вам нужен, но может быть самым близким к вам.
1) Удалите андроид: imeOptions = "actionSearch" из xml
2) Создайте пользовательский TextWatcher addTextChangedListener (наблюдатель TextWatcher), который позволяет вам динамически менять клавиатуру, например,
textMessage = (EditText)findViewById(R.id.textMessage);
textMessage.addTextChangedListener(new TextWatcher(){
public void afterTextChanged(Editable s) {
if(firstTime){//a boolean you init to true
firstTime = false;
textMessage.setImeOptions(EditorInfo.IME_ACTION_SEARCH);
}
public void beforeTextChanged(CharSequence s, int start, int count, int after){}
public void onTextChanged(CharSequence s, int start, int before, int count){}
});
вам нужно сделать Custom EditText, Make Extends EditText и @Override Ниже метод в нем.
Вот пример кода.
private ArrayList<Integer> keysToIgnore = new ArrayList<Integer>();
public EditTextCus(Context context) {
super(context);
}
public EditTextCus(Context context, AttributeSet attrs){
super(context, attrs);
}
public EditTextCus(Context context, AttributeSet attrs, int defStyle){
super (context, attrs, defStyle);
}
private Boolean keyInIgnoreList(int keyCode) {
for (Integer i:keysToIgnore){
int key = i.intValue();
if (key == keyCode)
return true;
}
return false;
}
public void addKeyToIgnoreList(int keyCode) {
if (!keyInIgnoreList(keyCode)){
keysToIgnore.add(keyCode);
}
}
public void removeKeyFromIgnoreList(int keyCode) {
if (keyInIgnoreList(keyCode)){
Integer key=new Integer(keyCode);
keysToIgnore.remove(key);
}
}
@Override
public boolean dispatchKeyEventPreIme(KeyEvent event) {
//Log.d("ws", "dispatchKeyEventPreIme(" + event + ")");
// swallow the any key in the ignore list
if (keyInIgnoreList(event.getKeyCode())) {
KeyEvent.DispatcherState state = getKeyDispatcherState();
if (state != null) {
if (event.getAction() == KeyEvent.ACTION_DOWN
/*&& event.getRepeatCount() == 0*/) {
state.startTracking(event, this);
return true;
} else if (event.getAction() == KeyEvent.ACTION_UP
&& !event.isCanceled() && state.isTracking(event)) {
return true;
}
}
}
}
return super.dispatchKeyEventPreIme(event);
}
вы также можете сделать это с помощью ключа поиска:
mCustomEditText.setOnEditorActionListener(new OnEditorActionListener() {
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
if(actionId==EditorInfo.IME_ACTION_SEARCH && event.getAction()==KeyEvent.KEYCODE_SEARCH){
System.out.println("Search pressed.........");
}
return false;
}
});
Внесите OnKeyListener
в Activity
.
добавьте этот keyListener в свой EditText
.
myEditText.setOnKeyListener(this);
переопределить onKey()
в Activity
.
@Override
public boolean onKey(View v, int keyCode, KeyEvent event) {
if(v.getId() == R.id.myEditText)
{
if(KeyEvent.KEYCODE_ENTER == keyCode)
{
if(myEditText.getText().toString().equals("") || myEditText.getText().toString().equals(null))
{
Toast.makeText(KeyboardTestActivity.this, "Event Eaten", Toast.LENGTH_SHORT).show();
Log.e("onKey", "Event Eaten");
return true;
}
}
}
return false;
}
и это будет сделано, если будет отображаться тост, когда ваш EditText
пуст, и вы нажимаете клавишу поиска.
Примечание: onKey()
дважды вызывается дважды для keyDown, а затем для KeyUp. вам придется отфильтровать его с помощью экземпляра KeyEvent, полученного как параметр в методе onKey()
.
Прикрепите OnEditorActionListener к вашему текстовому полю и верните true из его метода onEditorAction, когда actionId равно IME_ACTION_DONE. Это предотвратит скрытие скрывающейся клавиатуры:
EditText txtEdit = (EditText) findViewById(R.id.txtEdit);
txtEdit.setOnEditorActionListener(new OnEditorActionListener() {
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
if (actionId == EditorInfo.IME_ACTION_DONE) {
// your additional processing...
return true;
} else {
return false;
}
}
});
SearchInput.addTextChangedListener(new TextWatcher() {
@Override
public void afterTextChanged(Editable s) {
// TODO Auto-generated method stub
if( SearchInput.getText().toString().length() == 0 )
{
Search.setClickable(false);
}
}
@Override
public void beforeTextChanged(CharSequence s, int start, int count,
int after) {
// TODO Auto-generated method stub
Search.setClickable(false);
}
@Override
public void onTextChanged(CharSequence s, int start, int before,
int count) {
// TODO Auto-generated method stub
Search.setClickable(true);
}
});
или попробуйте это..! для причудливой ошибки dilog
Search.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
if( searchinput.getText().toString().length() == 0 )
{
searchinput.setError( "Enter something Blah Blah..!" );
}
else
{
// Original Functions Goes Here
}
Используйте следующий код в Редактировании текста,
android:imeOptions="flagNoEnterAction"
Я не могу установить flagNoEnterAction = "false"
Но кто-то может вам помочь.