1. 概述
在开发过程中,有时候会有这样的常见需求,在 ListView或者RecyclerView列表中显示一个列表,然后点击某个item实现单选效果,没有这个demo的截图,自己直接用自己项目中的截图来演示吧,效果是一样的,都是单选效果,望见谅哈。
2. 思路如下
1>:首先定义一个list集合,给lv填充数据;
2>:然后在 MyAdapter中定义一个 setTag(int s,int NaDayPostion)方法,用于标记点击 某个具体位置的item;
3>:然后在 setOnItemClickListener方法中,让mAdapter 调用setTag()方法,
mAdapter.setTag(2, position):表示给 adapter设置绑定,表示你点击某个具体的item;
mAdapter.notifyDataSetChanged():刷新数据;
4>:然后在 MyAdapter中的 getView()方法中:
在 if中判断:
如果tag标记为自己传递的2,并且NowDay为position,就给 item最右边设置选中的对号图标,
然后用 SP保存 一个key和选中的 postion;
在 else中:
可以对最右边图标设置没有选中的图标,,也可以让图标隐藏,都是可以的;
5>:然后在 MainActivity中的 onResume()中,从 SP中 取出在 getView()中存储的 key和position,然后重新调用:
mAdapter.setTag(2, position),用于给 adapter设置绑定,表示你点击某个具体item,
mAdapter.notifyDataSetChanged();表示刷新数据;
3. 代码如下
1>:MainActivity代码如下:
/**
* Email: 2185134304@qq.com
* Created by Novate 2018/7/28 11:37
* Version 1.0
* Params:
* Description:
*/
public class MainActivity extends AppCompatActivity {
private List<String> mData = new ArrayList<>();
private ListView mListView;
private MyAdapter mAdapter;
@Override
protected void onResume() {
super.onResume();
String mKey = PrefUtils.getString(MainActivity.this , "key" , "") ;
String position = PrefUtils.getString(MainActivity.this , "position" , "") ;
Log.e("TAG" , "mKey: " + mKey + ", position: " + position) ;
if (!TextUtils.isEmpty(mKey) && "Y".equals(mKey)){
if (!TextUtils.isEmpty(position)) {
mAdapter.setTag(2, Integer.parseInt(position)); //给adapter设置绑定 , 表示你点击某个具体的item
mAdapter.notifyDataSetChanged();//刷新数据
}
}
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mListView = (ListView) findViewById(R.id.listView);
//添加数据
for (int i = 0; i < 30; i++) {
mData.add("" + i);
}
//适配MyAdapter数据
mAdapter = new MyAdapter(this, mData);
mListView.setAdapter(mAdapter);
//点击 listview
mListView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view,
int position, long id) {
mAdapter.setTag(2, position); //给adapter设置绑定 , 表示你点击某个具体的item
mAdapter.notifyDataSetChanged(); //刷新数据
Toast.makeText(MainActivity.this , "点击了"+mData.get(position) , Toast.LENGTH_SHORT).show();
// lastPostion = position; //将当前位置 置为最后一个位置
}
});
}
}
2>:MyAdapter代码如下:
/**
* Email: 2185134304@qq.com
* Created by Novate 2018/7/28 11:39
* Version 1.0
* Params:
* Description:
*/
public class MyAdapter extends BaseAdapter {
private List<String> mData;
private Context mContext;
private LayoutInflater mInflater;
private int tag;
private int NowDay;
public MyAdapter(Context context, List<String> data) {
this.mContext = context;
this.mData = data;
mInflater = LayoutInflater.from(mContext);
}
@Override
public int getCount() {
return mData.size();
}
@Override
public Object getItem(int position) {
return mData.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
public void setTag(int s,int NaDayPostion){
tag=s;
NowDay=NaDayPostion;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
if (convertView == null) {
holder = new ViewHolder();
convertView = mInflater.inflate(R.layout.list_item, null);
holder.mImageView = (ImageView) convertView.findViewById(R.id.image);
holder.iv_check = (ImageView) convertView.findViewById(R.id.iv_check);
holder.mTextView = (TextView) convertView.findViewById(R.id.tvContent);
convertView.setTag(holder);
}else {
holder = (ViewHolder) convertView.getTag();
}
holder.mTextView.setText("我是:" + mData.get(position));
if(tag==2&&NowDay==position){
// holder.iv_check.setVisibility(View.VISIBLE);
holder.iv_check
.setImageResource(R.mipmap.checkedaddress); //选中地址的图片
// holder.mTextView
// .setTextColor(mContext.getResources().getColor(R.color.colorAccent));
PrefUtils.putString(mContext , "key" , "Y");
PrefUtils.putString(mContext , "position" , position+"");
}else{
// holder.iv_check.setVisibility(View.GONE);
holder.iv_check
.setImageResource(R.mipmap.nocheckedaddress);//没有选中的图片
}
return convertView;
}
class ViewHolder {
ImageView mImageView , iv_check;
TextView mTextView;
}
}