返回顶部
首页 > 资讯 > 移动开发 >Android实现网易Tab分类排序控件实现
  • 909
分享到

Android实现网易Tab分类排序控件实现

tab排序Android 2022-06-06 01:06:07 909人浏览 泡泡鱼
摘要

先看看效果图: 1、XML布局引入 <com.net168.lib.SortTabLayout Android:id="@+id/layout" androi

先看看效果图:

1、XML布局引入


<com.net168.lib.SortTabLayout
  Android:id="@+id/layout"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  />

2、设置数据源数据,也就是每个item的对应文本数据


//构造数据源,暂时仅支持String
List<String> data = new ArrayList<String>();
for (int i = 0; i < 20; i ++) {
  data.add("item" + i);
}
//设置数据源
vSortLayout.setShowData(data, 1);

3、设置监听,用于交互点击和长按的事件


vSortLayout.setOnSelectListener(new onSelectListener() {
  //点击事件,点击Tab布局里面的item触发
  @Override
  public void onSelect(View v, int index) {
    Toast.makeText(MainActivity.this, "你点击了item ,内容为:" + ((TextView)v).getText(), Toast.LENGTH_SHORT).show();
  }
  //长按事件,长按Tab布局里面的item触发
  @Override
  public void onLongSelect(View v) {
    Toast.makeText(MainActivity.this, "长按Tab,开始排列", Toast.LENGTH_SHORT).show();
  }
});

4、开始排序和结束排序的接口


//如果参数是true的话,开始排序,也就是可以拖动
vSortLayout.setIsMoveList(true);
//结束排序,并且会返回选择tab的当前新位置
vSortLayout.getAndFinishSortData();

未完善的自定义功能

1、现在仅仅是支持String,并且布局也无法自定义,后续可能会完善Tab的item的View的自定义输入

2、现在布局的行数和间距由硬代码控制,并没有形成简便易懂的接口暴漏

PS:调试间距的方法,主要调试下列几个参数



private final int mMaxRow = 4;
private final int mRowMagin = 5;
private final int mRowWidth = 26;
private final int mColumnMagin = 4;
private final int mColumnHeight = 10;

3、回滚不流畅,后期可以引入Scroller来控制缓慢回滚

实现原理

1、布局item排序采用基于ViewGroup的自定义布局,在onLayout的方法逻辑根据配置参数区域的参数进行计算配置


@Override
protected void onLayout(boolean arg0, int arg1, int arg2, int arg3, int arg4) {
  final int childCount = getChildCount();
  int row = 0;
  int column = 0;
  int startWidth = 0;
  int startHeight = 0;
  for (int i = 0; i < childCount; i++) {
    View childeView = childList.get(i);
    row = i / 4;
    column = i % 4;
    startWidth = (int) ((column * (mRowWidth + 2 * mRowMagin) + mRowMagin) * mChildeItemSize);
    startHeight = (int) ((row * (mColumnHeight + 2 * mColumnMagin) + mColumnMagin) * mChildeItemSize);
    childeView.layout(startWidth ,startHeight ,(int)(startWidth + mRowWidth * mChildeItemSize),
         (int)(startHeight + mColumnHeight * mChildeItemSize));
  }
}

2、滑动模块部分,在onTouchEvent里面根据坐标的捕获,有坐标分析出对应的子Item,利用View.layout()方法让拖动的View跟随手指移动,参加代码


private void moveChildView(float x, float y) {
  if (mMoveChildView != null) {
    int left = (int) (((mChildIndex % 4) * (mRowWidth + 2 * mRowMagin) + mRowMagin) * mChildeItemSize);
    int top = (int) (((mChildIndex / 4) * (mColumnHeight + 2 * mColumnMagin) + mColumnMagin) * mChildeItemSize);
    int width = (int) (left + mRowWidth * mChildeItemSize);
    int heigth = (int) (top + mColumnHeight * mChildeItemSize);
    int moveX = (int) (x - beginX);
    int moveY = (int) (y - beginY);
    mMoveChildView.layout(left + moveX, top + moveY, width + moveX, heigth + moveY);
    mMoveChildView.invalidate();
  }
}

3、动画模块,由于考虑低版本和不想引入过多的开源库,故采用普通的动画实现
具体参见beginAnimation(final int start,final int end, boolean forward)方法。

4、整体流程

a、Touch的down事件,捕捉当前的x、y数据,计算出被移动的View的所对应index,并且其余view开始抖动动画

b、move事件,将被选中的view根据x、y利用layout方法进行跟随手指移动

c、up事件,执行位置调整动画,并且在调整完毕后,进行新位置的设置

完整代码:https://GitHub.com/ganchuanpu/SortTabLayout.git

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

您可能感兴趣的文章:Android仿京东分类模块左侧分类条目效果Android使用Scroll+Fragment仿京东分类效果Android 仿京东、拼多多商品分类页的示例代码Android使用分类型RecyclerView仿各大商城首页Android编程实现仿美团或淘宝的多级分类菜单效果示例【附demo源码下载】android使用 ScrollerView 实现 可上下滚动的分类栏实例Android 仿网易新闻客户端分类排序功能Android学习教程之分类侧滑菜单(5)Android实现qq列表式的分类悬浮提示Android实现京东App分类页面效果


--结束END--

本文标题: Android实现网易Tab分类排序控件实现

