Android 中通过ViewDragHelper实现ListView的Item的侧拉划出效果

先来看看,今天要实现的自定义控件效果图:

关于ViewDragHelper的使用,大家可以先看这篇文章ViewDragHelper的使用介绍

实现该自定义控件的大体步骤如下:

1.ViewDragHelper使用的3部曲,初始化ViewDragHelper,传递触摸事件,实现ViewDragHelper.Callback抽象类.

2.需要创建2个直接的子View,分别是前景View和背景View,代表ListView每一项Item的布局的组成,如下所示:

未划出时显示的FrontView:

划出后的右边显示BackView:

以上2部分就是该自定义控件要包含的2个直接子View.

3.需要获取FrontView的宽高,宽度其实就是屏幕的宽度,高度就是ListView每一项Item的高度;还需获取BackView的宽度,因为这个宽度就是侧滑的最大范围.

4.需要确定FrontView和BackView的初始位置,在onLayout方法中确定,即默认情况下是只显示FrontView的.这个实现起来也很简单,FrontView的left=0,BackView的left=FrontView的right即可.

5.需要同步FrontView和BackView的滑动,即滑动FrontView的时候BackView也需要跟着划出,同样滑动BackView的时候也需要FrontView跟着滑动.

6.需要解决侧拉划出的效果是否有动画效果.平滑滑动的动画可以通过ViewDragHelper轻松实现.

好了,直接上自定义的SwipeLayout源码:

/**
 * Created by mChenys on 2015/12/26.
 */
