web-dev-qa-db-ja.com

下部のナビゲーションバーがキーボードとともに上に移動します

フラグメントでスクロールビューを使用していますが、キーボードが表示されているときに画面が上にスクロールしません。シナリオは次のとおりです。下部のナビゲーションバーと、アクティビティのコンテナとして機能するフレームレイアウトを持つmainActivityがあります。コードは次のとおりです。

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:tools="http://schemas.Android.com/tools"
    Android:layout_width="match_parent"
    Android:layout_height="match_parent"
    xmlns:app="http://schemas.Android.com/apk/res-auto"
    tools:context=".MainActivity"
    >
    <FrameLayout
        Android:id="@+id/fragment_container"
        Android:layout_width="match_parent"
        Android:layout_height="wrap_content"
        Android:layout_alignParentTop="true" />

    <Android.support.design.widget.BottomNavigationView
        Android:background="@color/clear_white"
        Android:id="@+id/navigation"
        Android:layout_width="match_parent"
        Android:layout_height="56dp"
        Android:layout_alignParentBottom="true"
        app:itemIconTint="@color/blue_navbar_icon"
        app:itemTextColor="@color/blue_navbar_icon"
        app:menu="@menu/navigation" />
</RelativeLayout>

フラグメント画面には、いくつかの入力フィールドと、制約付きレイアウトでラップされたボタンがあり、次に制約付きレイアウトがscrollViewでラップされるため、キーボードがアクティブなときに上にスクロールできます。フラグメントxmlファイルのコードは次のとおりです。

