518

EditTextがフォーカスされたときに (デバイスに物理キーボードがない場合) 、ソフト キーボードを自動的に表示したいのですが、次の 2 つの問題があります。

  1. myActivityが表示されている場合、myEditTextはフォーカスされているのにキーボードが表示されていないため、もう一度クリックしてキーボードを表示する必要があります (myActivityが表示されている場合は表示されるはずです)。

  2. そして、キーボードで完了をクリックすると、キーボードは閉じられますが、EditTextフォーカスされたままになり、必要ありません(編集が完了したため)。

再開するには、私の問題は、iPhone に似たものを用意することです。これは、キーボードを私のEditText状態 (フォーカスされている/フォーカスされていない) と同期させ、もちろん、物理キーボードがある場合はソフトキーボードを表示しません。

4

47 に答える 47

717

ソフトキーボードを強制的に表示するには、次を使用できます

EditText yourEditText= (EditText) findViewById(R.id.yourEditText);
yourEditText.requestFocus();
InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
imm.showSoftInput(yourEditText, InputMethodManager.SHOW_IMPLICIT);

のフォーカスを外すには、悲しいことに、フォーカスをつかむEditTextためのダミーが必要です。View


それを閉じるには、使用できます

InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
imm.hideSoftInputFromWindow(yourEditText.getWindowToken(), 0);

これは、ダイアログで使用する場合に機能します

public void showKeyboard(){
    InputMethodManager inputMethodManager = (InputMethodManager) context.getSystemService(Context.INPUT_METHOD_SERVICE);
    inputMethodManager.toggleSoftInput(InputMethodManager.SHOW_FORCED, 0);
}

public void closeKeyboard(){
    InputMethodManager inputMethodManager = (InputMethodManager) context.getSystemService(Context.INPUT_METHOD_SERVICE);
    inputMethodManager.toggleSoftInput(InputMethodManager.HIDE_IMPLICIT_ONLY, 0);
}
于 2011-02-24T15:04:15.063 に答える
253

私も同じ問題を抱えていました。editText VISIBILITYがGONEからVISIBLEに変更された直後に、フォーカスを設定してソフトキーボードを表示する必要がありました。私は次のコードを使用してこれを達成しました:

new Handler().postDelayed(new Runnable() {
            
    public void run() {
//        ((EditText) findViewById(R.id.et_find)).requestFocus();
//              
        EditText yourEditText= (EditText) findViewById(R.id.et_find);
//        InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
//        imm.showSoftInput(yourEditText, InputMethodManager.SHOW_IMPLICIT);

        yourEditText.dispatchTouchEvent(MotionEvent.obtain(SystemClock.uptimeMillis(), SystemClock.uptimeMillis(), MotionEvent.ACTION_DOWN, 0f, 0f, 0));
        yourEditText.dispatchTouchEvent(MotionEvent.obtain(SystemClock.uptimeMillis(), SystemClock.uptimeMillis(), MotionEvent.ACTION_UP, 0f, 0f, 0));                          
    }
}, 200);

100msの遅延で動作しますが、遅延なしまたは1msの遅延で失敗しました。

コードのコメント部分は、一部のデバイスでのみ機能する別のアプローチを示しています。OSバージョン2.2(エミュレーター)、2.2.1(実際のデバイス)、および1.6(エミュレーター)でテストしました。

このアプローチは私に多くの苦痛を救いました。

于 2011-10-16T14:27:57.607 に答える
166

キーボードを表示するには、次を使用します。

getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_VISIBLE);

このメソッドは、InputMethodManager を直接呼び出すよりも信頼性が高くなります。

それを閉じるには、

getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN);
于 2012-05-02T20:15:27.847 に答える
102

他に何も機能しない場合は、強制的に表示します:

editText.requestFocus();
InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
imm.toggleSoftInput(InputMethodManager.SHOW_FORCED, InputMethodManager.HIDE_IMPLICIT_ONLY);

その後、たとえば onPause() で閉じたい場合は、次のように呼び出すことができます。

InputMethodManager imm = (InputMethodManager) getActivity().getSystemService(Context.INPUT_METHOD_SERVICE);
imm.hideSoftInputFromWindow(editText.getWindowToken(), 0);
于 2015-12-02T14:42:29.577 に答える
36