public class SwipeLayout extends FrameLayout {
  private ViewDragHelper.Callback mCallback;
  private ViewDragHelper mDragHelper;
  private View mBackView; //item的侧边布局
  private View mFrontView;//当前显示的item布局
  private int mWidth; //屏幕的宽度,mFrontView的宽度
  private int mHeight; //mFrontView的高度
  private int mRange;//mFrontView侧拉时向左移动的最大距离,即mBackView的宽度
  public SwipeLayout(Context context) {
    this(context, null);
  }
  public SwipeLayout(Context context, AttributeSet attrs) {
    this(context, attrs, 0);
  }
  public SwipeLayout(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
    init();
  }
  //1.初始ViewDragHelper
  private void init() {
    mCallback = new ViewDragHelper.Callback() {
      //3.在回调方法中处理触摸事件
      @Override
      public boolean tryCaptureView(View child, int pointerId) {
        return true; //允许所有子控件的滑动
      }
      //设定滑动的边界值
      @Override
      public int clampViewPositionHorizontal(View child, int left, int dx) {
        if (child == mFrontView) {
          //前景View的滑动范围是(0~ -mRange)
          if (left > 0) {
            left = 0;
          } else if (left < -mRange) {
            left = -mRange;
          }
        }
        if (child == mBackView) {
          //背景View的滑动范围是(mWidth - mRange ~ mWidth)
          if (left > mWidth) {
            left = mWidth;
          } else if (left < (mWidth - mRange)) {
            left = mWidth - mRange;
          }
        }
        //返回修正过的建议值
        return left;
      }
      //监听View的滑动位置的改变,同步前景View和背景View的滑动事件
      @Override
      public void onViewPositionChanged(View changedView, int left, int top, int dx, int dy) {
        if (changedView == mFrontView) {
          //当滑动前景View时,也需要滑动背景View
          mBackView.offsetLeftAndRight(dx);
        } else if (changedView == mBackView) {
          //当滑动背景View时,也需要滑动前景View
          mFrontView.offsetLeftAndRight(dx);
        }
        // 兼容老版本
        invalidate();
      }
      //处理释放后的开启和关闭动作
      @Override
      public void onViewReleased(View releasedChild, float xvel, float yvel) {
        if (xvel < 0) {
          //有向左滑动的速度,则打开
          open();
        } else if (xvel == 0 && mFrontView.getLeft() < -mRange / 2.0f) {
          //前景View向左滑动的left小于背景View宽度一半的负值时,打开
          open();
        } else {
          //其他情况为关闭
          close();
        }
      }
    };
    mDragHelper = ViewDragHelper.create(this, mCallback);
  }
  //2.传递触摸事件
  @Override
  public boolean onInterceptTouchEvent(MotionEvent ev) {
    return mDragHelper.shouldInterceptTouchEvent(ev);
  }
  @Override
  public boolean onTouchEvent(MotionEvent event) {
    try {
      mDragHelper.processTouchEvent(event);
    } catch (Exception e) {
      e.printStackTrace();
    }
    return true;
  }
  //获取子控件的引用
  @Override
  protected void onFinishInflate() {
    super.onFinishInflate();
    mBackView = getChildAt(0); //获取背景View,即展示数据的Item的右边隐藏的侧滑布局
    mFrontView = getChildAt(1);//获取前景View,即展示数据的Item
  }
  //获取子控件的相关宽高信息
  @Override
  protected void onSizeChanged(int w, int h, int oldw, int oldh) {
    super.onSizeChanged(w, h, oldw, oldh);
    mWidth = mFrontView.getMeasuredWidth();
    mHeight = mFrontView.getMeasuredHeight();
    mRange = mBackView.getMeasuredWidth();
  }
  //确定子控件的初始位置
  @Override
  protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
    super.onLayout(changed, left, top, right, bottom);
    layoutChildView(false);
  }
  /**
   * 放置子控件的位置
   *
   * @param isOpen 是否是打开前景View,true打开,false关闭
   */
  private void layoutChildView(boolean isOpen) {
    //计算前景View的位置,将坐标信息封装到矩形中
    Rect fontRect = computerFontViewRect(isOpen);
    //摆放前景View
    mFrontView.layout(fontRect.left, fontRect.top, fontRect.right, fontRect.bottom);
    //摆放背景View,left坐标是前景View的right坐标
    int left = fontRect.right;
    mBackView.layout(left, 0, left + mRange, mHeight);
    //由于上面是后摆放背景View,所以会覆盖前景View,因此需要通过下面的方式将前景View显示在前面
    bringChildToFront(mFrontView);
  }
  /**
   * 计算前景View的坐标
   *
   * @param isOpen 是否是打开前景View
   * @return
   */
  private Rect computerFontViewRect(boolean isOpen) {
    int left = isOpen ? -mRange : 0;
    return new Rect(left, 0, left + mWidth, mHeight);
  }
  /**
   * 打开侧边栏mBackView,默认平滑打开
   */
  public void open() {
    open(true);
  }
  /**
   * 打开侧边栏mBackView
   *
   * @param isSmooth 是否平滑打开
   */
  public void open(boolean isSmooth) {
    if (isSmooth) {
      if (mDragHelper.smoothSlideViewTo(mFrontView, -mRange, 0)) {
        //动画在继续
        ViewCompat.postInvalidateOnAnimation(this);
      }
    } else {
      layoutChildView(true);
    }
  }
  /**
   * 关闭侧边栏mBackView,默认平滑关闭
   */
  public void close() {
    close(true);
  }
  /**
   * 关闭侧边栏mBackView
   *
   * @param isSmooth 是否平滑关闭
   */
  public void close(boolean isSmooth) {
    if (isSmooth) {
      if (mDragHelper.smoothSlideViewTo(mBackView, mWidth, 0)) {
        //动画在继续
        ViewCompat.postInvalidateOnAnimation(this);
      }
    } else {
      layoutChildView(false);
    }
  }
  @Override
  public void computeScroll() {
    super.computeScroll();
    if (mDragHelper.continueSettling(true)) {
      //动画还在继续
      ViewCompat.postInvalidateOnAnimation(this);
    }
  }
} 

如何使用呢?

使用该控件,必须要让其有2个直接的子控件,如下布局所示:

<?xml version="1.0" encoding="utf-8"?>
<mchenys.net.csdn.blog.myswipelayout.view.SwipeLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/sl"
  android:layout_width="match_parent"
  android:layout_height="60dp"
  android:minHeight="60dp"
  android:background="#44000000" >
  <!--后置布局-->
  <LinearLayout
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:orientation="horizontal" >
    <TextView
      android:id="@+id/tv_call"
      android:layout_width="60dp"
      android:layout_height="match_parent"
      android:background="#666666"
      android:gravity="center"
      android:text="Edit"
      android:textColor="#ffffff" />
    <TextView
      android:id="@+id/tv_del"
      android:layout_width="60dp"
      android:layout_height="match_parent"
      android:background="#ff0000"
      android:gravity="center"
      android:text="Delete"
      android:textColor="#ffffff" />
  </LinearLayout>
  <!--前景布局-->
  <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#44ffffff"
    android:gravity="center_vertical"
    android:orientation="horizontal" >
    <ImageView
      android:id="@+id/iv_image"
      android:layout_width="40dp"
      android:layout_height="40dp"
      android:layout_marginLeft="15dp"
      android:src="@drawable/head_1" />
    <TextView
      android:id="@+id/tv_name"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_marginLeft="15dp"
      android:text="Name" />
  </LinearLayout>
