热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

androidview实现横向滑动选择

这篇文章主要为大家详细介绍了androidview实现横向滑动选择,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了android view实现横向滑动选择的具体代码,供大家参考,具体内容如下

做文字编辑,从网上找来的。

HorizontalScrollSelectView:

  public boolean mAlwaysOverrideTouch = true;
  protected ListAdapter mAdapter;
  private int mLeftViewIndex = -1;
  private int mRightViewIndex = 0;
  protected int mCurrentX;
  protected int mNextX;
  private int mMaxX = Integer.MAX_VALUE;
  private int mDisplayOffset = 0;
  protected Scroller mScroller;
  private GestureDetector mGesture;
  private Queue mRemovedViewQueue = new LinkedList();
  private OnItemSelectedListener mOnItemSelected;
  private OnItemClickListener mOnItemClicked;
  private OnItemLongClickListener mOnItemLongClicked;
  private OnScrollListener mScrollListener;
  /**
   * 选中item时图片
   */
  private Drawable mDrawable;
  private boolean mDataChanged = false;
  private Context context;
  private boolean scrollerFalg1 = false;
  private boolean scrollerFalg2 = false;
  private int position = 0x7f020000;
 
 
  public HorizontalScrollSelectView(Context context, AttributeSet attrs) {
    super(context, attrs);
    this.cOntext= context;
    initView();
  }
 
  private synchronized void initView() {
    mLeftViewIndex = -1;
    mRightViewIndex = 0;
    mDisplayOffset = 0;
    mCurrentX = 0;
    mNextX = 0;
    mMaxX = Integer.MAX_VALUE;
    mScroller = new Scroller(getContext());
    mGesture = new GestureDetector(getContext(), mOnGesture);
  }
 
  public void setMScrollListener(OnScrollListener listener) {
    mScrollListener = listener;
  }
 
  @Override
  public void setOnItemSelectedListener(OnItemSelectedListener listener) {
    mOnItemSelected= listener;
  }
 
  @Override
  public void setOnItemClickListener(OnItemClickListener listener) {
    mOnItemClicked= listener;
  }
 
  @Override
  public void setOnItemLongClickListener(OnItemLongClickListener listener) {
    mOnItemLongClicked= listener;
  }
 
  /**
   * 设置选中状态时的图片
   *
   * @param mDrawable
   */
  public void setSelectBitmap(Drawable mDrawable) {
    this.mDrawable = mDrawable;
  }
 
  private DataSetObserver mDataObserver = new DataSetObserver() {
 
    @Override
    public void onChanged() {
      synchronized (HorizontalScrollSelectView.this) {
        mDataChanged = true;
      }
      invalidate();
      requestLayout();
    }
 
    @Override
    public void onInvalidated() {
      reset();
      invalidate();
      requestLayout();
    }
 
  };
 
  @Override
  public ListAdapter getAdapter() {
    return mAdapter;
  }
 
  @Override
  public View getSelectedView() {
    //TODO: implement
    return null;
  }
 
  @Override
  public void setAdapter(ListAdapter adapter) {
    if (mAdapter != null) {
      mAdapter.unregisterDataSetObserver(mDataObserver);
    }
    mAdapter = adapter;
    mAdapter.registerDataSetObserver(mDataObserver);
    reset();
  }
 
  private synchronized void reset() {
    initView();
    removeAllViewsInLayout();
    requestLayout();
  }
 
  @Override
  public void setSelection(int position) {
    //TODO: implement
    int positiOnX= position * this.getWidth();
    int maxWidth = this.getChildCount() * this.getWidth();
    if (positionX <= 0) {
      positiOnX= 0;
    }
    if (positionX > maxWidth) {
      positiOnX= maxWidth;
    }
    scrollTo(positionX);
  }
 
  private void addAndMeasureChild(final View child, int viewPos) {
    LayoutParams params = child.getLayoutParams();
    if (params == null) {
      params = new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT);
    }
 
    addViewInLayout(child, viewPos, params, true);
    child.measure(MeasureSpec.makeMeasureSpec(getWidth(), MeasureSpec.AT_MOST),
        MeasureSpec.makeMeasureSpec(getHeight(), MeasureSpec.AT_MOST));
  }
 
 
  @SuppressLint("NewApi")
  @Override
  protected synchronized void onLayout(boolean changed, int left, int top, int right, int bottom) {
    super.onLayout(changed, left, top, right, bottom);
 
    if (mAdapter == null) {
      return;
    }
 
    if (mDataChanged) {
      int oldCurrentX = mCurrentX;
      initView();
      removeAllViewsInLayout();
      mNextX = oldCurrentX;
      mDataChanged = false;
    }
 
    if (mScroller.computeScrollOffset()) {
      int scrollx = mScroller.getCurrX();
      mNextX = scrollx;
    }
 
// if(mNextX <= 0){
//  mNextX = 0;
//  mScroller.forceFinished(true);
// }
// if(mNextX >= mMaxX) {
//  mNextX = mMaxX;
//  mScroller.forceFinished(true);
// }
 
    int dx = mCurrentX - mNextX;
 
    removeNonVisibleItems(dx);
    fillList(dx);
    positionItems(dx);
// Log.e("onlayout", "mLeftViewIndex"+(mLeftViewIndex+1));
    mCurrentX = mNextX;
 
    if (!mScroller.isFinished()) {
      post(new Runnable() {
        @Override
        public void run() {
          requestLayout();
        }
      });
 
    } else {
      if (scrollerFalg1 || (!scrollerFalg1 && scrollerFalg2)) {
        View chid = getChildAt(0);
        if (chid != null) {
          mDisplayOffset = 0;
          positionItems(0);
          if (mDrawable != null) {
            getChildAt(2).setBackground(mDrawable);
          }
          if (mScrollListener != null) {
            int position = (int) getChildAt(2).getTag(this.position);
            mScrollListener.onScrollSelectItem(this, position);
          }
        }
 
      }
    }
 
 
  }
 
  /**
   * 获取屏幕宽度
   *
   * @param context
   * @return
   */
  public static int getSecreenWidth(Context context) {
    DisplayMetrics dm = new DisplayMetrics();
    dm = context.getResources().getDisplayMetrics();
    int screenWidth = dm.widthPixels;
    return screenWidth / 5;
  }
 
  private void fillList(final int dx) {
    int edge = 0;
    View child = getChildAt(0);
    if (child != null) {
      edge = child.getLeft();
    }
    fillListLeft(edge, dx);
 
    edge = 0;
    child = getChildAt(getChildCount() - 1);
    if (child != null) {
      edge = child.getRight();
    }
    fillListRight(edge, dx);
 
  }
 
  private void fillListRight(int rightEdge, final int dx) {
    //&& mRightViewIndex = mAdapter.getCount()) {
        mRightViewIndex = 0;
      }
      View child = mAdapter.getView(mRightViewIndex, mRemovedViewQueue.poll(), this);
      child.setTag(position, mRightViewIndex);
      addAndMeasureChild(child, -1);
      rightEdge += child.getMeasuredWidth();
 
