2017-09-08 12 views
1

以下は私のレイアウトxmlです。今問題は、BottomNavigationViewがFrameLayoutとオーバーラップしていることです。私はFrameLayoutをBottomNavigationViewの上に伸ばしたいと思っていました。BottomNavigationViewはCoordinatorLayoutのFrameLayoutをオーバーラップします

FrameLayoutにpaddingBottomを追加するなどのトリックで試しましたが、他にも優れたソリューションがあるのだろうかと思います。ありがとう。

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.CoordinatorLayout 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" 
    > 

    <include layout="@layout/user_app_bar"/> 

    <android.support.design.widget.BottomNavigationView 
     android:id="@+id/navigation" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:layout_gravity="bottom" 
     android:background="?android:attr/windowBackground" 
     app:menu="@menu/navigation" 
     app:itemTextColor="@color/colorPrimaryDark" 
     app:itemIconTint="@color/colorPrimaryDark" 
     /> 

    <FrameLayout 
     android:id="@+id/fragment_frame" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:paddingBottom="58dp" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior"/> 

    <android.support.design.widget.FloatingActionButton 
     android:id="@+id/fab" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_margin="@dimen/fab_margin" 
     app:layout_anchorGravity="bottom|end" 
     app:layout_anchor="@id/app_bar" 
     app:srcCompat="@drawable/ic_edit_white_24px" /> 

</android.support.design.widget.CoordinatorLayout> 

UPDATE:user_app_bar.xmlの詳細については。 CollapsingToolbarLayoutが含まれています。

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.AppBarLayout 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/app_bar" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:theme="@style/AppTheme.AppBarOverlay" 
    app:layout_behavior="co.domain.DisableAppBarLayoutBehaviour" 
    > 

    <android.support.design.widget.CollapsingToolbarLayout 
     android:id="@+id/toolbar_layout" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:fitsSystemWindows="true" 
     app:layout_scrollFlags="scroll|exitUntilCollapsed" 
     app:titleEnabled="false" 
     app:contentScrim="?attr/colorPrimary"> 

     <android.support.constraint.ConstraintLayout 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      app:layout_collapseMode="parallax"> 

      <ImageView 
       android:id="@+id/backdrop" 
       android:layout_width="match_parent" 
       android:layout_height="250dp" 
       android:layout_marginBottom="0dp" 
       android:layout_marginLeft="0dp" 
       android:layout_marginRight="0dp" 
       android:layout_marginTop="0dp" 
       android:contentDescription="" 
       app:layout_constraintBottom_toBottomOf="parent" 
       app:layout_constraintHorizontal_bias="0.0" 
       app:layout_constraintLeft_toLeftOf="parent" 
       app:layout_constraintRight_toRightOf="parent" 
       app:layout_constraintTop_toTopOf="parent" 
       app:layout_constraintVertical_bias="0.0" 
       tools:ignore="ContentDescription" 
       android:background="@color/gray"/> 

      <TextView 
       android:id="@+id/profileName" 
       style="@style/textShadow" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:layout_marginEnd="8dp" 
       android:layout_marginLeft="8dp" 
       android:layout_marginRight="8dp" 
       android:layout_marginStart="8dp" 
       android:layout_marginTop="0dp" 
       android:text="user name" 
       android:textAlignment="center" 
       android:textSize="18sp" 
       android:textColor="#fff" 
       app:layout_constraintHorizontal_bias="0.5" 
       app:layout_constraintLeft_toLeftOf="@+id/profileImage" 
       app:layout_constraintRight_toRightOf="@+id/profileImage" 
       app:layout_constraintTop_toBottomOf="@+id/profileImage" /> 

      <de.hdodenhof.circleimageview.CircleImageView 
       android:id="@+id/profileImage" 
       android:layout_width="70dp" 
       android:layout_height="70dp" 
       android:layout_marginBottom="8dp" 
       android:layout_marginLeft="32dp" 
       android:layout_marginStart="32dp" 
       android:layout_marginTop="8dp" 
       android:alpha="0.5" 
       android:src="@drawable/ic_account_circle_black_24dp" 
       app:layout_constraintBottom_toBottomOf="parent" 
       app:layout_constraintLeft_toLeftOf="parent" 
       app:layout_constraintTop_toTopOf="parent" /> 
     </android.support.constraint.ConstraintLayout> 

     <android.support.v7.widget.Toolbar 
      android:id="@+id/toolbar" 
      android:layout_width="match_parent" 
      android:layout_height="?attr/actionBarSize" 
      app:layout_collapseMode="pin" 
      app:popupTheme="@style/AppTheme.PopupOverlay"/> 

    </android.support.design.widget.CollapsingToolbarLayout> 

</android.support.design.widget.AppBarLayout> 
+0

ボトムビューのレイアウトの上に常にあるように固定高さを与える必要があります(画面の高さを計算してボトムバーの高さを計算することで動的に行うことができます)。または、相対レイアウトを使用してボトムプロパティを割り当てることができます –

+0

XMLはどうですか? – hjchin

+0

私は知ってほしいルートの相対的なレイアウトはあなたのために良いですか? –

答えて

0
/Try to replace your code with this/ 

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.CoordinatorLayout 
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" 
> 

<include layout="@layout/user_app_bar"/> 

<FrameLayout 
    android:id="@+id/fragment_frame" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:paddingBottom="58dp" 
    app:layout_behavior="@string/appbar_scrolling_view_behavior"/> 

<android.support.design.widget.FloatingActionButton 
    android:id="@+id/fab" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_margin="@dimen/fab_margin" 
    app:layout_anchorGravity="bottom|end" 
    app:layout_anchor="@id/app_bar" 
    app:srcCompat="@drawable/ic_edit_white_24px" /> 


<android.support.design.widget.BottomNavigationView 
    android:id="@+id/navigation" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:layout_gravity="bottom" 
    android:background="?android:attr/windowBackground" 
    app:menu="@menu/navigation" 
    app:itemTextColor="@color/colorPrimaryDark" 
    app:itemIconTint="@color/colorPrimaryDark" 
    /> 

</android.support.design.widget.CoordinatorLayout> 
+0

要素の並べ替えだけですか?私はパディングボトムも取り除くことを前提としていた。私は試して、それは動作しませんでした。 – hjchin

1

あなたの問題の簡単な解決策があります。つまりをFrameLayout56dpと書いてあります。これは文書heightBottomNavigationViewに従っています。私はそれがモバイル画面に応じて変更可能であるかどうかはわかりません。ドキュメンテーションでさえ、身長の変化について何も言わない。そして私はいくつかの私のアプリでそれを使用して、私はBottomNavigationViewの高さが変化しているのを見つけませんでした。しかし、チェックの場合のみ。これが役立つことを願っています。

+0

user_app_barレイアウトファイルにAppBarLayoutがあるので、私はCoordinatorLayoutをルートレイアウトとして使用する必要があります。 – hjchin

+0

yout app_bar_ layout.xmlの中に 'TabLayout'がない場合は、topmarginを使用してください。私のediteの回答を参照してください。 – Yupi

+0

上記のapp_barレイアウトファイルを追加しました。 AppBarLayoutにCollapsingToolbarLayoutがあるので、固定高さを使用することはできません。 – hjchin

関連する問題