</mchenys.net.csdn.blog.myswipelayout.view.SwipeLayout> 

就是这么简单,跑起来就可以用了.不过这个只是定义出了SwipeLayout控件,如果要集成到ListView中,还需要做进一步的处理.
例如实现如下效果:

需要考虑2点:

1.在自定义SwipeLayout控件内需要处理3种状态,打开,关闭,拖拽.

2.需要添加一个侧滑监听接口,用于对外暴露当前SwipeLayout的打开,关闭,拖拽,将要打开,将要关闭这5种情况.接口定义如下所示:

/**
 * 侧拉SwipeLayout的监听
 * Created by mChenys on 2015/12/26.
 */
public interface SwipeViewListener {
  //关闭
  void onClose(SwipeLayout mSwipeLayout);
  //打开
  void onOpen(SwipeLayout mSwipeLayout);
  //正在侧拉
  void onDraging(SwipeLayout mSwipeLayout);
  //开始要去关闭
  void onStartClose(SwipeLayout mSwipeLayout);
  //开始要去开启
  void onStartOpen(SwipeLayout mSwipeLayout);
} 

SwipeLayout的3种状态,用enum表示即定义接收获取SwipeViewListener监听器的方法1

//以下是定义SwipeLayout的打开,关闭,滑动的3种状态
  public enum Status {
    CLOSE, OPEN, DRAGING;
  }
  //默认关闭
  private Status mStatus = Status.CLOSE;
  //滑动的监听器
  private SwipeViewListener mSwipeViewListener;
  //设置监听器
  public void setSwipeViewListener(SwipeViewListener swipeViewListener) {
    mSwipeViewListener = swipeViewListener;
  } 

在onViewPositionChanged方法内添加多一个方法,用于处理拖拽的监听.

/**
   * 处理滑动,打开,关闭的3种情况
   * 在onViewPositionChanged 调用
   */
  private void dispatchSwipeEvent() {
    if (mSwipeViewListener != null) {
      mSwipeViewListener.onDraging(this);
    }
    //记录上一次的状态
    Status preStatus = mStatus;
    //获取当前的状态
    mStatus = getCurrStatus();
    if (preStatus != mStatus && null != mSwipeViewListener) {
      //说明有状态发生变化
      if (mStatus == Status.CLOSE) {
        //关闭
        mSwipeViewListener.onClose(this);
      } else if (mStatus == Status.OPEN) {
        //打开
        mSwipeViewListener.onOpen(this);
      } else if (mStatus == Status.DRAGING) {
        //这里有2中情况,要么要打开,要么要关闭
        if (preStatus == Status.CLOSE) {
          //如果之前是关闭的,那么就是要打开
          mSwipeViewListener.onStartOpen(this);
        } else if (preStatus == Status.OPEN) {
          //如果之前是打开,那么就是要关闭
          mSwipeViewListener.onStartClose(this);
        }
      }
    }
  }
  /**
   * 获取当前的状态
   *
   * @return
   */
  private Status getCurrStatus() {
    int left = mFrontView.getLeft();
    if (left == 0) {
      return Status.CLOSE;
    } else if (left == -mRange) {
      return Status.OPEN;
    }
    return Status.DRAGING;
  } 

最后来看看MainActivity的测试:

