Mam następujący układ:
<android.support.design.widget.CoordinatorLayout
android:id="@+id/main_content"
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.AppBarLayout
android:id="@+id/appBar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/ThemeOverlay.AppCompat.ActionBar">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:layout_scrollFlags="scroll|enterAlways"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>
</android.support.design.widget.AppBarLayout>
<FrameLayout
android:id="@+id/content"
android:layout_width="match_parent"
android:layout_height="match_parent"
/>
</android.support.design.widget.CoordinatorLayout>
Dodaję Fragment
s do FrameLayout
, zastępując je. Jedna z moich Fragment
list to lista, która ma następujący układ:
<android.support.v7.widget.RecyclerView
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/recyclerView"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"/>
Mój problem polega na tym, że pasek narzędzi jest rysowany nad listą . Próbowałem to rozwiązać, zawijając zawartość CoordinatorLayout
pliku w a LinearLayout
, co rozwiązało problem przerysowania, ale w ten sposób zachowanie przewijania paska aplikacji nie działa.
Każda pomoc jest mile widziana!
Fragment
zawierającego listę innąFragment
. W ten sposób udało mi się ręcznie wyświetlić pasek narzędzi .Udało mi się to naprawić dodając:
do FrameLayout w następujący sposób:
źródło
android:layout_marginTop="?android:attr/actionBarSize"
Począwszy od Android Studio 3.4, musisz umieścić tę linię w swoim układzie, która zawiera rozszerzenie
RecyclerView
.źródło
Aby użyć zwijanego górnego paska narzędzi lub używając dowolnie wybranych ScrollFlags, możemy zrobić to w następujący sposób: Z Material Design pozbądź się FrameLayout
źródło