服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Android - Android recyclerView横条指示器实现淘宝菜单模块

Android recyclerView横条指示器实现淘宝菜单模块

2022-11-21 15:44一般的帅gg Android

这篇文章主要为大家详细介绍了recyclerView横条指示器实现淘宝菜单模块,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

电商首页菜单模块,可以横向滑动,底部的滑动位置指示器该如何实现呢?

Android recyclerView横条指示器实现淘宝菜单模块

实现思路:

1.上方横滑列表可以直接使用RecyclerView实现;

2.下方的指示器:

(1).计算出RecyclerView划出屏幕的距离w1和剩余宽度w2的比例y,y = w1 / (总宽度w3 - 可使视区域宽度w4);

(2).计算出指示器该移动的距离w5 = y * (指示器的总宽度w6 - 滑块宽度w7);

(3).指示器布局实现:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<RelativeLayout
  android:id="@ id/parent_layout"
  android:layout_marginTop="10dp"
  android:layout_width="80dp"
  android:layout_height="4dp"
  android:layout_gravity="center"
  android:background="@drawable/bg_store_classify_normal">
 
  <View
   android:id="@ id/main_line"
   android:layout_width="40dp"
   android:layout_height="4dp"
   android:layout_centerVertical="true"
   android:background="@drawable/bg_store_classify_selected" />
</RelativeLayout>

(4).代码调用:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
rcvClassifyTypes.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 temp = rcvClassifyTypes.computeHorizontalScrollRange();
  if (temp > range) {
   range = temp;
  }
  //滑块的偏移量
  int offset = rcvClassifyTypes.computeHorizontalScrollOffset();
  //可视区域长度
  int extent = rcvClassifyTypes.computeHorizontalScrollExtent();
  //滑出部分在剩余范围的比例
  float proportion = (float) (offset * 1.0 / (range - extent));
  //计算滚动条宽度
  float transMaxRange = parentLayout.getWidth() - childline.getWidth();
  //设置滚动条移动
  childline.setTranslationX(transMaxRange * proportion);
 }
});

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/kobe_wharton/article/details/104474669

延伸 · 阅读

精彩推荐
  • AndroidAndroid中使用TextView实现图文混排的方法

    Android中使用TextView实现图文混排的方法

    向TextView或EditText中添加图像比直接添加文本复杂一点点,需要用到标签。接下来通过本文给大家介绍Android中使用TextView实现图文混排的方法,希望对大...

    susu的Dream12412021-05-31
  • AndroidAndroid编程实现圆角边框的方法

    Android编程实现圆角边框的方法

    这篇文章主要介绍了Android编程实现圆角边框的方法,涉及Android针对样式布局的相关设置技巧,具有一定参考借鉴价值,需要的朋友可以参考下...

    Just run11712021-04-09
  • AndroidAndroid实现拍照和录制视频功能

    Android实现拍照和录制视频功能

    这篇文章主要为大家详细介绍了Android实现拍照和录制视频功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    HuangGui9710224952022-02-25
  • AndroidAndroid中监听短信的两种方法

    Android中监听短信的两种方法

    这篇文章主要介绍了Android中监听短信的两种方法,本文讲解了监听广播、采用观察方法,监听短信数据库两种方法,需要的朋友可以参考下...

    安卓之家12532021-03-19
  • Android浅谈Gradle 常用配置总结

    浅谈Gradle 常用配置总结

    这篇文章主要介绍了浅谈Gradle 常用配置总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    叶应是叶8162022-08-01
  • AndroidAndroid使用ViewPager实现左右无限滑动

    Android使用ViewPager实现左右无限滑动

    这篇文章主要为大家详细介绍了Android使用ViewPager实现左右无限滑动,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    mufeng_慕枫8182022-02-24
  • Androidandroid 检测耳机是否插入方法

    android 检测耳机是否插入方法

    在android开发过程中经常会用到检测耳机是否插入的功能,本文将介绍一些方法,可供有需要的朋友参考下...

    Android教程网2802020-12-21
  • Androidandroid WebView加载html5介绍

    android WebView加载html5介绍

    viewport属性放在HTML的meta中接下来看详细代码,感兴趣的你可以参考下本文...

    Android开发网10052021-01-08