public class MainActivity extends AppCompatActivity {
  private List<String> mData = new ArrayList<>();//数据集合
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    //获取数据,注意:Arrays.asList返回的并不是一个java.util.ArrayList,而是一个Arrays类的内部类,该List实现是不能进行增删操作的
    //因此必须再包装一下
    mData = new ArrayList<>(Arrays.asList(Constant.NAME));
    ListView listView = new ListView(this);
    listView.setAdapter(mAdapter);
    setContentView(listView);
  }
  //自定义适配器
  private BaseAdapter mAdapter = new BaseAdapter() {
    //标记当前打开的SwipeLayout的集合
    private List<SwipeLayout> mOpenItem = new ArrayList<>();
    @Override
    public int getCount() {
      return mData.size();
    }
    @Override
    public String getItem(int position) {
      return mData.get(position);
    }
    @Override
    public long getItemId(int position) {
      return position;
    }
    @Override
    public View getView(final int position, View convertView, ViewGroup parent) {
      ViewHolder holder = null;
      if (null == convertView) {
        holder = new ViewHolder();
        convertView = View.inflate(MainActivity.this, R.layout.item_list, null);
        holder.mSwipeLayout = (SwipeLayout) convertView;
        holder.tvName = (TextView) convertView.findViewById(R.id.tv_name);
        holder.tvDel = (TextView) convertView.findViewById(R.id.tv_del);
        holder.tvEdit = (TextView) convertView.findViewById(R.id.tv_edit);
        convertView.setTag(holder);
      } else {
        holder = (ViewHolder) convertView.getTag();
      }
      //设置侧拉监听
      holder.mSwipeLayout.setSwipeViewListener(getSwipeViewListener());
      holder.tvName.setText(getItem(position));
      holder.tvDel.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
          //删除
          mData.remove(position);
          mAdapter.notifyDataSetChanged();
        }
      });
      holder.tvEdit.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
          ToastUtils.showToast(MainActivity.this,"编辑");
        }
      });
      return convertView;
    }
    class ViewHolder {
      TextView tvName, tvDel, tvEdit;
      SwipeLayout mSwipeLayout;
    }
    //获取滑动监听器
    private SwipeViewListener getSwipeViewListener() {
      return new SwipeViewListener() {
        @Override
        public void onClose(SwipeLayout mSwipeLayout) {
          //关闭是移除
          mOpenItem.remove(mSwipeLayout);
          ToastUtils.showToast(MainActivity.this, "关闭");
        }
        @Override
        public void onOpen(SwipeLayout mSwipeLayout) {
          //打开时添加
          mOpenItem.add(mSwipeLayout);
          ToastUtils.showToast(MainActivity.this, "打开");
        }
        @Override
        public void onDraging(SwipeLayout mSwipeLayout) {
        }
        @Override
        public void onStartClose(SwipeLayout mSwipeLayout) {
          ToastUtils.showToast(MainActivity.this, "开始关闭");
        }
        @Override
        public void onStartOpen(SwipeLayout mSwipeLayout) {
          //将要打开时,需要将集合中的之前打开的SwipeLayout统统关闭
          for (SwipeLayout swipeLayout : mOpenItem) {
            swipeLayout.close();
          }
          mOpenItem.clear();//清空集合
          ToastUtils.showToast(MainActivity.this, "开始打开");
        }
      };
    }
  };
} 

总结

以上所述是小编给大家介绍的 Android 中通过ViewDragHelper实现ListView的Item的侧拉划出效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

(0)

