我正在创建一个应用程序,我的浮动操作按钮覆盖在我的底部导航栏上我试图将fab放在导航栏上方但是它不工作fab正在重叠底部导航栏下面是xml文件 我搜索了SO,但没有得到任何正确的解决方案,任何帮助将不胜感激
我为底部naigation布局制作了一个单独的xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout 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.design.widget.BottomNavigationView
android:id="@+id/navigation"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:background="?android:attr/windowBackground"
app:menu="@menu/navigation"
android:backgroundTint="@color/nav_color"
app:itemIconTint="@color/bottom_nav_fore_color"/>
</android.support.constraint.ConstraintLayout>
这里是xml for activity main
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:orientation="vertical"
android:background="@color/colorPrimary">
<com.ct.listrr.widget.BounceScrollView
android:layout_height="match_parent"
android:id="@+id/scrollview"
android:layout_width="match_parent"
android:fitsSystemWindows="true"
android:fillViewport="true"
xmlns:android="http://schemas.android.com/apk/res/android" >
<LinearLayout 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:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context="com.ct.listrr.MainActivity"
>
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="330dp"
android:layout_height="340dp"
android:layout_marginTop="10dp"
android:layout_marginLeft="25dp"
tools:layout_editor_absoluteX="8dp"
tools:layout_editor_absoluteY="8dp" />
<LinearLayout
android:id="@+id/club_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<com.ct.listrr.widget.CustomTextViewMedium
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="50"
android:textSize="40sp"
android:text="Clubs"
android:layout_marginLeft="10dp"
android:layout_marginTop="15dp"
android:textColor="@color/White"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<android.support.v7.widget.RecyclerView
android:id="@+id/clubrecycler_view"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v7.widget.RecyclerView>
</LinearLayout>
<LinearLayout
android:id="@+id/lounge_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<com.ct.listrr.widget.CustomTextViewMedium
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="50"
android:textSize="40sp"
android:text="Lounge"
android:layout_marginLeft="10dp"
android:layout_marginTop="15dp"
android:textColor="@color/White"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<android.support.v7.widget.RecyclerView
android:id="@+id/loungerecycler_view"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v7.widget.RecyclerView>
</LinearLayout>
<LinearLayout
android:id="@+id/cafe_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<com.ct.listrr.widget.CustomTextViewMedium
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="50"
android:textSize="40sp"
android:text="Cafe"
android:layout_marginLeft="10dp"
android:layout_marginTop="15dp"
android:textColor="@color/White"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<android.support.v7.widget.RecyclerView
android:id="@+id/caferecycler_view"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v7.widget.RecyclerView>
</LinearLayout>
<LinearLayout
android:id="@+id/rooftop_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<com.ct.listrr.widget.CustomTextViewMedium
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="50"
android:textSize="40sp"
android:text="RoofTop"
android:layout_marginLeft="10dp"
android:layout_marginTop="15dp"
android:textColor="@color/White"/>
</LinearLayout>
<LinearLayout
android:id="@+id/layout_recycle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<android.support.v7.widget.RecyclerView
android:id="@+id/rooftoprecycler_view"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v7.widget.RecyclerView>
</LinearLayout>
</LinearLayout>
</com.ct.listrr.widget.BounceScrollView>
<android.support.design.widget.FloatingActionButton
android:id="@+id/fab"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentRight="true"
android:src="@drawable/ic_my_icon"
android:layout_margin="16dp"
app:rippleColor="@color/colorAccent"/>
<include layout="@layout/bottom_nav_bar"
android:id="@+id/bottom_nav_bar"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:layout_alignParentBottom="true"
/>
</RelativeLayout>
答案 0 :(得分:0)
在FloatingActionButton
中使用上面的布局参数android:layout_above="@id/bottom_nav_bar"
这是你的完整xml:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:orientation="vertical"
android:background="@color/colorPrimary">
<com.ct.listrr.widget.BounceScrollView
android:layout_height="match_parent"
android:id="@+id/scrollview"
android:layout_width="match_parent"
android:fitsSystemWindows="true"
android:fillViewport="true"
xmlns:android="http://schemas.android.com/apk/res/android" >
<LinearLayout 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:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context="com.ct.listrr.MainActivity"
>
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="330dp"
android:layout_height="340dp"
android:layout_marginTop="10dp"
android:layout_marginLeft="25dp"
tools:layout_editor_absoluteX="8dp"
tools:layout_editor_absoluteY="8dp" />
<LinearLayout
android:id="@+id/club_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<com.ct.listrr.widget.CustomTextViewMedium
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="50"
android:textSize="40sp"
android:text="Clubs"
android:layout_marginLeft="10dp"
android:layout_marginTop="15dp"
android:textColor="@color/White"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<android.support.v7.widget.RecyclerView
android:id="@+id/clubrecycler_view"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v7.widget.RecyclerView>
</LinearLayout>
<LinearLayout
android:id="@+id/lounge_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<com.ct.listrr.widget.CustomTextViewMedium
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="50"
android:textSize="40sp"
android:text="Lounge"
android:layout_marginLeft="10dp"
android:layout_marginTop="15dp"
android:textColor="@color/White"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<android.support.v7.widget.RecyclerView
android:id="@+id/loungerecycler_view"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v7.widget.RecyclerView>
</LinearLayout>
<LinearLayout
android:id="@+id/cafe_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<com.ct.listrr.widget.CustomTextViewMedium
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="50"
android:textSize="40sp"
android:text="Cafe"
android:layout_marginLeft="10dp"
android:layout_marginTop="15dp"
android:textColor="@color/White"/>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<android.support.v7.widget.RecyclerView
android:id="@+id/caferecycler_view"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v7.widget.RecyclerView>
</LinearLayout>
<LinearLayout
android:id="@+id/rooftop_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<com.ct.listrr.widget.CustomTextViewMedium
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="50"
android:textSize="40sp"
android:text="RoofTop"
android:layout_marginLeft="10dp"
android:layout_marginTop="15dp"
android:textColor="@color/White"/>
</LinearLayout>
<LinearLayout
android:id="@+id/layout_recycle"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<android.support.v7.widget.RecyclerView
android:id="@+id/rooftoprecycler_view"
android:layout_width="match_parent"
android:layout_height="match_parent">
</android.support.v7.widget.RecyclerView>
</LinearLayout>
</LinearLayout>
</com.ct.listrr.widget.BounceScrollView>
<include layout="@layout/bottom_nav_bar"
android:id="@+id/bottom_nav_bar"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:layout_alignParentBottom="true"
/>
<android.support.design.widget.FloatingActionButton
android:id="@+id/fab"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:src="@drawable/ic_my_icon"
android:layout_above="@id/bottom_nav_bar"
android:layout_margin="16dp"
app:rippleColor="@color/colorAccent"/>
</RelativeLayout>
答案 1 :(得分:0)
这有效:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
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/container"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/message"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="@dimen/activity_horizontal_margin"
android:layout_marginStart="@dimen/activity_horizontal_margin"
android:layout_marginTop="@dimen/activity_vertical_margin"
android:text="@string/title_home"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<android.support.design.widget.BottomNavigationView
android:id="@+id/navigation"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginEnd="0dp"
android:layout_marginStart="0dp"
android:background="?android:attr/windowBackground"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:menu="@menu/navigation">
</android.support.design.widget.BottomNavigationView>
<android.support.design.widget.FloatingActionButton
android:id="@+id/fab"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="end|bottom"
android:layout_marginBottom="28dp"
android:layout_marginEnd="16dp"
android:layout_marginRight="16dp"
app:elevation="2dp"
app:layout_constraintBottom_toTopOf="@+id/navigation"
app:layout_constraintEnd_toStartOf="parent" />
答案 2 :(得分:0)
我实际上没有找到任何解决办法。
我所做的是将environment.local.ts
设置为floating action button marginBottom
。
看起来不太好,但是至少它不再与屏幕重叠。
EDIT2:我相信香港专业教育学院找到了解决方案。尝试将父视图的marginBottom设置为?attr / actionBarSize。