本文链接: https://lsjlt.com/news/21976.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Android实现网易Tab分类排序控件实现
    先看看效果图: 1、XML布局引入 <com.net168.lib.SortTabLayout android:id="@+id/layout" androi...
    99+
    2022-06-06
    tab 排序 Android
  • 怎么在Android项目中实现一个Tab分类排序控件
    怎么在Android项目中实现一个Tab分类排序控件?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。XML布局引入<com.net168.lib.SortTabLayout...
    99+
    2023-05-31
    android tab roi
  • Android 仿网易新闻客户端分类排序功能
    先来看看网易新闻客户端以及自己实现的效果图,效果当然还是网易的好 gridviewsort.gif 如何实现拖拽一个Item 用WindowManager添加一个Image...
    99+
    2022-06-06
    客户端 网易新闻 分类 网易 排序 Android
  • Android实现类似iOS分栏控制器
    近公司接了一个项目,需要会安卓,人手不够的情况作为一个开发iOS的也需要跟进,开始学习android,集成开发环境以后。直接就被难到了,iOS里面的分栏控制器(tabbarcontr...
    99+
    2024-04-02
  • android自定义控件实现简易时间轴(2)
    这篇做了一个简单的时间轴控件。右侧的数据就是一个简单的字符串。问题还是有的,当右侧的文字长度不一样的时候就会有问题了。现在可以修改一下适配右侧的文字。 效果如下: 代码: priv...
    99+
    2024-04-02
  • android自定义控件实现简易时间轴(1)
    本文实例为大家分享了android自定义控件实现简易时间轴的具体代码,供大家参考,具体内容如下 之前项目需要写一个消费记录,类似于时间轴似的控件,自身在自定义控件这里不咋地(&hel...
    99+
    2024-04-02
  • 基于jQuery排序及应用实现Tab栏特效
    目录一、jQuery排序二、index()方法三、应用:Tab栏特效中的排他一、jQuery排序 eq()排序,可以看作是一个筛选方法 jQuery 中获得的对象,内部包含选择的一组...
    99+
    2024-04-02
  • 基于jQuery排序及怎么实现Tab栏特效
    今天小编给大家分享一下基于jQuery排序及怎么实现Tab栏特效的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、jQuer...
    99+
    2023-06-29
  • Python实现简易信息分类存储软件
    时间紧任务重,女神提出的要求有模棱两可,只能自己考虑各种情况,除了用python还有谁能这么短的时间搞出来。 程序界面,增删改查不能少,后悔药也需要给女神准备上,由于最后需要打包给...
    99+
    2024-04-02
  • Android控件TextView的实现原理分析
      我们以窗口为单位,分析了WindowManagerService服务的实现。同时,在再前面一个系列的文章中,我们又分析了窗口的组成。简单来说,窗口是由一系列的视图按照一...
    99+
    2022-06-06
    Android
  • Android实现Neumorphism UI控件
    目录效果图第三方库支持代码示例引入第三方库黑暗模式布局明亮风格文档说明(案例)总结效果图 第三方库支持 Github:https://github.com/fornewid/n...
    99+
    2024-04-02
  • android自定义控件如何实现简易时间轴
    这篇“android自定义控件如何实现简易时间轴”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“android自定义控件如何实现简易时间轴”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过...
    99+
    2023-06-28
  • MyBatisPlus分页时排序的实现
    目录简介建库建表依赖配置代码EntityServiceController测试简介 说明 本文用示例介绍MyBtisPlus分页时排序的方法。 分页时排序的方法 后端OrderIte...
    99+
    2024-04-02
  • Android中实现HashMap排序的方法
    HashMap排序是数据结构与算法中常见的一种排序算法。本文即以Android平台为例来实现该算法。 具体代码如下: public static void main(Stri...
    99+
    2022-06-06
    方法 hashmap Android
  • android自定义控件是怎么实现简易时间轴
    这篇文章主要为大家分析了android自定义控件是怎么实现简易时间轴的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“android自定义控件是怎么实现简易时间...
    99+
    2023-06-28
  • drupal按分类进行文章排序的实现方法
    本文实例讲述了drupal按分类进行文章排序的实现方法。分享给大家供大家参考。具体实现方法如下: Drupal的文章组织形式,决定了其文章排序是一件比较麻烦的事。由于Drupal中没有“栏目”这样...
    99+
    2022-06-12
    drupal 按分类 文章 排序 方法
  • Python如何实现简易信息分类存储软件
    Python如何实现简易信息分类存储软件,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。时间紧任务重,女神提出的要求有模棱两可,只能自己考虑各种情况,除了用python还有谁...
    99+
    2023-06-22
  • C#冒泡排序的类库的实现
    本篇内容主要讲解“C#冒泡排序的类库的实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#冒泡排序的类库的实现”吧!直接在c#中建立类库,类中可以实现不同的方法和属性;直接编码,无需右键单击类...
    99+
    2023-06-17
  • MyBatisPlus如何实现分页时排序
    这篇文章将为大家详细讲解有关MyBatisPlus如何实现分页时排序,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。简介说明本文用示例介绍MyBtisPlus分页时排序的方法。分页时排序的方法后端Order...
    99+
    2023-06-29
  • Android实现控件拖动效果
    本文实例为大家分享了Android实现控件拖动效果的具体代码,供大家参考,具体内容如下 1.今天突然想到做个实现个控件拖动效果,就来试试,一查原来还是很简单的 2.原理就是实现OnT...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作