1. 概述
这篇文章主要记录下自己在开发过程中,需要交换list集合中相邻两个位置的数据,需求如下:
效果描述如下:
1. 银行卡列表为listview,数据为list集合;
2. 需要实现点击向下箭头交换当前位置数据和下一个位置数据,点击向上箭头交换当前位置数据和上一个位置数据;
3. 需要使用ArrayList中的 remove和add 方法实现 上移下移list集合中相邻两个位置的数据;
2. 上移思路如下
1. 根据当前位置 curPosition,从itemList集合中获取到 curPosition 对应的数据 upFirst;
2. 根据上一个位置 curPosition-1,从itemList集合中获取到 curPosition-1 对应的数据 upSecond;
3. 从 itemList集合中 移除 当前位置 curPosition;
4. 从 itemList集合中 移除 上一个位置 curPosition-1;
5. 实现上移效果:调用add方法,把 upFirst数据添加到 上一个位置 curPosition-1;
6. 实现上移效果:调用add方法,把 upSecond数据添加到 当前位置 curPosition;
7. 此时上移效果代码已经写完,需要把 curPosition-1位置 重新设置为当前位置 currentPosition;
8. 调用adapter的 refresh方法,把 上移后重新设置的当前位置 currentPosition 传递给 refresh方法,
刷新数据即可;
3. 下移思路如下
1. 根据当前位置 curPosition,从itemList集合中获取到 curPosition 对应的数据 downFirst;
2. 根据下一个位置 curPosition+1,从itemList集合中获取到 curPosition+1 对应的数据 downSecond;
3. 从 itemList集合中 移除 当前位置 curPosition+1;
4. 从 itemList集合中 移除 下一个位置 curPosition;
5. 实现下移效果:调用add方法,把 downSecond数据添加到 当前位置 curPosition;
6. 实现下移效果:调用add方法,把 downFirst数据添加到 上一个位置 curPosition+1;
7. 此时下移效果代码已经写完,需要把 curPosition+1位置 重新设置为当前位置 currentPosition;
8. 调用adapter的 refresh方法,把 下移后重新设置的当前位置 currentPosition 传递给 refresh方法,
刷新数据即可;
3. 上移分析图
4. 下移分析图
4. 代码如下
/**
* Email: 2185134304@qq.com
* Created by Novate 2018/8/21 9:42
* Version 1.0
* Params:
* Description: 默认付款方式
*/
public class DefaultPayStyleActivity extends BaseActivity implements ChangeAdapter.Callback {
private ListView lv;
private ChangeAdapter adapter;
private ArrayList<String> itemList;
private int currentPosition = -1;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_default_pay_style);
}
@Override
public void initView() {
lv = (ListView) findViewById(R.id.lv_change);
initDatas() ;
adapter = new ChangeAdapter(this, itemList, this, currentPosition);
lv.setAdapter(adapter);
}
private void initDatas() {
itemList = new ArrayList<String>();
itemList.add("余额宝");
itemList.add("蚂蚁花呗");
itemList.add("余额");
itemList.add("工商银行储蓄卡(1689)");
itemList.add("花呗分期");
}
/**
* ChangeAdapter中的3个点击事件
* 1. 整个item点击事件的处理逻辑
* 2. 向上图标按键点击事件的处理逻辑
* 3. 向下图标按键点击事件的处理逻辑
*/
@Override
public void click(View v) {
int curPosition;
int mCurPosition;
switch (v.getId()){
//整个item点击事件的处理逻辑
case R.id.item:
// 通过getTag(key)方法, 强制类型转换获取该item的position,然后调用refresh()方法通知adapter当前position数据更新了,
// 然后adapter就会根据 currentPosition处理向上向下箭头的显示与隐藏
mCurPosition = (int) v.getTag(R.id.tag_item_click);
currentPosition = mCurPosition;
adapter.refresh(currentPosition);
break;
//向上图标按键点击事件的处理逻辑
case R.id.up:
// 调用getTag获取点击的position,调换当前位置与上一个位置的数据值,就实现了item上移效果,
// 对于第一个item,不处理上移,然后调用refresh()方法刷新数据即可
curPosition = (int) v.getTag();
if (curPosition != 0) {
String upFirst = itemList.get(curPosition); // 当前item位置对应数据
String upSecond = itemList.get(curPosition - 1); // 上一个位置数据值
itemList.remove(curPosition);
itemList.remove(curPosition - 1);
itemList.add(curPosition - 1, upFirst);
itemList.add(curPosition, upSecond);
currentPosition = curPosition - 1;
adapter.refresh(currentPosition);
}
break;
//向下图标按键点击事件的处理逻辑
case R.id.down:
// 调用getTag获取点击的position,调用当前位置与下一个位置的数据值,就实现item下移效果,
// 对于最后一个item,不处理下移,然后调用refresh()方法刷新数据即可
curPosition = (int) v.getTag();
if (curPosition != itemList.size() - 1) {
String downFirst = itemList.get(curPosition);
String downSecond = itemList.get(curPosition + 1);
itemList.remove(curPosition + 1);
itemList.remove(curPosition);
itemList.add(curPosition, downSecond);
itemList.add(curPosition + 1, downFirst);
currentPosition = curPosition + 1;
adapter.refresh(currentPosition);
}
break;
default:
break;
}
}
}