1、背景介绍
其实要实现的东西并不算太复杂,类似于QQ那样的ListView横向滑动展现删除控件而已。图示,如下:
2、SwipeListView
介绍一下,我在最开始实现这样的功能的时候,找到的是这样的一个开源控件,名字如标题,地址是:https://github.com/47deg/android-swipelistview
大家可以直接在GitHub上去看,不过这个项目的注释写得可能有些不太清楚,简单列举一些它的属性如下:
swipeFrontView - Required - front view id. 即ListView Item正常显示的控件Id,且必须与Item的布局文件中的控件id一样
swipeBackView - Required - back view id. 手指滑动时显示的,隐藏在FrontView后面,且必须与item的布局文件中控件Id一样
swipeActionLeft - Optional - left swipe action Default: 'reveal' 左滑的动作,默认reveal,即显示BackView,还有dismiss,choice会触发响应的方法。
swipeActionRight - Optional - right swipe action Default: 'reveal' 同上
swipeMode - Gestures to enable or 'none'. Default: 'both' 设置左滑、右滑、都支持
swipeCloseAllItemsWhenMoveList - Close revealed items on list motion. Default: 'true' 当滚动listview时,关闭所有展开的Item,最好不要设置为false,由于item的复用,false存在一些问题。
swipeOpenOnLongPress - Reveal on long press Default: 'true' 长按时触发显示
swipeAnimationTime - item drop animation time. Default: android configuration 动画时间长度
swipeOffsetLeft - left offset 左偏移量
swipeOffsetRight - right offset 右偏移量
使用的代码,XML文件代码如下:
<com.fortysevendeg.swipelistview.SwipeListView
xmlns:swipe="http://schemas.android.com/apk/res-auto"
android:id="@+id/example_lv_list"
android:listSelector="#00000000"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
swipe:swipeFrontView="@+id/front"
swipe:swipeBackView="@+id/back"
swipe:swipeActionLeft="[reveal | dismiss]"
swipe:swipeActionRight="[reveal | dismiss]"
swipe:swipeMode="[none | both | right | left]"
swipe:swipeCloseAllItemsWhenMoveList="[true | false]"
swipe:swipeOpenOnLongPress="[true | false]"
swipe:swipeAnimationTime="[miliseconds]"
swipe:swipeOffsetLeft="[dimension]"
swipe:swipeOffsetRight="[dimension]"
/>
可能接下来会有一个比较容易出错的地方,这里