相关推荐

  • Android ListView实现单选及多选等功能示例

    本文实例讲述了Android ListView实现单选及多选等功能的方法.分享给大家供大家参考,具体如下: 在项目中也遇到过给ListView的item添加选择功能.比如一个网购APP,有个历史浏览页面,这个页面现点击item单选/多选及全选删除功能. 当时也是通过在数据中添加一个是否选择的字段来记录item的状态,然后根据这个字段有相应的position位置进行选择状态更改及删除操作. 刚刚看了Android API Demos中17种ListView的实现方法,发现ListView自身就带有

  • Android ListView之setEmptyView正确使用方法

    Android ListView之setEmptyView正确使用方法 我们知道ListView组件提供了一个空数据是的视图设置方法setEmptyView,该方法存在一个诟病,就是空视图和listview组件要在一个Parent中,这个就不在此细说,下面说另一个问题,原因其实和前面那个问题同出一辙. 假如emptyView和listview在布局中,已经属于同一个parent,设置EmptyView的代码如下 private void setEmptyView(){ emptyTv.setTe

  • Android编程之ListView和EditText发布帖子隐藏软键盘功能详解

    本文实例讲述了Android编程之ListView和EditText发布帖子隐藏软键盘功能.分享给大家供大家参考,具体如下: 在Android开发中,手动调用软件盘的隐藏和显示有时候也是非常常见的需求. EditText控件实现了点击打开软键盘输入功能,but why ? 为什么EditText可以点击弹出keyboard,而TextView却不可以,EditText继承TextView做了哪些修改呢?关于这些问题得查看相关具体代码如何实现可以参考,看似简单的控件其实系统封装实现的很复杂.这里告

  • Android listview定位到上次显示的位置的实现方法

    Android listview定位到上次显示的位置的实现方法 整体思路:滑动lictview时,记录listview的位置,定位时定位到该位置. 1.添加全局变量 private int scrolledX = 0; private int scrolledY = 0; 2.Oncreate()添加滚动事件监听 ClassesLV.setOnScrollListener(new OnScrollListener() { /** * 滚动状态改变时调用 */ @Override public v

  • Android ListView填充数据的方法

    Android ListView填充数据的方法 因为多人开发,为了是自己开发的模块方便融合到主框架中,同时也为了减小apk的大小,要求尽可能少的使用xml的布局文件,开发中需要在ListView中显示数据,网上查到的几乎所有的示例,都是通过xml文件来为ListView的Item提供布局样式,甚是不方便. 能不能将自己通过代码创建的布局(如View,LinearLayout)等动态的布局到ListView呢?当然可以. 为了给ListView提供数据,我们需要为其设置一个适配,我们可以从Base

  • Android Adapter里面嵌套ListView实例详解

    Android Adapter里面嵌套ListView实例详解 前言: 可嵌套~但是显示需要特殊处理下~以下是处理方法 前几天因为项目的需要,要在一个ListView中放入另一个ListView,也即在一个ListView的每个ListItem中放入另外一个ListView.但刚开始的时候,会发现放入的小ListView会显示不完全,它的高度始终有问题.上网查了下,发现别人也有遇到这样的问题,而大多数人都不推荐这样的设计,因为默认情况下Android是禁止在ScrollView中放入另外的Scr

  • Android 实现ListView的点击变色的实例

    Android 实现ListView的点击变色的实例 我做了一个音乐播放器,其中用ListView显示歌曲列表,当我点击某一首歌时,希望这首歌所在的item的背景颜色改变,以突出显示所选择的歌曲. 首先我想到的是在ItemClickListener里面写,如下: private View formerView=null; private class ListViewClickListener implements OnItemClickListener{ @Override public voi

  • Android ListView中headerview的动态显示和隐藏的实现方法

    Android ListView中headerview的动态显示和隐藏的实现方法 1.动态设置headerview的方法 动态设置headerview有两个思路. 方法一 将header的布局写在list item的布局文件中,在adapter中通过判断position的值是否为0动态控制其显示或隐藏. 代码示例: item.xml布局文件 <?xml version="1.0" encoding="utf-8"?> <LinearLayout x

  • Android 中通过ViewDragHelper实现ListView的Item的侧拉划出效果

    先来看看,今天要实现的自定义控件效果图: 关于ViewDragHelper的使用,大家可以先看这篇文章ViewDragHelper的使用介绍 实现该自定义控件的大体步骤如下: 1.ViewDragHelper使用的3部曲,初始化ViewDragHelper,传递触摸事件,实现ViewDragHelper.Callback抽象类. 2.需要创建2个直接的子View,分别是前景View和背景View,代表ListView每一项Item的布局的组成,如下所示: 未划出时显示的FrontView: 划出

  • Android实现带有边框的ListView和item的方法

    本文实例讲述了Android实现带有边框的ListView和item的方法.分享给大家供大家参考,具体如下: 想为ListView和item四周添加边框有两种方法: 1.贴一张带有边框效果的背景图 2.自定义Draw的方法 第一种方法较第二种方法更耗系统资源,但是用法简单,只需要一张图设置为相应控件的背景即可,而第二种灵活性好些. 这次是实现带有边框的ListView和item,为此写个简单Demo 学习学习 先看下Demo运行效果吧 下面是主要代码,主要是用到Canvas.drawLine(.

  • Android 中使用 ViewPager实现屏幕页面切换和页面轮播效果

    之前关于如何实现屏幕页面切换,写过一篇博文<Android中使用ViewFlipper实现屏幕切换>,相比ViewFlipper,ViewPager更适用复杂的视图切换,而且Viewpager有自己的adapter,这也让其适应复杂对象,实现数据的动态加载. ViewPager是谷歌官方给我们提供的一个兼容低版本安卓设备的软件包,里面包囊了只有在安卓3.0以上可以使用的api.而viewpager就是其中之一,利用它,我们可以做很多事情,从最简单的导航,到页面菜单等等. 下面我们就展示下Vie

  • Android中使用TextView实现高仿京东淘宝各种倒计时效果

    今天给大家带来的是仅仅使用一个TextView实现一个高仿京东.淘宝.唯品会等各种电商APP的活动倒计时.最近公司一直加班也没来得及时间去整理,今天难得休息想把这个分享给大家,只求共同学习,以及自己后续的复习.为什么会想到使用一个TextView来实现呢?因为最近公司在做一些优化的工作,其中就有一个倒计时样式,原来开发的这个控件的同事使用了多个TextView拼接在一起的,实现的代码冗余比较大,故此项目经理就说:小宏这个就交给你来优化了,并且还要保证有一定的扩展性,当时就懵逼了.不知道从何处开始

  • 解析android中隐藏与显示软键盘及不自动弹出键盘的实现方法

    1.//隐藏软键盘    ((InputMethodManager)getSystemService(INPUT_METHOD_SERVICE)).hideSoftInputFromWindow(WidgetSearchActivity.this.getCurrentFocus().getWindowToken(), InputMethodManager.HIDE_NOT_ALWAYS); 2.//显示软键盘,控件ID可以是EditText,TextView    ((InputMethodMa

  • android开发教程之实现listview下拉刷新和上拉刷新效果

    复制代码 代码如下: public class PullToLoadListView extends ListView implements OnScrollListener { private static final String TAG = PullToLoadListView.class.getSimpleName(); private static final int STATE_NON = 0; private static final int STATE_PULL_TO_REFRE

  • Android中自定义View实现圆环等待及相关的音量调节效果

    圆环交替.等待效果 效果就这样,分析了一下,大概有这几个属性,两个颜色,一个速度,一个圆环的宽度. 自定View的几个步骤: 1.自定义View的属性 2.在View的构造方法中获得我们自定义的属性 3.重写onMesure  4.重写onDraw 1.自定义属性: <?xml version="1.0" encoding="utf-8"?> <resources> <attr name="firstColor" f

  • Android中使用PagerSlidingTabStrip实现导航标题的示例

    此开源框架官网地址:https://github.com/astuetz/PagerSlidingTabStrip 可以理解为配合ViewPager使用的交互式页面指示器控件. 话不多说,先上效果图: 为了演示其中的pstsIndicatorHeight与pstsUnderlineHeight 的区别,进行了不同的设置已区分效果(做了去除actionbar处理).大家可以很直观的看出相比之前单独使用ViewPager以及ViewPager与Fragement嵌套,本次演示PagerSliding

  • 详解Android中fragment和viewpager的那点事儿

    在之前的博文<Android 中使用 ViewPager实现屏幕页面切换和页面轮播效果>和<详解Android中Fragment的两种创建方式>以及<Android中fragment与activity之间的交互(两种实现方式)>中我们介绍了ViewPager以及Fragment各自的使用场景以及不同的实现方式. 那如果将他们两结合起来,会不会擦出点火花呢,答案是肯定的.之前在介绍ViewPager时,我们实现了多个ImageView的切换,并配合更新导航原点的状态.那我

  • Android中使用imageviewswitcher 实现图片切换轮播导航的方法

    前面写过了使用ViewFlipper和ViewPager实现屏幕中视图切换的效果(ViewPager未实现轮播)附链接: ANDROID中使用VIEWFLIPPER类实现屏幕切换(关于坐标轴的问题已补充更改) Android 中使用 ViewPager实现屏幕页面切换和页面轮播效果 今天我们在换一种实现方式ImageViewSwitcher. ImageSwitcher是Android中控制图片展示效果的一个控件,如:幻灯片效果 ImageSwitcher粗略的理解就是ImageView的选择器

随机推荐