it-swarm.com.ru

Как скрыть программную клавиатуру от фрагмента?

У меня есть FragmentActivity, использующий ViewPager для обслуживания нескольких фрагментов. Каждый является ListFragment со следующим макетом:

<?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>

При запуске упражнения отображается программная клавиатура. Чтобы исправить это, я сделал следующее внутри фрагмента:

@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);
}

Я сохраняю входящий параметр ViewGroup container из onCreateView как способ доступа к токену окна для основной активности. Это работает без ошибок, но клавиатура не скрывается от вызова hideSoftInputFromWindow в onStart.

Первоначально я попытался использовать раздутый макет вместо container, т.е.

imm.hideSoftInputFromWindow(myInflatedLayout.getWindowToken(), 0);

но это бросило NullPointerException, предположительно, потому что сам фрагмент не является действием и не имеет уникального токена окна?

Есть ли способ скрыть программную клавиатуру из фрагмента или мне следует создать метод в FragmentActivity и вызвать его из фрагмента?

72
WilHall

Пока ваш фрагмент создает представление, вы можете использовать IBinder (маркер окна) из этого представления после он был прикреплен. Например, вы можете переопределить onActivityCreated в вашем фрагменте:

@Override
public void onActivityCreated(Bundle savedInstanceState) {
    super.onActivityCreated(savedInstanceState);
    final InputMethodManager imm = (InputMethodManager) getActivity().getSystemService(Context.INPUT_METHOD_SERVICE);
    imm.hideSoftInputFromWindow(getView().getWindowToken(), 0);
}
154
Ian G. Clifton

Ничто, кроме следующей строки кода, не сработало для меня:

getActivity().getWindow().setSoftInputMode(
            WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN);
71
Shajeel Afzal

Если вы добавите следующий атрибут в определение манифеста своей деятельности, он полностью запретит выдвижение клавиатуры при открытии вашей деятельности. Надеюсь, это поможет:

(Добавьте к определению манифеста вашей деятельности):

Android:windowSoftInputMode="stateHidden"
21
Eric Schlenz
    @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;
    }

Держите экземпляр моего корневого представления в моем классе

View view;

public void onCreate(View rootView) {
    view = rootView;

Используйте вид, чтобы скрыть клавиатуру

 public void removePhoneKeypad() {
    InputMethodManager inputManager = (InputMethodManager) view
            .getContext()
            .getSystemService(Context.INPUT_METHOD_SERVICE);

    IBinder binder = view.getWindowToken();
    inputManager.hideSoftInputFromWindow(binder,
            InputMethodManager.HIDE_NOT_ALWAYS);
}
12
Mobile Applications

Исключение составляет DialogFragment, однако, фокус встроенного Dialog должен быть скрыт, а не только первый EditText во встроенном Dialog

this.getDialog().getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN);
8
macio.Jun

во фрагменте, работающем с этим кодом

    getActivity().getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN);
5
Keshav Gera

это будет работать в моем случае, когда во вкладках я переключаюсь с одного фрагмента на другой

@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);
        }
    }
}
2
Meerz

Используйте этот статический метод из любого места (Activity/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();
    }
}

Если вы хотите использовать для фрагмента, просто позвоните hideKeyboard(((Activity) getActivity())).

0
Nazmus Saadat

В Котлине:

(activity?.getSystemService(Context.INPUT_METHOD_SERVICE) as InputMethodManager).hideSoftInputFromWindow(view?.windowToken,0)
0
timeSmith

Просто добавьте эту строку в ваш код:

getActivity().getWindow().setSoftInputMode(
                WindowManager.LayoutParams.SOFT_INPUT_STATE_ALWAYS_HIDDEN);
0
Digital Buddha

Ничего из этого не работало на API27. Мне пришлось добавить это в контейнер макета, для меня это был 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>
0
hiddeneyes02