Android BottomNavigationVIew重叠片段内容

时间:2017-10-10 14:08:38

标签: android android-fragments

我正在尝试聊天。 MainActivity ToolBar BottomNavigationVIew

聊天fragmentrecyclerVieweditTextImageButton,但是当我加载片段时,BottomNavigationVIewEditText重叠和ImageButton

我不知道这是否很重要但是在Android Studio中,BottomNavigationVIew的项目看起来比它小,不像工具栏那样 我也使用android:layout_above="@+id/navigation",但它不起作用 enter image description here

enter image description here

我尝试了很多方法,但我不能这样做

activity_main.xml中

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_home"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <android.support.v7.widget.Toolbar xmlns:app="http://schemas.android.com/apk/res-auto"
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:background="?attr/colorPrimary"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
        app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="horizontal">

            <TextView
                android:id="@+id/tv_parent_name"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center"
                android:layout_weight="1"
                android:text="@string/parent_name"
                android:textSize="20sp" />


            <de.hdodenhof.circleimageview.CircleImageView xmlns:app="http://schemas.android.com/apk/res-auto"
                android:id="@+id/student_photo"
                android:layout_width="55dp"
                android:layout_height="55dp"
                android:layout_alignParentEnd="true"

                android:layout_alignParentRight="true"
                android:layout_gravity="right|center"
                android:onClick="onClick"
                android:padding="4dp"
                android:src="@drawable/foto"
                app:civ_border_color="@color/iron"
                app:civ_border_width="1dp" />

        </LinearLayout>

    </android.support.v7.widget.Toolbar>


    <FrameLayout
        android:id="@+id/frame_layout"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_alignParentTop="true"
        android:layout_above="@+id/navigation">

        <ProgressBar
            android:id="@+id/pb_loading"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:visibility="invisible" />
    </FrameLayout>

</LinearLayout>

<android.support.design.widget.BottomNavigationView
    android:id="@+id/navigation"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:background="@color/primary_dark"
    app:itemIconTint="@color/nav_item_state_list"
    app:itemTextColor="@color/nav_item_state_list"
    app:menu="@menu/menu_navigation" />
</RelativeLayout>

chat_fragment.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">

<android.support.v7.widget.RecyclerView
    android:id="@+id/messages"
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:scrollbars="vertical"
    android:scrollbarStyle="outsideOverlay"/>

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:orientation="horizontal"
    android:gravity="center_vertical">

    <EditText
        android:id="@+id/message_input"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:hint="@string/prompt_message"
        android:imeActionId="@+id/send"
        android:imeActionLabel="@string/action_send"
        android:imeOptions="actionSend"
        android:inputType="text"
        android:maxLines="1"/>
    <ImageButton
        android:id="@+id/send_button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@android:drawable/ic_menu_send"
        android:contentDescription="@string/action_send"/>

</LinearLayout>

</LinearLayout>

fragment.java

                FragmentManager fragmentManager = getFragmentManager();
            FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
            fragmentManager.popBackStackImmediate();
            fragmentTransaction.replace(R.id.frame_layout, chat);
            fragmentTransaction.addToBackStack(null);
            fragmentTransaction.commit();

2 个答案:

答案 0 :(得分:4)

activity_main.xml中,设置方向设置为垂直的根布局LinearLayout。在根布局内删除LinearLayout右侧。并为FrameLayout设置以下高度宽度配置:

android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"

最后,删除所有align...内容,因为它们在LinearLayout内无效。

答案 1 :(得分:0)

您必须将FrameLayout代码移出LinearLayout(我的意思是在LinearLayout之后),并且您还必须将此代码添加到您的框架中:

    android:layout_above="@+id/navigation"