Android仿天猫横向滑动指示器功能的实现

 更新时间:2022年08月08日 10:11:26   作者:xiangzhihong8  
这篇文章主要介绍了Android仿天猫横向滑动指示器,Android开发中会有很多很新奇的交互,比如天猫商城的首页头部的分类,使用的是GridLayoutManager+横向指示器实现的,需要的朋友可以参考下

Android开发中会有很多很新奇的交互,比如天猫商城的首页头部的分类,使用的是GridLayoutManager+横向指示器实现的,效果如下图。

那对于这种效果要如何实现呢?最简单的方式就是使用RecyclerView+GridLayoutManager,我们知道RecyclerView可以实现九宫格,接下来就是通过RecyclerView控制指示器的显示位置,逻辑实现如下:

  1. 计算出RecyclerView划出屏幕的距离w1和剩余宽度w2的比例y,y = w1 / (总宽度w3 - 可使视区域宽度w4)
  2. 计算出指示器该移动的距离w5 = y * (指示器的总宽度w6 - 滑块宽度w7)
  3. 指示器布局,并控制位置

首先,我们创建两个drawable文件,分别用于表示指示器的默认背景和选中的背景。
indicator_bg_normal.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <corners android:radius="5dp" />
    <solid android:color="@color/gray_9" />
</shape>

indicator_bg_select.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <corners android:radius="5dp"/>
    <solid android:color="@color/red"/>
</shape>

然后,我们再添加一个布局,上面是RecyclerView,下面是指示器。

 <androidx.recyclerview.widget.RecyclerView
         android:id="@+id/recycler_view"
         android:layout_width="0dp"
         android:layout_height="@dimen/dp_120"
         android:layout_marginBottom="@dimen/dp_10"/>

  <RelativeLayout
        android:id="@+id/rl_indicator"
        android:layout_width="60dp"
        android:layout_height="4dp"
        android:layout_marginTop="10dp"
        android:layout_gravity="center_horizontal"
        android:background="@drawable/indicator_bg_normal">
        <View
            android:id="@+id/main_line"
            android:layout_width="30dp"
            android:layout_height="4dp"
            android:layout_centerVertical="true"
            android:background="@drawable/indicator_bg_select"/>
  </RelativeLayout>

接下来,就是通过监听RecyclerView的横向滚动的距离,来判断指示器显示的位置,代码如下。

 rvMenu.addOnScrollListener(new RecyclerView.OnScrollListener() {
            @Override
            public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
                super.onScrollStateChanged(recyclerView, newState);

            }

            @Override
            public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
                super.onScrolled(recyclerView, dx, dy);
                int range=0;
                int temp = rvMenu.computeHorizontalScrollRange();
                if (temp > range) {
                    range = temp;
                }
                //滑块的偏移量
                int offset = rvMenu.computeHorizontalScrollOffset();
                //可视区域长度
                int extent = rvMenu.computeHorizontalScrollExtent();
                //滑出部分在剩余范围的比例
                float proportion = (float) (offset * 1.0 / (range - extent));
                //计算滚动条宽度
                float transMaxRange = rlIndicator.getWidth() - mainLine.getWidth();
                //设置滚动条移动
                mainLine.setTranslationX(transMaxRange * proportion);
            }
        });

到此这篇关于Android仿天猫横向滑动指示器功能的实现的文章就介绍到这了,更多相关Android横向滑动指示器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Android Studio 2020新版本卡在Gradle downloading/sync failed/下载缓慢/下载超时的问题

    Android Studio 2020新版本卡在Gradle downloading/sync failed/下载缓慢/

    Android Studio 2020新版本 卡在Gradle downloading / sync failed / 下载缓慢 / 下载超时 亲测有效解决办法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2020-12-12
  • Android 贝塞尔曲线绘制一个波浪球

    Android 贝塞尔曲线绘制一个波浪球

    当 flutter 的现有组件无法满足产品要求的UI效果时,我们就需要通过自绘组件的方式来进行实现了。本文章就来介绍如何用贝塞尔曲线实现一个带文本的波浪球,需要的可以参考一下
    2022-05-05
  • Android ViewPager实现图片轮翻效果

    Android ViewPager实现图片轮翻效果

    这篇文章主要为大家详细介绍了Android ViewPager实现图片轮翻效果的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • Android采取BroadcastReceiver方式自动获取验证码

    Android采取BroadcastReceiver方式自动获取验证码

    这篇文章主要介绍了Android采取BroadcastReceiver方式自动获取验证码,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • Android实现验证码登录

    Android实现验证码登录

    这篇文章主要为大家详细介绍了Android实现验证码登录,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-03-03
  • 协程作用域概念迭代RxTask 实现自主控制

    协程作用域概念迭代RxTask 实现自主控制

    这篇文章主要为大家介绍了协程作用域概念迭代RxTask实现自主控制详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • Android底部菜单简单应用

    Android底部菜单简单应用

    这篇文章主要为大家详细介绍了Android底部菜单简单应用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • Android实现扫一扫功能之绘制指定区域透明区域

    Android实现扫一扫功能之绘制指定区域透明区域

    这篇文章主要给大家介绍了关于Android实现扫一扫功能之绘制指定区域透明区域的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2018-07-07
  • android实现Splash闪屏效果示例

    android实现Splash闪屏效果示例

    这篇文章主要介绍了android实现Splash闪屏效果的方法,涉及Android中postDelayed方法及AndroidManifest.xml权限控制的相关使用技巧,需要的朋友可以参考下
    2016-08-08
  • Android 深入探究自定义view之事件的分发机制与处理详解

    Android 深入探究自定义view之事件的分发机制与处理详解

    对于安卓程序员来说,自定义view简直不要太重要,毕竟有很多功能,譬如圆形头像这些,用单纯的原生非常难以实现,而用自定义view,简直分分钟
    2021-11-11

最新评论