Mam do FragmentActivity
podania ViewPager
kilku fragmentów. Każdy ma ListFragment
następujący układ:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<LinearLayout
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="8dp">
<ListView android:id="@id/android:list"
android:layout_width="fill_parent"
android:layout_height="fill_parent" />
<EditText android:id="@+id/entertext"
android:layout_width="fill_parent"
android:layout_height="wrap_content" />
</LinearLayout>
</LinearLayout>
Podczas rozpoczynania działania wyświetlana jest klawiatura programowa. Aby temu zaradzić, wewnątrz fragmentu wykonałem następujące czynności:
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
//Save the container view so we can access the window token
viewContainer = container;
//get the input method manager service
imm = (InputMethodManager)getActivity().getSystemService(Context.INPUT_METHOD_SERVICE);
. . .
}
@Override
public void onStart() {
super.onStart();
//Hide the soft keyboard
imm.hideSoftInputFromWindow(viewContainer.getWindowToken(), 0);
}
Zapisuję ViewGroup container
parametr przychodzący z onCreateView
jako sposób na dostęp do tokena okna dla głównej czynności. To działa bez błędu, ale klawiatura nie zostanie ukryte przed wywołaniem hideSoftInputFromWindow
w onStart
.
Pierwotnie próbowałem użyć zawyżonego układu zamiast container
, tj .:
imm.hideSoftInputFromWindow(myInflatedLayout.getWindowToken(), 0);
ale to wyrzuciło NullPointerException
, prawdopodobnie dlatego, że sam fragment nie jest działaniem i nie ma unikalnego tokenu okna?
Czy istnieje sposób na ukrycie klawiatury programowej przed fragmentem, czy też powinienem utworzyć metodę w FragmentActivity
i wywołać ją z wnętrza fragmentu?
Nie działało dla mnie nic poza następującym wierszem kodu:
źródło
SOFT_INPUT_STATE_HIDDEN
też działało dla mnie, chociaż nie wiem, jaka jest różnica między tym a `SOFT_INPUT_STATE_ALWAYS_HIDDEN '.Jeśli dodasz następujący atrybut do definicji manifestu działania, całkowicie wyeliminuje on wyskakiwanie klawiatury po otwarciu działania. Mam nadzieję, że to pomoże:
(Dodaj do definicji manifestu swojej aktywności):
android:windowSoftInputMode="stateHidden"
źródło
@Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View rootView = inflater.inflate(R.layout.fragment_my, container, false); someClass.onCreate(rootView); return rootView; }
Zachowaj instancję mojego widoku głównego w mojej klasie
View view; public void onCreate(View rootView) { view = rootView;
Użyj widoku, aby ukryć klawiaturę
public void removePhoneKeypad() { InputMethodManager inputManager = (InputMethodManager) view .getContext() .getSystemService(Context.INPUT_METHOD_SERVICE); IBinder binder = view.getWindowToken(); inputManager.hideSoftInputFromWindow(binder, InputMethodManager.HIDE_NOT_ALWAYS); }
źródło
Wyjątkiem jest
DialogFragment
jednak fakt, że fokus elementu osadzonegoDialog
musi być ukryty, a nie tylko pierwszyEditText
element osadzonyDialog
this.getDialog().getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN);
źródło
override fun onActivityCreated(savedInstanceState: Bundle?) { super.onActivityCreated(savedInstanceState) dialog?.window?.setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN)}
Ten kod działa dla fragmentów:
źródło
Użyj tej statycznej metody z dowolnego miejsca (aktywność / fragment).
public static void hideKeyboard(Activity activity) { try{ InputMethodManager inputManager = (InputMethodManager) activity .getSystemService(Context.INPUT_METHOD_SERVICE); View currentFocusedView = activity.getCurrentFocus(); if (currentFocusedView != null) { inputManager.hideSoftInputFromWindow(currentFocusedView.getWindowToken(), InputMethodManager.HIDE_NOT_ALWAYS); } }catch (Exception e){ e.printStackTrace(); } }
Jeśli chcesz użyć fragmentu, po prostu zadzwoń
hideKeyboard(((Activity) getActivity()))
.źródło
tak będzie w moim przypadku, gdy w zakładkach przełączam się z jednego fragmentu na inny
@Override public void setUserVisibleHint(boolean isVisibleToUser) { super.setUserVisibleHint(isVisibleToUser); if (isVisibleToUser) { try { InputMethodManager mImm = (InputMethodManager) getActivity().getSystemService(Context.INPUT_METHOD_SERVICE); mImm.hideSoftInputFromWindow(getView().getWindowToken(), 0); mImm.hideSoftInputFromWindow(getActivity().getCurrentFocus().getWindowToken(), 0); } catch (Exception e) { Log.e(TAG, "setUserVisibleHint: ", e); } } }
źródło
Nic z tego nie działało na API27. Musiałem dodać to w kontenerze układu, dla mnie był to ConstraintLayout:
<android.support.constraint.ConstraintLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:focusable="true" android:focusableInTouchMode="true" android:focusedByDefault="true"> //Your layout </android.support.constraint.ConstraintLayout>
źródło
To zadziałało dla mnie w klasie Kotlin
fun hideKeyboard(activity: Activity) { try { val inputManager = activity .getSystemService(Context.INPUT_METHOD_SERVICE) as InputMethodManager val currentFocusedView = activity.currentFocus if (currentFocusedView != null) { inputManager.hideSoftInputFromWindow(currentFocusedView.windowToken, InputMethodManager.HIDE_NOT_ALWAYS) } } catch (e: Exception) { e.printStackTrace() } }
źródło
Użyj tego kodu w dowolnym odbiorniku przycisków fragmentów:
InputMethodManager imm = (InputMethodManager) getActivity().getSystemService(getActivity().INPUT_METHOD_SERVICE); imm.hideSoftInputFromWindow(getActivity().getCurrentFocus().getWindowToken(), 0);
źródło
getActivity().getCurrentFocus().getWindowToken()
nie jest null, w przeciwnym razie spowoduje to błąd, jeśli nie ma skupionego tekstu editText. Zobacz moją odpowiedź poniżejKod Kotlin
val imm = requireActivity().getSystemService(Context.INPUT_METHOD_SERVICE) as InputMethodManager imm.hideSoftInputFromWindow(requireActivity().currentFocus?.windowToken, 0)
źródło
Po prostu dodaj tę linię w swoim kodzie:
źródło
W Kotlinie:
(activity?.getSystemService(Context.INPUT_METHOD_SERVICE) as InputMethodManager).hideSoftInputFromWindow(view?.windowToken,0)
źródło
Użyj tego:
Button loginBtn = view.findViewById(R.id.loginBtn); loginBtn.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { InputMethodManager imm = (InputMethodManager) getActivity().getSystemService(getActivity().INPUT_METHOD_SERVICE); imm.hideSoftInputFromWindow(v.getWindowToken(), 0); } });
źródło