android 横向滑动分类效果实现

简介: android 横向滑动分类效果实现

image.png

大家看上面的分类栏,我们这个分类数目不固定,要求可以一个一个横向滑动。不是viewPager分页 一屏幕放4个,一滑动一下子显示下一页的4个。当然这种效果一般都是用viewPager实现。实现方法我晚点会写一篇文章链接到这里。


这个横向的列表之前的博客已经写过了用的HorizontalListView,所以这个横向滑动列表的实现 我就不再写一次了 ,感兴趣的可以直接看这篇文章


Android 横向ListView实现

但是用这个实现了列表后,发现这个效果对用户来讲不是特别友好,因为可能一部分用户不知道那个列表是滑动的,所以特意在下面加了两个小圆点

这两个小圆点的添加方式就是监听 横向列表的onTouch事件

  mDocumentCategoryHlv.setOnTouchListener(this);

然后在onTouch事件里面增加判断

让当前类继承 View.OnTouchListener, GestureDetector.OnGestureListener

    private GestureDetector gd = new GestureDetector(this);
    private int FLING_MIN_DISTANCE = 200;// 水平方向手指滑动距离最小值
    private int FLING_MIN_VELOCITY = 0;// 垂直方向手指滑动距离最小值
  @Override
    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
        if (e1.getX() - e2.getX() > FLING_MIN_DISTANCE && Math.abs(velocityX) > FLING_MIN_VELOCITY) {
            //            SingleToast.show(getContext(), "向左手势");
            setTip(2);
        } else if (e2.getX() - e1.getX() > FLING_MIN_DISTANCE && Math.abs(velocityX) > FLING_MIN_VELOCITY) {
            //            SingleToast.show(getContext(), "向右手势");
            setTip(1);
        }
        return false;
    }
    @Override
    public boolean onTouch(View view, MotionEvent motionEvent) {
        return gd.onTouchEvent(motionEvent);
    }

判断滑动状态,给小圆点设置不同图片就实现了上图的效果

  private void setTip(int flag) {
        if (flag == 1) {
            mTipLeftIv.setImageResource(R.drawable.tip_yes);
            mTipRightIv.setImageResource(R.drawable.tip_no);
        } else if (flag == 2) {
            mTipLeftIv.setImageResource(R.drawable.tip_no);
            mTipRightIv.setImageResource(R.drawable.tip_yes);
        }
    }


相关文章
|
Android开发
flutter中实现仿Android端的onResume和onPause方法
flutter中实现仿Android端的onResume和onPause方法
|
Android开发
Android HorizontalScrollView 横向滚动自动居中
Android HorizontalScrollView 横向滚动自动居中
|
Android开发 容器
Android实现面包屑效果,支持Fragment联动
Android实现面包屑效果,支持Fragment联动
|
Android开发
Android实现连线题效果
Android实现连线题效果
|
Android开发
Android实现调用系统相机录像及实现录音
Android实现调用系统相机录像及实现录音
592 0
|
移动开发 JavaScript Android开发
通过howler.js实现在Android下的微信浏览器自动播放音频
通过howler.js实现在Android下的微信浏览器自动播放音频
414 0
通过howler.js实现在Android下的微信浏览器自动播放音频
|
存储 Dart Java
【Flutter】packages思维以及使用Java添加Android平台特定的实现在Flutter框架里的体现和运用
【Flutter】packages思维以及使用Java添加Android平台特定的实现在Flutter框架里的体现和运用
|
缓存 JSON Java
java 实现读取txt文件,反射创建对象,android 手机缓存文件目录
java 实现读取txt文件,反射创建对象,android 手机缓存文件目录
340 1
java 实现读取txt文件,反射创建对象,android 手机缓存文件目录
|
数据库 Android开发
android 多级下拉菜单实现教程 greendao使用
android 多级下拉菜单实现教程 greendao使用
174 0
android 多级下拉菜单实现教程 greendao使用
|
XML 开发工具 Android开发
Android自定义控件(十三)——实现CSDN搜索框文字提示容器
Android自定义控件(十三)——实现CSDN搜索框文字提示容器
267 0
Android自定义控件(十三)——实现CSDN搜索框文字提示容器