//  if(mRightViewIndex == mAdapter.getCount()-1) {
//  mMaxX = mCurrentX + rightEdge - getWidth();
//  }
//  
//  if (mMaxX <0) {
//  mMaxX = 0;
//  }
      mRightViewIndex++;
    }
 
  }
 
  private void fillListLeft(int leftEdge, final int dx) {
    //&& mLeftViewIndex >= 0
    while (leftEdge + dx > 0) {
      if (mLeftViewIndex <= -1) {
        mLeftViewIndex = mAdapter.getCount() - 1;
      }
      View child = mAdapter.getView(mLeftViewIndex, mRemovedViewQueue.poll(), this);
      child.setTag(position, mLeftViewIndex);
      addAndMeasureChild(child, 0);
      leftEdge -= child.getMeasuredWidth();
      mLeftViewIndex--;
      mDisplayOffset -= child.getMeasuredWidth();
    }
  }
 
  private void removeNonVisibleItems(final int dx) {
    View child = getChildAt(0);
    while (child != null && child.getRight() + dx <= 0) {
      mDisplayOffset += child.getMeasuredWidth();
      mRemovedViewQueue.offer(child);
      removeViewInLayout(child);
      mLeftViewIndex++;
      if (mLeftViewIndex >= mAdapter.getCount()) {
        mLeftViewIndex = 0;
      }
      child = getChildAt(0);
 
    }
 
    child = getChildAt(getChildCount() - 1);
    while (child != null && child.getLeft() + dx >= getWidth()) {
      mRemovedViewQueue.offer(child);
      removeViewInLayout(child);
      mRightViewIndex--;
      if (mRightViewIndex <= -1) {
        mRightViewIndex = mAdapter.getCount() - 1;
      }
      child = getChildAt(getChildCount() - 1);
    }
  }
 
 
  private void positionItems(final int dx) {
    if (getChildCount() > 0) {
      mDisplayOffset += dx;
      int left = mDisplayOffset;
      for (int i = 0; i 

demo截图:

源码下载:android view实现横向滑动选择

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


推荐阅读
  • 猫猫分享,必须精品原文地址:http:blog.csdn.netu013357243articledetails44571163素材地址:http:download.csdn.n ... [详细]
  • Android性能优化检测App卡顿
    在移动APP性能评测-流畅度评测中,我们介绍了如何准确客观评价APP的流畅度,最终采用SM指标来评价应用的流畅度,在知道如何评价流畅度之后 ... [详细]
  • 这一篇主要总结一下jQuery这个js在引入的时候做的一些初始化工作第一句window.undefinedwindow.undefined;是为了兼容低版本的IE而写的因为在低版本 ... [详细]
  • spotify engineering culture part 1
    原文,因为原视频说的太快太长,又没有字幕,于是借助youtube,把原文听&打出来了。中文版日后有时间再翻译。oneofthebigsucceessfactorshereatSpo ... [详细]
  • MyBatis模糊查询和多条件查询一、ISmbmsUserDao层根据姓名模糊查询publicListgetUser();多条件查询publicList ... [详细]
  • 载波|等份_NR SRS时频域位置
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了NRSRS时频域位置相关的知识,希望对你有一定的参考价值。微信同步更新欢迎关注同名modem协议笔记S ... [详细]
  • Mac下Flutter安装AndroidStudio配置
    补一个Mac下Flutter安装AndroidStudio配置(官网地址:https:flutter.devdocsget-startedinstallmacos)1.下载安装包; ... [详细]
  • vscode里的html标签导航的一系列问题
    哈喽,我今天带来的经验是,vscode在18年10月更新后的1.29以后,编辑html文档时,会发现最上面有个类似于HTML标签导航的玩意儿,可能部分同学和我一样不习惯用它们,现在 ... [详细]
  • Android Rxbus事件总线
    我的视频课程:《FFmpeg打造Android万能音频播放器》最近在项目中使用了Rxjava和RxAndroid,确实感觉挺不错的,然后听说可以用RxBus来替换 ... [详细]
  • Illustrator绘制逼真的愤怒的小鸟实例教程
    Illustrator教程: ... [详细]
  • Android 自定义控件基础 canvas paint
    1、首先说一下canvas类:ClassOverviewTheCanvasclassholdsthedrawcalls.Todrawsomething,youne ... [详细]
  • 抓取百万知乎用户设计之实体设计
    一.实体的关系实体是根据返回的Json数据来设计的教育经历方面用户可以有很多教育经理,USER和education是一对多的关系,一个education对应一个education一 ... [详细]
  • iOS之富文本
    之前做项目时遇到一个问题:使用UITextView显示一段电影的简介,由于字数比较多,所以字体设置的很小,行间距和段间距也很小,一大段文字挤在一起看起来很别扭,想要把行间距调大,结 ... [详细]
  • Xib九宫格应用管理使用xib封装一个自定义view的步骤1新建一个继承UIView的自定义view,假设类名叫做(AppView)2新建一个AppView.xib文件来描述 ... [详细]
  • 【自制小工具】代码生成器
    【自制小工具】代码生成器陆陆续续接触过好几款代码生成工具,发现确实好用,但都会有那么点不完善的地方,所以索性就自己做一个吧。界面非常简单,反正是自己用的,简单点用起来也方便上图:左 ... [详细]
author-avatar
87年的第一场雪
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有