android:windowSoftInputMode="stateAlwaysVisible"->マニフェストファイル内。

edittext.requestFocus(); ->コード内。

これにより、アクティビティが表示されるときに編集テキストがリクエストフォーカスを持つソフトキーボードが開きます。

于 2012-11-27T11:44:36.143 に答える
30

以下のコードを使用して、いくつかの単純なケースで最近運が良かったです。まだ全部のテストは終わっていませんが……。

EditText input = (EditText) findViewById(R.id.Input);
input.requestFocus();    
input.dispatchTouchEvent(MotionEvent.obtain(SystemClock.uptimeMillis(), SystemClock.uptimeMillis(), MotionEvent.ACTION_DOWN, 0f, 0f, 0));
input.dispatchTouchEvent(MotionEvent.obtain(SystemClock.uptimeMillis(), SystemClock.uptimeMillis(), MotionEvent.ACTION_UP, 0f, 0f, 0));

そして、キーボードが表示されます。

于 2011-10-08T20:24:17.040 に答える
16

Kotlin の場合は、次の拡張機能を使用します。

fun EditText.showKeyboard() {
    val imm = context.getSystemService(Context.INPUT_METHOD_SERVICE) as InputMethodManager
    imm.showSoftInput(this, InputMethodManager.SHOW_IMPLICIT)
}

fun EditText.hideKeyboard() {
    val imm = context.getSystemService(Context.INPUT_METHOD_SERVICE) as InputMethodManager
    imm.hideSoftInputFromWindow(this.windowToken, 0)
}
于 2018-10-22T22:36:59.723 に答える
10

showSoftInput私のためにまったく働いていませんでした。

入力モードを設定する必要があると考えました: (ここでは、マニフェストの Activity コンポーネントにあります)

android:windowSoftInputMode="stateVisible" 
于 2014-06-27T07:09:46.847 に答える
9

Kotlinフォーカス時にキーボードを表示するための拡張機能。

これは以前の回答を組み合わせたもので、長すぎるか不完全です。

この拡張機能は、フォーカスを要求した後にソフト キーボードを表示するランナブルをメッセージ キューに投稿します。

fun View.showSoftKeyboard() {
    post {
        if (this.requestFocus()) {
            val imm = context.getSystemService(Context.INPUT_METHOD_SERVICE) as InputMethodManager
            imm?.showSoftInput(this, InputMethodManager.SHOW_IMPLICIT)
        }
    }
}

後で必要に応じて、任意のビューから呼び出します。

editText.showSoftKeyboard()
于 2019-09-30T22:04:09.150 に答える
6

信じられないかもしれませんが、アクティビティアニメーションでソフトキーボードが無効になることがわかったときに、ソフトキーボードの問題は解決しました。あなたがインテントを呼び出すとき

i.setFlags(Intent.FLAG_ACTIVITY_NO_ANIMATION);

overridePendingTransition(0, 0);

ソフトキーボードを非表示にすることができ、表示する方法がありません。

于 2012-01-24T18:51:59.470 に答える
6

ここですべてを組み合わせましたが、私にとってはうまくいきます:

public static void showKeyboardWithFocus(View v, Activity a) {
    try {
        v.requestFocus();
        InputMethodManager imm = (InputMethodManager) a.getSystemService(Context.INPUT_METHOD_SERVICE);
        imm.showSoftInput(v, InputMethodManager.SHOW_IMPLICIT);
        a.getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_VISIBLE);
    } catch (Exception e) {
        e.printStackTrace();
    }
}
于 2016-10-03T14:36:42.287 に答える
6

私はさまざまな状況で同じ問題を抱えていました。私が見つけた解決策は、いくつかの状況では機能しますが、他の状況では機能しないため、私が見つけたほとんどの状況で機能する組み合わせソリューションを次に示します。

