Android 带有两个对齐点的 CollapsingToolbarLayout
Android CollapsingToolbarLayout with two snapping point
我正在尝试创建一个带有两个对齐点的折叠工具栏视图。有什么办法可以做到这一点。我试了两天,找不到合适的解决方案。我想要这样的东西:
**
默认外观:
**
**
第一个捕捉点:
**
**
第二个捕捉点:
**
我想你知道如何设置 Collapsing Toolbar
吧?
如果你这样做了,你可以通过如下设置滚动标志来获得两个捕捉点:
<android.support.design.widget.CollapsingToolbarLayout
...stuff...
app:layout_scrollFlags="scroll|enterAlways|snap">
如果这对您不起作用,我发现了一个很棒的 ,它提供了自定义滚动行为。干杯
所以在阅读了很多堆栈问题并发现他们的解决方案对于这个简单的任务有很多复杂的代码(而且我很懒惰)。我喜欢一个简单的解决方案:
这是我折叠的收费栏布局:
<com.google.android.material.appbar.AppBarLayout
android:id="@+id/appBar"
android:layout_width="match_parent"
android:layout_height="258dp"
android:background="@android:color/transparent"
android:fitsSystemWindows="true"
android:minHeight="60dp"
app:elevation="0dp"
app:layout_insetEdge="top">
<com.google.android.material.appbar.CollapsingToolbarLayout
android:id="@+id/collapsingToolbarLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:contentScrim="@android:color/transparent"
app:layout_scrollFlags="scroll|enterAlways|snap">
**/**** First snapping point ***************/**
<com.google.android.material.appbar.MaterialToolbar
android:id="@+id/toolbarOne"
android:layout_width="match_parent"
android:layout_height="70dp"
app:layout_collapseMode="pin" />
</com.google.android.material.appbar.CollapsingToolbarLayout>
</com.google.android.material.appbar.AppBarLayout>
对于第一个捕捉点,您可以使用带 layout_collapseMode="pin"
的工具栏并设置捕捉位置所需的大小。
现在对于内容布局中的第二个捕捉点 有一个嵌套的滚动视图或其他任何东西,您可以使用具有您想要的大小的透明视图作为第二个捕捉位置。这将避免应用栏丰富滚动范围并且您有第二个捕捉点:
<androidx.core.widget.NestedScrollView 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/nestedScrollView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fillViewport="true"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/fragment_calendar">
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
**/**** second snapping point ***************/**
<ImageView
android:id="@+id/daily"
android:layout_width="match_parent"
android:layout_height="60dp"
app:layout_constraintTop_toTopOf="parent" />
<androidx.constraintlayout.widget.ConstraintLayout
style="@style/PageBackground.White"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_constraintTop_toBottomOf="@id/daily"
android:background="@drawable/background_top_corner_calendar">
your content.....
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.core.widget.NestedScrollView>
我正在尝试创建一个带有两个对齐点的折叠工具栏视图。有什么办法可以做到这一点。我试了两天,找不到合适的解决方案。我想要这样的东西:
**
默认外观:
**
**
第一个捕捉点:
**
**
第二个捕捉点:
**
我想你知道如何设置 Collapsing Toolbar
吧?
如果你这样做了,你可以通过如下设置滚动标志来获得两个捕捉点:
<android.support.design.widget.CollapsingToolbarLayout
...stuff...
app:layout_scrollFlags="scroll|enterAlways|snap">
如果这对您不起作用,我发现了一个很棒的
所以在阅读了很多堆栈问题并发现他们的解决方案对于这个简单的任务有很多复杂的代码(而且我很懒惰)。我喜欢一个简单的解决方案:
这是我折叠的收费栏布局:
<com.google.android.material.appbar.AppBarLayout
android:id="@+id/appBar"
android:layout_width="match_parent"
android:layout_height="258dp"
android:background="@android:color/transparent"
android:fitsSystemWindows="true"
android:minHeight="60dp"
app:elevation="0dp"
app:layout_insetEdge="top">
<com.google.android.material.appbar.CollapsingToolbarLayout
android:id="@+id/collapsingToolbarLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:contentScrim="@android:color/transparent"
app:layout_scrollFlags="scroll|enterAlways|snap">
**/**** First snapping point ***************/**
<com.google.android.material.appbar.MaterialToolbar
android:id="@+id/toolbarOne"
android:layout_width="match_parent"
android:layout_height="70dp"
app:layout_collapseMode="pin" />
</com.google.android.material.appbar.CollapsingToolbarLayout>
</com.google.android.material.appbar.AppBarLayout>
对于第一个捕捉点,您可以使用带 layout_collapseMode="pin"
的工具栏并设置捕捉位置所需的大小。
现在对于内容布局中的第二个捕捉点 有一个嵌套的滚动视图或其他任何东西,您可以使用具有您想要的大小的透明视图作为第二个捕捉位置。这将避免应用栏丰富滚动范围并且您有第二个捕捉点:
<androidx.core.widget.NestedScrollView 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/nestedScrollView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fillViewport="true"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:showIn="@layout/fragment_calendar">
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
**/**** second snapping point ***************/**
<ImageView
android:id="@+id/daily"
android:layout_width="match_parent"
android:layout_height="60dp"
app:layout_constraintTop_toTopOf="parent" />
<androidx.constraintlayout.widget.ConstraintLayout
style="@style/PageBackground.White"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_constraintTop_toBottomOf="@id/daily"
android:background="@drawable/background_top_corner_calendar">
your content.....
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.core.widget.NestedScrollView>