食谱如下:
如果您设置android:minHeight,AppBarLayout 将尊重该值,不会滚动超出使您的组件变小的点。所以你的 XML 布局可能是这样的:
<com.example.CustomCollapsingLayout
android:layout_width="match_parent"
android:layout_height="320dp"
android:minHeight="108dp"
android:fitsSystemWindows="true"
app:layout_scrollFlags="scroll|exitUntilCollapsed">
接下来,您想让您的班级向父级AppBarLayout 注册一个OnOffsetChangedListener。您的组件将在应用栏滚动时获取事件,以便您知道如何配置视图。
class OnOffsetChangedListener implements AppBarLayout.OnOffsetChangedListener {
@Override
public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
final int scrollRange = appBarLayout.getTotalScrollRange();
float offsetFactor = (float) (-verticalOffset) / (float) scrollRange;
...
这将向您展示如何找到总滚动范围,然后找到总滚动范围与当前滚动位置(即应用栏在其滚动中的位置)之间的比率。
你应该做CollapsingToolbarLayout 做的事情;覆盖onAttachedToWindow 并在那里添加监听器:
// Add an OnOffsetChangedListener if possible
final ViewParent parent = getParent();
if (parent instanceof AppBarLayout) {
if (mOnOffsetChangedListener == null) {
mOnOffsetChangedListener = new OnOffsetChangedListener();
}
((AppBarLayout) parent).addOnOffsetChangedListener(mOnOffsetChangedListener);
}
看看source code for CollapsingToolbarLayout,它会给你一些想法。您的视图需要做很多相同的事情。
您还可以查看我的示例项目,该项目有一个随着工具栏滚动而缩放和移动的图像:https://github.com/klarson2/Collapsing-Image