Android 使用CoordinatorLayout+AppBarLayout时,下方主内容区域高度无法填满问题

今天我在使用 CoordinatorLayout+AppBarLayout 时,出现一个奇葩的问题。头部布局用 appbarlayout 实现,下方主内容区域就一个 viewpager;但是 viewpager 中时滑动列表。问题来了,主内容列表区域的高度无法填充,总是多出一个 CollapsingToolbarLayout 的高度;经过问题分析定位,最终发现时外层AppBarLayut的问题。下方提出我的解决方式。

之前有文章写到AppBarLayout+TabLayout+ViewPager 时限头部布局滑动渐变的效果(链接) --->>https://blog.csdn.net/PenTablet/article/details/95459396

其中有提到过app:layout_behavior属性,来实现滑动效果。今天也是通过改变这个属性;

默认的属性是这样的, app:layout_behavior="@string/appbar_scrolling_view_behavior";我们要自定义一个behavior,来解决内容区域高度的问题。

FixScrollingFooterBehavior.java:
package com.koib.healthcontrol.view;

import android.content.Context;
import android.util.AttributeSet;
import android.view.View;

import androidx.coordinatorlayout.widget.CoordinatorLayout;

import com.google.android.material.appbar.AppBarLayout;

public class FixScrollingFooterBehavior extends AppBarLayout.ScrollingViewBehavior {
    private AppBarLayout appBarLayout;

    public FixScrollingFooterBehavior() {
        super();
    }

    public FixScrollingFooterBehavior(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    @Override
    public boolean onDependentViewChanged(CoordinatorLayout parent, View child, View dependency) {

        if (appBarLayout == null) {
            appBarLayout = (AppBarLayout) dependency;
        }

        final boolean result = super.onDependentViewChanged(parent, child, dependency);
        final int bottomPadding = calculateBottomPadding(appBarLayout);
        final boolean paddingChanged = bottomPadding != child.getPaddingBottom();
        if (paddingChanged) {
            child.setPadding(
                    child.getPaddingLeft(),
                    child.getPaddingTop(),
                    child.getPaddingRight(),
                    bottomPadding);
            child.requestLayout();
        }
        return paddingChanged || result;
    }

    private int calculateBottomPadding(AppBarLayout dependency) {
        final int totalScrollRange = dependency.getTotalScrollRange();
        return totalScrollRange + dependency.getTop();
    }

}

直接替换掉就好了。

我的问题时解决了,以此来记录。可能并使适合你们的布局,近作参考,勿喷,谢谢~~~

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值