Android Используйте кнопку «Готово» на клавиатуре, чтобы нажать кнопку

131

Хорошо, в моем приложении у меня есть поле для ввода числа пользователем. У меня есть поле для приема только чисел. Когда пользователь щелкает по полю, появляется клавиатура. На клавиатуре (на ICS) есть кнопка готово. Я хотел бы, чтобы кнопка «Готово» на клавиатуре запускала кнопку отправки, которая есть в моем приложении. Мой код выглядит следующим образом.

package com.michaelpeerman.probability;

import android.app.Activity;
import android.app.ProgressDialog;
import android.content.DialogInterface;
import android.content.DialogInterface.OnCancelListener;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import java.util.Random;

public class ProbabilityActivity extends Activity implements OnClickListener {

private Button submit;
ProgressDialog dialog;
int increment;
Thread background;
int heads = 0;
int tails = 0;

public void onCreate(Bundle paramBundle) {
    super.onCreate(paramBundle);
    setContentView(R.layout.main);
    submit = ((Button) findViewById(R.id.submit));
    submit.setOnClickListener(this);
}

public void onClick(View view) {
    increment = 1;
    dialog = new ProgressDialog(this);
    dialog.setCancelable(true);
    dialog.setMessage("Flipping Coin...");
    dialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
    dialog.setProgress(0);
    EditText max = (EditText) findViewById(R.id.number);
    int maximum = Integer.parseInt(max.getText().toString());
    dialog.setMax(maximum);
    dialog.show();
    dialog.setOnCancelListener(new OnCancelListener(){

          public void onCancel(DialogInterface dialog) {

              background.interrupt();
              TextView result = (TextView) findViewById(R.id.result);
                result.setText("heads : " + heads + "\ntails : " + tails);


          }});


    background = new Thread(new Runnable() {
        public void run() {
            heads=0;
            tails=0;
            for (int j = 0; !Thread.interrupted() && j < dialog.getMax(); j++) {
                int i = 1 + new Random().nextInt(2);
                if (i == 1)
                    heads++;
                if (i == 2)
                    tails++;
                progressHandler.sendMessage(progressHandler.obtainMessage());
            }
        }
    });
    background.start();
}

Handler progressHandler = new Handler() {
    public void handleMessage(Message msg) {

        dialog.incrementProgressBy(increment);
        if (dialog.getProgress() == dialog.getMax()) {
            dialog.dismiss();
            TextView result = (TextView) findViewById(R.id.result);
            result.setText("heads : " + heads + "\ntails : " + tails);


        }
    }

};

}
mpeerman
источник
1
проверьте этот stackoverflow.com/questions/5330243/…
Nishant
Это относится к обновлению текстового поля.
mpeerman 07
Я хочу, чтобы он тоже нажимал кнопку, которая у меня уже есть. Я не хочу избавляться от кнопки, потому что некоторые люди могут использовать клавиатуры, на которых нет кнопки «Готово».
mpeerman 07

Ответы:

313

Вы также можете использовать это (устанавливает специальный прослушиватель, который будет вызываться при выполнении действия над EditText), он работает как для DONE, так и для RETURN:

max.setOnEditorActionListener(new OnEditorActionListener() {
        @Override
        public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
            if ((event != null && (event.getKeyCode() == KeyEvent.KEYCODE_ENTER)) || (actionId == EditorInfo.IME_ACTION_DONE)) {
                Log.i(TAG,"Enter pressed");
            }    
            return false;
        }
    });