public static void showVirtualKeyboard(Context context, final View view) {
    if (context != null) {
        final InputMethodManager imm =  (InputMethodManager) context.getSystemService(Context.INPUT_METHOD_SERVICE);
        view.clearFocus();

        if(view.isShown()) {
            imm.showSoftInput(view, 0);
            view.requestFocus();
        } else {
            view.addOnAttachStateChangeListener(new View.OnAttachStateChangeListener() {
                @Override
                public void onViewAttachedToWindow(View v) {
                    view.post(new Runnable() {
                        @Override
                        public void run() {
                            view.requestFocus();
                            imm.showSoftInput(view, 0);
                        }
                    });

                    view.removeOnAttachStateChangeListener(this);
                }

                @Override
                public void onViewDetachedFromWindow(View v) {
                    view.removeOnAttachStateChangeListener(this);
                }
            });
        }
    }
}
于 2013-09-25T12:29:16.180 に答える
4
final InputMethodManager keyboard = (InputMethodManager) ctx.getSystemService(Context.INPUT_METHOD_SERVICE);
keyboard.toggleSoftInput(InputMethodManager.SHOW_FORCED,0);
于 2015-01-16T23:24:44.067 に答える
1

そのため、swithview で使用する raukodraug に同意します。次のようにフォーカスをリクエスト/クリアする必要があります。

    final ViewSwitcher viewSwitcher = (ViewSwitcher) findViewById(R.id.viewSwitcher);
    final View btn = viewSwitcher.findViewById(R.id.address_btn);
    final View title = viewSwitcher.findViewById(R.id.address_value);

    title.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            viewSwitcher.showPrevious();
            btn.requestFocus();
            InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
            imm.showSoftInput(btn, InputMethodManager.SHOW_IMPLICIT);
        }
    });

    // EditText affiche le titre evenement click
    btn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            btn.clearFocus();
            viewSwitcher.showNext();
            InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
            imm.hideSoftInputFromWindow(btn.getWindowToken(), 0);
            // Enregistre l'adresse.
            addAddress(view);
        }
    });

よろしく。

于 2016-04-15T17:14:12.530 に答える
1

私のアプリの1つでは、アクティビティに入るとソフトキーボードが自動的に表示されていたので、奇妙な動作を発見しました(onCreateにeditText.requestFocus()があります)。

さらに掘り下げると、これはレイアウトの周りに ScrollView があるためであることがわかりました。ScrollView を削除すると、動作は元の問題ステートメントで説明したとおりになります。すでにフォーカスされている editText をクリックした場合にのみ、ソフト キーボードが表示されます。

うまくいかない場合は、ScrollView を入れてみてください。とにかく無害です。

于 2014-09-10T07:16:08.483 に答える
1

view animations を使用して同様の問題が発生しました。そのため、アニメーション リスナーを配置して、アニメーションが終了するのを待ってから、表示されている編集テキストでキーボード アクセスを要求しようとしました。

    bottomUp.setAnimationListener(new Animation.AnimationListener() {
        @Override
        public void onAnimationStart(Animation animation) {
        }

        @Override
        public void onAnimationEnd(Animation animation) {
            if (textToFocus != null) {
                // Position cursor at the end of the text
                textToFocus.setSelection(textToFocus.getText().length());
                // Show keyboard
                InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
                imm.showSoftInput(textToFocus, InputMethodManager.SHOW_IMPLICIT);
            }
        }

        @Override
        public void onAnimationRepeat(Animation animation) {
        }
    });
于 2015-03-02T17:56:21.510 に答える
1

また、フォーカスを受け取ったときにソフト キーボードを開くことを認識している EditText のカスタム拡張機能を作成することもできます。それが私がやったことです。これが私のために働いたものです:

public class WellBehavedEditText extends EditText {
    private InputMethodManager inputMethodManager;
    private boolean showKeyboard = false;

    public WellBehavedEditText(Context context) {
        super(context);
        this.initializeWellBehavedEditText(context);
    }

    public WellBehavedEditText(Context context, AttributeSet attributes) {
        super(context, attributes);
        this.initializeWellBehavedEditText(context);
    }

    public WellBehavedEditText(Context context, AttributeSet attributes, int defStyleAttr) {
        super(context, attributes, defStyleAttr);
        this.initializeWellBehavedEditText(context);
    }

