RecyclerView с NestedScrollView
Я занимаюсь разработкой музыкального плеера для Android, в котором у меня есть детализация альбома с сворачивающейся панелью инструментов и вложенным видом прокрутки. Внутри вложенного вида прокрутки есть три вида текста и вид переработчика, см. Код ниже,
<android.support.v4.widget.NestedScrollView
app:layout_behavior="@string/appbar_scrolling_view_behavior"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/linear_detail_background"
app:behavior_overlapTop="50dp"
>
<LinearLayout
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/album_name"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingTop="20dp"
android:paddingLeft="10dp"
android:maxLines="1"
android:ellipsize="end"
android:text="Album Name"
android:textSize="24dp"
android:textColor="#000"
/>
<TextView
android:id="@+id/album_artist"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Album Name"
android:textSize="14dp"
android:paddingLeft="10dp"
android:layout_marginTop="5dp"
android:layout_marginBottom="15dp"
android:maxLines="1"
android:ellipsize="end"
/>
<TextView
android:id="@+id/song_text"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Songs"
android:textAppearance="@style/Base.TextAppearance.AppCompat.Body1"
android:paddingLeft="10dp"
android:layout_marginTop="5dp"
android:textColor="#000"
/>
<android.support.v7.widget.RecyclerView
android:nestedScrollingEnabled="false"
android:id="@+id/album_songs"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
</LinearLayout>
</android.support.v4.widget.NestedScrollView>
Приведенный выше код приводит к этому изображению
Проблема возникает, когда есть больше песен, на изображении выше показано название альбома This Party Gettin Hot и имя исполнителя. Но когда появляется больше песен, название альбома и имя исполнителя не отображаются.
Смотрите это изображение для проблемы
Полный XML-код как ниже
<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:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/white">
<android.support.design.widget.AppBarLayout
android:id="@+id/app_bar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:fitsSystemWindows="true"
android:background="@color/white"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
>
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/collapsing_albums_songs"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:contentScrim="@color/white"
app:layout_scrollFlags="scroll|exitUntilCollapsed">
<ImageView
android:id="@+id/poster"
android:layout_width="match_parent"
android:layout_height="300dp"
android:scaleType="centerCrop"
app:layout_collapseMode="parallax"
app:layout_collapseParallaxMultiplier="0.7"
android:background="@drawable/gradient_bg"/>
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar_album_detail"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:layout_collapseMode="pin"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
/>
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<android.support.v4.widget.NestedScrollView
app:layout_behavior="@string/appbar_scrolling_view_behavior"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/linear_detail_background"
app:behavior_overlapTop="50dp"
>
<LinearLayout
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/album_name"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingTop="20dp"
android:paddingLeft="10dp"
android:maxLines="1"
android:ellipsize="end"
android:text="Album Name"
android:textSize="24dp"
android:textColor="#000"
/>
<TextView
android:id="@+id/album_artist"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Album Name"
android:textSize="14dp"
android:paddingLeft="10dp"
android:layout_marginTop="5dp"
android:layout_marginBottom="15dp"
android:maxLines="1"
android:ellipsize="end"
/>
<TextView
android:id="@+id/song_text"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Songs"
android:textAppearance="@style/Base.TextAppearance.AppCompat.Body1"
android:paddingLeft="10dp"
android:layout_marginTop="5dp"
android:textColor="#000"
/>
<android.support.v7.widget.RecyclerView
android:nestedScrollingEnabled="false"
android:id="@+id/album_songs"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
</LinearLayout>
</android.support.v4.widget.NestedScrollView>
как я могу решить эту проблему? Что я делаю не так?
1 ответ
Попробуйте изменить вложенное представление прокрутки layout_width для переноса содержимого
<android.support.v4.widget.NestedScrollView
app:layout_behavior="@string/appbar_scrolling_view_behavior"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:background="@drawable/linear_detail_background"
app:behavior_overlapTop="50dp"
>