vladexologija
источник
1
Как я могу настроить его так, чтобы он запускал нажатие, у меня уже отключена кнопка отправки. Public void onClick (Просмотр представления) {
mpeerman
3
Вы можете либо переместить весь этот код в одну функцию, а затем вызвать ее, либо использовать performClick ()
vladexologija 08
6
Это не сработало для меня при нажатии кнопки DONE, KeyEvent всегда был нулевым ... actionId, однако, был установлен на EditorInfo.IME_ACTION_DONE, и я мог использовать это вместо этого. (Это в Android 4.2.2 и в настоящее время даже не соответствует документации по SDK для Android)
Джеймс
28

Вы можете попробовать IME_ACTION_DONE.

Это действие выполняет «готовую» операцию, ничего не вводя, и IME будет закрыт.

 Your_EditTextObj.setOnEditorActionListener(new TextView.OnEditorActionListener() {
            @Override
            public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
                boolean handled = false;
                if (actionId == EditorInfo.IME_ACTION_DONE) {
                  /* Write your logic here that will be executed when user taps next button */


                    handled = true;
                }
                return handled;
            }
        });
IntelliJ Amiya
источник
8
Этот подходит мне идеально. Будьте осторожны с возвратом ИСТИНА. Клавиатура остается отображаемой. Если вы хотите скрыть клавиатуру, верните FALSE.
Matwosk
1
Работает как жемчужина!
sam
16

Попробуй это:

max.setOnKeyListener(new OnKeyListener(){
    @Override
    public boolean onKey(View v, int keyCode, KeyEvent event){
        if(keyCode == event.KEYCODE_ENTER){
            //do what you want
        }
    }
});
Роман Блэк
источник
Когда вы нажимаете любую кнопку, ваше представление генерирует событие onKey, и когда keyCode совпадает с правой кнопкой, он делает то, что вы хотите,
Роман Блэк,
1
кнопка должна иметь фокус
Джеффри Блаттман
8

Попробуйте это для Xamarin.Android (кроссплатформенный)

edittext.EditorAction += (object sender, TextView.EditorActionEventArgs e) {
       if (e.ActionId.Equals (global::Android.Views.InputMethods.ImeAction.Done)) {
           //TODO Something
       }
};
Нитин В. Патил
источник
7

Kotlin Solution

Базовый способ обработки выполненного действия в Kotlin:

edittext.setOnEditorActionListener { _, actionId, _ ->
    if (actionId == EditorInfo.IME_ACTION_DONE) {
        // Call your code here
        true
    }
    false
}

Расширение Kotlin

Используйте это для вызова edittext.onDone {/*action*/}вашего основного кода. Делает это более читабельным и ремонтопригодным

edittext.onDone { submitForm() }

fun EditText.onDone(callback: () -> Unit) {
    setOnEditorActionListener { _, actionId, _ ->
        if (actionId == EditorInfo.IME_ACTION_DONE) {
            callback.invoke()
            true
        }
        false
    }
}

Не забудьте добавить эти параметры в текст редактирования

<EditText ...
    android:imeOptions="actionDone"
    android:inputType="text"/>

Если вам нужна inputType="textMultiLine"поддержка, прочитайте этот пост

Gibolt
источник
4

Я скопировал следующий код из AndroidStudio при создании объекта LoginActivity. Я использую атрибуты ime

В вашем макете

<EditText android:id="@+id/unidades" android:layout_width="match_parent"
                    android:layout_height="wrap_content" android:hint="@string/prompt_unidades"
                    android:inputType="number" android:maxLines="1"
                    android:singleLine="true"
                    android:textAppearance="?android:textAppearanceSmall"
                    android:enabled="true" android:focusable="true"
                    android:gravity="right"
                    android:imeActionId="@+id/cantidad"
                    android:imeActionLabel="@string/add"
                    android:imeOptions="actionUnspecified"/>

В вашей деятельности

editTextUnidades.setOnEditorActionListener(new TextView.OnEditorActionListener() {
        @Override
        public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
            if (actionId == R.id.cantidad || actionId == EditorInfo.IME_NULL) {
                addDetalle(null);
                return true;
            }
            return false;
        }
    });
Хуан Рохас
источник
2

Вы можете реализовать на ключевом слушателе:

