Android科普知识之recyclerView与标题栏的滑动变色

这种情况就不说了,很多购物的商城都有这样的情况,刚开始标题栏是不存在的,透明的,在列表滑动的时候,开始发生变化,划到一定距离整个标题栏完全出现了。

就是一个透明度的问题,刚开始透明度设置成为1 ,在滑动的时候开始增加这个透明度值。等增加到一定程度,当然就完全显示里。


直接上代码

xml文件:

<?xml version="1.0" encoding="utf-8"?>
<layout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:omi="http://schemas.android.com/apk/res-auto"
    >

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/white"
        >
        <android.support.v7.widget.RecyclerView
            android:id="@+id/recyclerView"
            android:layout_width="match_parent"
            android:layout_height="wrap_content">

        </android.support.v7.widget.RecyclerView>

        <com.omi.ui.widget.TopNavigationBar
            android:id="@+id/topNavigationBar"
            style="@style/TopBarStyle"
            omi:centerText="@string/omilive"
            omi:leftClick="@{@string/top_left_click}"
            omi:leftSrc="@mipmap/back_btn"
            omi:rightClick="@{@string/top_right_click}"
            omi:rightSrc="@mipmap/sort"
            />
    </RelativeLayout>
</layout>


初始化控件之后,声明一个成员变量:float  alpha;  就是透明度

给标题栏设置透明度的方法:

public void setAlpha(float alpha) {
    if (alpha == this.alpha) return;
    this.alpha = alpha;
    myliveBinding.topNavigationBar.setBackgroundAlpha(alpha);
}

将透明度赋值给标题栏,并开启滑动监听:

//滑动变色
myliveBinding.topNavigationBar.setBackgroundAlpha(alpha);
myliveBinding.recyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {
    @Override
    public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
        LinearLayoutManager layoutManager = (LinearLayoutManager) recyclerView.getLayoutManager();
        int position = layoutManager.findFirstVisibleItemPosition();
        if (position > 0) {
            setAlpha(1);
        } else {
            View firstView = layoutManager.findViewByPosition(position);
            int top = firstView.getTop();
            int height = myliveBinding.topNavigationBar.getHeight();
            int firstHeight = firstView.getHeight();
            setAlpha(Math.min(1f, (float) -top / (float) (firstHeight - height)));
        }
    }
});


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值