<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:Android="http://schemas.Android.com/apk/res/Android"
    Android:layout_width="match_parent"
    Android:layout_height="match_parent"
    xmlns:app="http://schemas.Android.com/apk/res-auto">
    <Android.support.constraint.ConstraintLayout
        Android:layout_width="match_parent"
        Android:layout_height="match_parent"

        >
        <include
            Android:id="@+id/app_bar_new"
            layout="@layout/app_bar_new"
            app:layout_constraintBottom_toTopOf="@+id/btn_get_location"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent" />

        <Button
            Android:id="@+id/btn_get_location"
            style="@style/btn_style"
            Android:layout_width="match_parent"
            Android:layout_height="43dp"
            Android:layout_marginBottom="8dp"
            Android:layout_marginEnd="11dp"
            Android:layout_marginLeft="11dp"
            Android:layout_marginRight="11dp"
            Android:layout_marginStart="11dp"
            Android:layout_marginTop="12dp"
            Android:text="@string/get_location_btn_str"
            app:layout_constraintBottom_toTopOf="@+id/tv_long"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintHorizontal_bias="0.0"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/app_bar_new" />

        <EditText
            Android:id="@+id/et_name_of_attr"
            style="@style/input_field_style"
            Android:layout_width="0dp"
            Android:layout_height="47dp"
            Android:layout_marginBottom="7dp"
            Android:layout_marginEnd="11dp"
            Android:layout_marginLeft="11dp"
            Android:layout_marginRight="11dp"
            Android:layout_marginStart="11dp"
            Android:layout_marginTop="7dp"
            Android:background="@drawable/input_field_design"
            Android:ems="10"
            Android:hint="@string/loc_name"
            Android:inputType="textPersonName"
            app:layout_constraintBottom_toTopOf="@+id/et_description"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintHorizontal_bias="0.0"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/tv_long" />

        <Button
            Android:id="@+id/btn_save"
            style="@style/btn_style"
            Android:layout_width="90dp"
            Android:layout_height="42dp"
            Android:layout_marginBottom="25dp"
            Android:layout_marginEnd="8dp"
            Android:layout_marginLeft="8dp"
            Android:layout_marginRight="8dp"
            Android:layout_marginStart="8dp"
            Android:layout_marginTop="7dp"
            Android:padding="10dp"
            Android:text="@string/btn_save"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/rg_access" />

        <EditText
            Android:id="@+id/et_cam_img_title"
            style="@style/input_field_style"
            Android:layout_width="0dp"
            Android:layout_height="47dp"
            Android:layout_marginBottom="7dp"
            Android:layout_marginEnd="11dp"
            Android:layout_marginLeft="11dp"
            Android:layout_marginRight="11dp"
            Android:layout_marginStart="11dp"
            Android:layout_marginTop="7dp"
            Android:ems="10"
            Android:hint="@string/loc_img_title"
            Android:inputType="textMultiLine"
            app:layout_constraintBottom_toTopOf="@+id/additional_imgs"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintHorizontal_bias="0.0"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/et_description" />

        <EditText
            Android:id="@+id/et_description"
            style="@style/input_field_style"
            Android:layout_width="0dp"
            Android:layout_height="47dp"
            Android:layout_marginBottom="7dp"
            Android:layout_marginEnd="11dp"
            Android:layout_marginLeft="11dp"
            Android:layout_marginRight="11dp"
            Android:layout_marginStart="11dp"
            Android:layout_marginTop="7dp"
            Android:ems="10"
            Android:hint="@string/loc_desc"
            Android:inputType="textMultiLine"
            app:layout_constraintBottom_toTopOf="@+id/et_cam_img_title"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintHorizontal_bias="1.0"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/et_name_of_attr" />

        <TextView
            Android:id="@+id/tv_long"
            Android:layout_width="170dp"
            Android:layout_height="35dp"
            Android:layout_marginBottom="8dp"
            Android:layout_marginTop="8dp"
            Android:background="@drawable/long_lat_bg"
            Android:ems="10"
            Android:inputType="numberDecimal"
            Android:padding="5dp"
            Android:text="@string/loc_long"
            app:layout_constraintBottom_toTopOf="@+id/location_name_text"
            app:layout_constraintEnd_toStartOf="@+id/tv_lat"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/btn_get_location" />

        <TextView
            Android:id="@+id/tv_lat"
            Android:layout_width="170dp"
            Android:layout_height="35dp"
            Android:layout_marginBottom="8dp"
            Android:layout_marginTop="8dp"
            Android:background="@drawable/long_lat_bg"
            Android:ems="10"
            Android:inputType="textPersonName"
            Android:padding="5dp"
            Android:text="@string/loc_lat"
            app:layout_constraintBottom_toTopOf="@+id/location_name_text"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toEndOf="@+id/tv_long"
            app:layout_constraintTop_toBottomOf="@+id/btn_get_location" />

        <RelativeLayout
            Android:id="@+id/additional_imgs"
            style="@style/input_field_style"
            Android:layout_width="0dp"
            Android:layout_height="47dp"
            Android:layout_marginBottom="7dp"
            Android:layout_marginEnd="11dp"
            Android:layout_marginLeft="11dp"
            Android:layout_marginRight="11dp"
            Android:layout_marginStart="11dp"
            Android:layout_marginTop="7dp"
            Android:orientation="horizontal"
            app:layout_constraintBottom_toTopOf="@+id/relativeLayout2"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/et_cam_img_title">

            <TextView
                Android:id="@+id/textView3"
                Android:layout_width="wrap_content"
                Android:layout_height="wrap_content"
                Android:layout_alignParentStart="true"
                Android:layout_centerVertical="true"
                Android:layout_marginStart="13dp"
                Android:layout_weight="1"
                Android:text="@string/loc_additional_imgs"
                Android:layout_alignParentLeft="true"
                Android:layout_marginLeft="13dp" />

            <ImageView
                Android:id="@+id/btn_add_imgs"
                Android:layout_width="wrap_content"
                Android:layout_height="match_parent"
                Android:layout_alignParentEnd="true"
                Android:layout_alignParentRight="true"
                Android:src="@drawable/ic_action_add_blue" />

        </RelativeLayout>

        <RelativeLayout
            Android:id="@+id/relativeLayout2"
            style="@style/input_field_style"
            Android:layout_width="0dp"
            Android:layout_height="47dp"
            Android:layout_marginBottom="7dp"
            Android:layout_marginEnd="11dp"
            Android:layout_marginLeft="11dp"
            Android:layout_marginRight="11dp"
            Android:layout_marginStart="11dp"
            Android:layout_marginTop="7dp"
            Android:orientation="horizontal"
            app:layout_constraintBottom_toTopOf="@+id/rg_access"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/additional_imgs">


            <ImageView
                Android:id="@+id/icon_drop_down_img"
                Android:layout_width="wrap_content"
                Android:layout_height="match_parent"
                Android:layout_alignParentEnd="true"
                Android:layout_alignParentRight="true"
                Android:src="@drawable/ic_drop_down" />

            <Spinner
                Android:id="@+id/spin_classification"
                Android:layout_width="match_parent"
                Android:layout_height="match_parent"
                Android:background="@Android:color/transparent" />
        </RelativeLayout>


        <TextView
            Android:textSize="16sp"
            Android:textColor="@color/blue"
            Android:id="@+id/tv_desc_access"
            Android:layout_width="wrap_content"
            Android:layout_height="32dp"
            Android:layout_alignParentLeft="true"
            Android:layout_alignParentStart="true"
            Android:layout_centerVertical="true"
            Android:layout_marginBottom="7dp"
            Android:layout_marginEnd="8dp"
            Android:layout_marginLeft="11dp"
            Android:layout_marginRight="8dp"
            Android:layout_marginStart="11dp"
            Android:layout_marginTop="7dp"
            Android:text="@string/loc_acess"
            app:layout_constraintBottom_toTopOf="@+id/btn_save"
            app:layout_constraintEnd_toStartOf="@+id/rg_access"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/relativeLayout2" />

        <RadioGroup
            Android:id="@+id/rg_access"
            Android:layout_width="wrap_content"
            Android:layout_height="wrap_content"
            Android:layout_marginBottom="7dp"
            Android:layout_marginEnd="21dp"
            Android:layout_marginRight="21dp"
            Android:layout_marginTop="7dp"
            Android:gravity="center"
            Android:orientation="horizontal"
            app:layout_constraintBottom_toTopOf="@+id/btn_save"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/relativeLayout2">

            <RadioButton
                Android:id="@+id/rb_car"
                Android:background="@drawable/rb_car"
                Android:button="@Android:color/transparent"
                Android:layout_width="wrap_content"
                Android:layout_height="wrap_content"
                Android:layout_marginLeft="10dp"
                Android:layout_marginRight="10dp" />

            <RadioButton
                Android:id="@+id/rb_jeep"
                Android:background="@drawable/rb_jeep"
                Android:button="@Android:color/transparent"
                Android:layout_width="wrap_content"
                Android:layout_height="wrap_content"
                Android:layout_marginLeft="10dp"
                Android:layout_marginRight="10dp" />

            <RadioButton
                Android:id="@+id/rb_track"
                Android:background="@drawable/rb_hike"
                Android:button="@Android:color/transparent"
                Android:layout_width="wrap_content"
                Android:layout_height="wrap_content"
                Android:layout_marginLeft="20dp"
                Android:layout_marginRight="10dp"/>
        </RadioGroup>
    </Android.support.constraint.ConstraintLayout>
