3
  1. 以下に示すように、AppBarLayout の一部である CollapsingToolbarLayout 内にイメージビューがあります。イメージビューからスクロールを開始してコンテンツをスクロールしようとするたびにスクロールしませんが、recyclerview/NestedScrollView からスクロールするとコンテンツがスクロールされます。これは CoordinatorLayout の予想される動作でしたか? imageview をスクロールしてコンテンツ、つまり imageview と recyclerview/NestedScrollView をスクロールしたい場合、これをどのように達成できますか。ここで何か不足していますか?

  2. プログラムで recyclerView.smoothScrollBy()/scrollToPosition()/scrollTo() を呼び出そうとすると、コンテンツ全体、つまり CoordinatorLayout と imageview がスクロールされません。

<>

<android.support.design.widget.CoordinatorLayout
    android:id="@+id/rootLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/appToolbarLayout"
        android:layout_width="match_parent"
        android:layout_height="@dimen/app_bar_height"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/collapsingToolbarLayout"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:contentScrim="?attr/colorPrimary"
            app:layout_scrollFlags="scroll|exitUntilCollapsed">

            <ImageView
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:scaleType="centerCrop"
                android:src="@drawable/header"
                app:layout_collapseMode="parallax"
                app:layout_collapseParallaxMultiplier="0.7" />

            <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/ThemeOverlay.AppCompat.Light"
                app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar" />

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

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

    <android.support.v7.widget.RecyclerView // or NestedScrollView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/recycler"
        app:layout_behavior="@string/appbar_scrolling_view_behavior" />

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

<>

4

1 に答える 1

1

最後に、回避策があります:

パート 1: ImageView を recyclerview に移動し、視差効果を持たせるために " https://github.com/kanytu/android-parallax-recyclerview/blob/master/library/src/main/java/comを使用しています/poliveira/parallaxrecyclerview/ParallaxRecyclerAdapter.java "

パート 2: RecyclerView として、recyclerView.smoothScrollBy()/scrollToPosition()/scrollTo() を使用できます

于 2015-07-09T17:07:29.577 に答える