public class ProbabilityActivity extends Activity implements OnClickListener, View.OnKeyListener {

В onCreate:

max.setOnKeyListener(this);

...

@Override
public boolean onKey(View v, int keyCode, KeyEvent event){
    if(keyCode == event.KEYCODE_ENTER){
        //call your button method here
    }
    return true;
}
Оловянный человек
источник
1

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

Edittext ed= (EditText) findViewById(R.id.edit_text);

ed.setOnEditorActionListener(new TextView.OnEditorActionListener() {
@Override
public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
    if (actionId == EditorInfo.IME_ACTION_DONE) {
        // Do you job here which you want to done through event
    }
    return false;
}
});
Надим Бхат
источник
1

Котлин и цифровая клавиатура

Если вы используете цифровую клавиатуру, вам нужно отключить клавиатуру, это будет примерно так:

editText.setOnEditorActionListener { v, actionId, event ->
  if (action == EditorInfo.IME_ACTION_DONE || action == EditorInfo.IME_ACTION_NEXT || action == EditorInfo.IME_ACTION_UNSPECIFIED) {
      //hide the keyboard
      val imm = context.getSystemService(Context.INPUT_METHOD_SERVICE) as InputMethodManager
      imm.hideSoftInputFromWindow(windowToken, 0)
      //Take action
      editValue.clearFocus()
      return true
  } else {
      return false
  }
}
Джексон Диаш да Силва
источник
0

Используйте этот класс в своем макете:

public class ActionEditText extends EditText
{
    public ActionEditText(Context context)
    {
        super(context);
    }

    public ActionEditText(Context context, AttributeSet attrs)
    {
        super(context, attrs);
    }

    public ActionEditText(Context context, AttributeSet attrs, int defStyle)
    {
        super(context, attrs, defStyle);
    }

    @Override
    public InputConnection onCreateInputConnection(EditorInfo outAttrs)
    {
        InputConnection conn = super.onCreateInputConnection(outAttrs);
        outAttrs.imeOptions &= ~EditorInfo.IME_FLAG_NO_ENTER_ACTION;
        return conn;
    }

}

В xml:

<com.test.custom.ActionEditText
                android:id="@+id/postED"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:background="@android:color/transparent"
                android:gravity="top|left"
                android:hint="@string/msg_type_message_here"
                android:imeOptions="actionSend"
                android:inputType="textMultiLine"
                android:maxLines="5"
                android:padding="5dip"
                android:scrollbarAlwaysDrawVerticalTrack="true"
                android:textColor="@color/white"
                android:textSize="20sp" />
Йогендра
источник
0
max.setOnKeyListener(new OnKeyListener(){
  @Override
  public boolean onKey(View v, int keyCode, KeyEvent event){
    if(keyCode == event.KEYCODE_ENTER){
        //do what you want
    }
  }
});
RkKhanpuriya
источник
1
Комментирование кода всегда улучшает читаемость ответа ...
jAC
Хотя этот код может ответить на вопрос, предоставление дополнительного контекста относительно того, как и / или почему он решает проблему, улучшит долгосрочную ценность ответа. Помните, что вы отвечаете на вопрос для читателей в будущем, а не только для того, кто спрашивает сейчас! Пожалуйста , измените свой ответ , чтобы добавить объяснение, и дать указание о том , что применять ограничения и допущения. Также не помешает упомянуть, почему этот ответ более уместен, чем другие.
Dev-
0

Ваш последний Edittext .setOnEditorActionListener вызывает этот метод с автоматическим обращением api

Я звонил в LoginActivity в et_password

 et_Pass.setOnEditorActionListener(new TextView.OnEditorActionListener() {
            public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
                if ((event != null && (event.getKeyCode() == KeyEvent.KEYCODE_ENTER)) || (actionId == EditorInfo.IME_ACTION_DONE)) {

                    Log.i(TAG,"Enter pressed");
                    Log.i(Check Internet," and Connect To Server");

                }
                return false;
            }
        });

Работает нормально

Кешав Гера
источник
0

А это версия Котлина:

editText.setOnEditorActionListener { v, actionId, event ->
  if(actionId == EditorInfo.IME_ACTION_DONE){
      //Put your action there
      true
  } else {
      false
  }
}
iluxa.b
источник