</ScrollView>

また、ここに私のマニフェストファイルがあります:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:Android="http://schemas.Android.com/apk/res/Android"
    package="com.example.eapple.tripdatacollection">

    <uses-permission Android:name="Android.permission.INTERNET" />
    <uses-permission Android:name="Android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission Android:name="Android.permission.ACCESS_COARSE_LOCATION" />

    <application
        Android:allowBackup="true"
        Android:icon="@mipmap/ic_launcher"
        Android:label="@string/app_name"
        Android:roundIcon="@mipmap/ic_launcher_round"
        Android:supportsRtl="true"
        Android:theme="@style/AppTheme">
        <activity Android:name=".Main2Activity"
            Android:windowSoftInputMode="adjustResize"
            >
            <intent-filter>
                <action Android:name="Android.intent.action.MAIN" />

                <category Android:name="Android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity Android:name=".ViewSavedLocations" />
        <activity Android:name=".fireBaseUpdates" />
        <activity Android:name=".SignInActivity" />
        <activity Android:name=".ForgotPasswordActivity" />
        <activity Android:name=".UploadDataActivity" />
        <activity
            Android:name=".MainActivity"
            Android:label="@string/title_activity_main2" />
    </application>
</manifest>

しかし、意図したとおりには機能しません。 1)下のナビゲーションバーは、ここに示すようにキーボードとともに上がります: スクリーンショット

キーボードがアクティブなときに下部のナビゲーションバーを下部に残すか、非表示にします。

5
Haroon khan

これが解決策であり、このAPIを使用して問題を解決した方法です: https://github.com/yshrsmz/KeyboardVisibilityEvent

手順:

1)androidManifestファイル内:

Add the following tag: Android:windowSoftInputMode="adjustResize"

私がここでしたように:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:Android="http://schemas.Android.com/apk/res/Android"
    package="com.example.eapple.tripdatacollection">

    <uses-permission Android:name="Android.permission.INTERNET" />
    <uses-permission Android:name="Android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission Android:name="Android.permission.ACCESS_COARSE_LOCATION" />

    <application
        Android:allowBackup="true"
        Android:icon="@mipmap/ic_launcher"
        Android:label="@string/app_name"
        Android:roundIcon="@mipmap/ic_launcher_round"
        Android:supportsRtl="true"
        Android:theme="@style/AppTheme">
        <activity Android:name=".Main2Activity"
            Android:windowSoftInputMode="adjustResize"
            >
            <intent-filter>
                <action Android:name="Android.intent.action.MAIN" />

                <category Android:name="Android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity Android:name=".ViewSavedLocations" />
        <activity Android:name=".fireBaseUpdates" />
        <activity Android:name=".SignInActivity" />
        <activity Android:name=".ForgotPasswordActivity" />
        <activity Android:name=".UploadDataActivity" />
        <activity
            Android:name=".MainActivity"
            Android:label="@string/title_activity_main2" />

    </application>