    public WellBehavedEditText(Context context, AttributeSet attributes, int defStyleAttr, int defStyleRes) {
        super(context, attributes, defStyleAttr, defStyleRes);
        this.initializeWellBehavedEditText(context);
    }

    private void initializeWellBehavedEditText(Context context) {
        this.inputMethodManager = (InputMethodManager)context.getSystemService(Context.INPUT_METHOD_SERVICE);

        final WellBehavedEditText editText = this;
        this.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
            @Override
            public void onGlobalLayout() {
                if(showKeyboard) {
                    showKeyboard = !(inputMethodManager.showSoftInput(editText, InputMethodManager.SHOW_FORCED));
                }
            }
        });
    }

    @Override
    protected void onFocusChanged(boolean focused, int direction, Rect previouslyFocusedRect) {
        if(!focused) this.showKeyboard = false;
        super.onFocusChanged(focused, direction, previouslyFocusedRect);
    }

    @Override
    public boolean requestFocus(int direction, Rect previouslyFocusedRect) {
        boolean result = super.requestFocus(direction, previouslyFocusedRect);
        this.showKeyboard = true;
        final WellBehavedEditText self = this;
        this.post(new Runnable() {
            @Override
            public void run() {
                showKeyboard = !(inputMethodManager.showSoftInput(self, InputMethodManager.SHOW_FORCED));
            }
        });
        return result;
    }
}
于 2017-08-03T04:07:02.510 に答える
1

これはワイルドですが、実際には機能します

fun showKeyboard(view: View) {
    try {
        InputMethodManager::class.java.getMethod(
                "showSoftInputUnchecked",
                Int::class.javaPrimitiveType,
                ResultReceiver::class.java
        ).apply {
            isAccessible = true
            invoke(view.context.inputMethodManager, 0, null)
        }
    }
    catch (e: Exception) {
       e.printStackTrace()
    }
}
于 2018-08-24T14:34:19.693 に答える
1

ここで個々の回答をすべて試した後、キーボードが表示されません..これを解決するのに何時間も費やしたので、将来誰かがそれを無駄にしないことを願っています..

私の場合、問題は at でのプログラミングの問題ではありませんでした。ハードウェア キーボードを備えた電話を搭載したエミュレーターでテストしていたので、デフォルトではソフトウェア キーボードが表示されません。これを解決するには、次のようにする必要があります。ハードウェア キーボードをオフにするか、ソフト キーボードを有効にして、エミュレータで show soft input が有効になっていることを確認します。

API-15 & 16 でのみこれに直面しました。これを行う方法のスクリーンショットを次に示します

Geny Motion エミュレータの場合:

ここに画像の説明を入力 ここに画像の説明を入力

Android Studio エミュレーターの場合:

ここに画像の説明を入力

于 2020-08-06T21:27:43.120 に答える
1

この拡張機能を使って、Kotlin でキーボードを表示します。

fun EditText.requestFocusWithKeyboard() {
    post {
        dispatchTouchEvent(MotionEvent.obtain(SystemClock.uptimeMillis(), SystemClock.uptimeMillis(), MotionEvent.ACTION_DOWN, 0f, 0f, 0))
        dispatchTouchEvent(MotionEvent.obtain(SystemClock.uptimeMillis(), SystemClock.uptimeMillis(), MotionEvent.ACTION_UP, 0f, 0f, 0))
        setSelection(length())
    }
}

次のように呼び出すことができます。

editText.requestFocusWithKeyboard()

非常に便利であることに加えて:

  1. InputMethodManager.SHOW_FORCED で戻る場合など、考えられるすべてのケースで閉じることを心配する必要はありません。
  2. フォーカスを要求するだけでなく、選択も設定します (テキストの末尾へのカーソル)。
于 2021-11-28T07:18:22.403 に答える
0

Xamarin を使用すると、これは Fragment 内で機能します。

using Android.Views.InputMethods;
using Android.Content;

...

if ( _txtSearch.RequestFocus() ) {
  var inputManager = (InputMethodManager) Activity.GetSystemService( Context.InputMethodService );
  inputManager.ShowSoftInput( _txtSearch, ShowFlags.Implicit );
}
于 2017-01-13T11:54:04.993 に答える