</manifest>

2)build.gradeファイル(アプリ)に次の依存関係を追加します

依存関係{実装 'net.yslibrary.keyboardvisibilityevent:keyboardvisibilityevent:2.1.0'}

3)アクティビティonCreateメソッドに次のコードを追加します。

KeyboardVisibilityEvent.setEventListener(
        getActivity(),
        new KeyboardVisibilityEventListener() {
            @Override
            public void onVisibilityChanged(boolean isOpen) {
                // some code depending on keyboard visiblity status
            }
        });

これが私のJavaファイルです:

package com.example.eapple.tripdatacollection;

import Android.annotation.SuppressLint;
import Android.app.Fragment;
import Android.app.FragmentTransaction;
import Android.content.Context;
import Android.content.res.Resources;
import Android.os.Bundle;
import Android.support.annotation.NonNull;
import Android.support.design.widget.BottomNavigationView;
import Android.support.v7.app.AppCompatActivity;
import Android.util.DisplayMetrics;
import Android.util.Log;
import Android.util.TypedValue;
import Android.view.MenuItem;
import Android.view.View;
import Android.view.ViewGroup;
import Android.view.ViewTreeObserver;

import net.yslibrary.Android.keyboardvisibilityevent.KeyboardVisibilityEvent;
import net.yslibrary.Android.keyboardvisibilityevent.KeyboardVisibilityEventListener;

public class Main2Activity extends AppCompatActivity {

    private static AddLocationFragment addLocationFragment;
    private static ProfileFragment profileFragment;
    private static SavedLocationsFragment savedLocationsFragment;
    private View rootView;
    private final String TAG = "Main2Activity";

    private BottomNavigationView.OnNavigationItemSelectedListener mOnNavigationItemSelectedListener
            = new BottomNavigationView.OnNavigationItemSelectedListener() {

        @Override
        public boolean onNavigationItemSelected(@NonNull MenuItem item) {
            switch (item.getItemId()) {
                case R.id.navigation_profile:
                    loadFragment(profileFragment);
                    return true;
                case R.id.navigation_saved_locations:
                    loadFragment(savedLocationsFragment);
                    return true;
                case R.id.navigation_add_location:
                    loadFragment(addLocationFragment);
                    return true;
            }
            return false;
        }
    };

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);

        addLocationFragment = new AddLocationFragment();
        savedLocationsFragment = new SavedLocationsFragment();
        profileFragment = new ProfileFragment();

        rootView = findViewById(R.id.root_view);

        final BottomNavigationView navigation = findViewById(R.id.navBar);
        navigation.setOnNavigationItemSelectedListener(mOnNavigationItemSelectedListener);
        navigation.setSelectedItemId(R.id.navigation_add_location);
        loadFragment(addLocationFragment);

        KeyboardVisibilityEvent.setEventListener(
                this,
                new KeyboardVisibilityEventListener() {
                    @Override
                    public void onVisibilityChanged(boolean isOpen) {
                        Log.d(TAG,"onVisibilityChanged: Keyboard visibility changed");
                        if(isOpen){
                            Log.d(TAG, "onVisibilityChanged: Keyboard is open");
                            navigation.setVisibility(View.INVISIBLE);
                            Log.d(TAG, "onVisibilityChanged: NavBar got Invisible");
                        }else{
                            Log.d(TAG, "onVisibilityChanged: Keyboard is closed");
                            navigation.setVisibility(View.VISIBLE);
                            Log.d(TAG, "onVisibilityChanged: NavBar got Visible");
                        }
                    }
                });
    }

    private void loadFragment(Android.support.v4.app.Fragment fragment) {
        Android.support.v4.app.FragmentTransaction fragmentTransaction = getSupportFragmentManager().beginTransaction();
        fragmentTransaction.replace(R.id.fragment_container, fragment);
        fragmentTransaction.addToBackStack(null);
        fragmentTransaction.commit();
    }

}
0
Haroon khan