ListView与RadioButton组合——自定义单选列表

时间:2021-12-28 07:25:12
 
2013-09-10 11:13 19396人阅读 评论(8) 收藏 举报
ListView与RadioButton组合——自定义单选列表 分类:
Android(19) ListView与RadioButton组合——自定义单选列表

版权声明:本文为博主原创文章,未经博主允许不得转载。

Android自带的RadioButton单选框只支持添加文字,我们自己写Adapter实现自定义的RadioButton

首先item的XML源码

search_user_item.xml (现在只是文字+单选按钮+自定义背景,可以根据需要随意扩展)

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:id="@+id/search_user_list_item"
  4. android:layout_width="fill_parent"
  5. android:layout_height="30dp"
  6. android:layout_marginBottom="10dp"
  7. android:layout_marginTop="10dp"
  8. android:background="@drawable/more_item_press"
  9. android:gravity="center_vertical"
  10. android:orientation="horizontal" >
  11. <TextView
  12. android:id="@+id/search_user_name"
  13. android:layout_width="200dp"
  14. android:layout_height="wrap_content"
  15. android:layout_marginLeft="30dp"
  16. android:gravity="left"
  17. android:textColor="@android:color/black"
  18. android:textSize="16sp" />
  19. <RadioButton
  20. android:id="@+id/radio_btn"
  21. android:layout_width="wrap_content"
  22. android:layout_height="wrap_content"
  23. android:layout_marginLeft="10dp" />
  24. </LinearLayout>

Listview就是用系统自带的

  1. <ListView
  2. android:id="@+id/search_user_list"
  3. android:layout_width="fill_parent"
  4. android:layout_height="200dp"
  5. android:layout_marginLeft="5dp"
  6. android:layout_marginRight="5dp"
  7. android:paddingBottom="5dp"
  8. android:cacheColorHint="@android:color/transparent"
  9. android:divider="@null"
  10. android:listSelector="@android:color/transparent"
  11. android:visibility="gone" >
  12. </ListView>

再来是Adapter代码

SearchUserAdapter.java (具体改动写在代码注释里面)

  1. package ouc.sei.suxin.android.ui.adapter;
  2. import java.util.HashMap;
  3. import java.util.List;
  4. import ouc.sei.suxin.R;
  5. import android.content.Context;
  6. import android.view.LayoutInflater;
  7. import android.view.View;
  8. import android.view.ViewGroup;
  9. import android.widget.BaseAdapter;
  10. import android.widget.LinearLayout;
  11. import android.widget.RadioButton;
  12. import android.widget.TextView;
  13. public class SearchUserAdapter extends BaseAdapter {
  14. private Context context;
  15. private List<String> userList;
  16. HashMap<String,Boolean> states=new HashMap<String,Boolean>();//用于记录每个RadioButton的状态,并保证只可选一个
  1. public SearchUserAdapter(Context context, List<String> userList)
  2. {
  3. this.context = context;
  4. this.userList= userList;
  5. }
  6. @Override
  7. public int getCount() {
  8. return userList.size();
  9. }
  10. @Override
  11. public Object getItem(int position) {
  12. return userList.get(position);
  13. }
  14. @Override
  15. public long getItemId(int position) {
  16. return position;
  17. }
  18. @Override
  19. public View getView(final int position, View convertView, ViewGroup parent) {
  20. ViewHolder holder;
  21. if (convertView == null) {
  22. convertView = LayoutInflater.from(context).inflate(R.layout.search_user_item, null);
  23. holder = new ViewHolder();
  24. holder.background = (LinearLayout) convertView.findViewById(R.id.search_user_list_item);
  25. holder.userName = (TextView) convertView.findViewById(R.id.search_user_name);
  26. convertView.setTag(holder);
  27. }else{
  28. holder=(ViewHolder) convertView.getTag();
  29. }
  30. final RadioButton radio=(RadioButton) convertView.findViewById(R.id.radio_btn);
  31. holder.rdBtn = radio;
  32. holder.userName.setText(userList.get(position));
  33. //根据Item位置分配不同背景
  34. if(userList.size() > 0)
  35. {
  36. if(userList.size() == 1)
  37. {
  38. holder.background.setBackgroundResource(R.drawable.more_item_press);
  39. }
  40. else{
  41. if(position == 0){
  42. holder.background.setBackgroundResource(R.drawable.more_itemtop_press);
  43. }
  44. else if(position == userList.size()-1){
  45. holder.background.setBackgroundResource(R.drawable.more_itembottom_press);
  46. }
  47. else{
  48. holder.background.setBackgroundResource(R.drawable.more_itemmiddle_press);
  49. }
  50. }
  51. }
  52. //当RadioButton被选中时,将其状态记录进States中,并更新其他RadioButton的状态使它们不被选中
  53. holder.rdBtn.setOnClickListener(new View.OnClickListener() {
  54. public void onClick(View v) {
  55. //重置,确保最多只有一项被选中
  56. for(String key:states.keySet()){
  57. states.put(key, false);
  58. }
  59. states.put(String.valueOf(position), radio.isChecked());
  60. SearchUserAdapter.this.notifyDataSetChanged();
  61. }
  62. });
  63. boolean res=false;
  64. if(states.get(String.valueOf(position)) == null || states.get(String.valueOf(position))== false){
  65. res=false;
  66. states.put(String.valueOf(position), false);
  67. }
  68. else
  69. res = true;
  70. holder.rdBtn.setChecked(res);
  71. return convertView;
  72. }
  73. static class ViewHolder {
  74. LinearLayout background;
  75. TextView userName;
  76. RadioButton rdBtn;
  77. }

List适配代码(与一般无异):

  1. adapter = new SearchUserAdapter(this, searchUserList);
  2. searchUserLV.setAdapter(adapter);
  3. searchUserLV.setVisibility(View.VISIBLE);
  4. setListViewHeightBasedOnChildren(searchUserLV);

这里还根据内容动态设置了一下,具体函数如下:

  1. public void setListViewHeightBasedOnChildren(ListView listView) {
  2. Adapter listAdapter = listView.getAdapter();
  3. if (listAdapter == null) {
  4. return;
  5. }
  6. int totalHeight = 0;
  7. int viewCount = listAdapter.getCount();
  8. for (int i = 0; i < viewCount; i++) {
  9. View listItem = listAdapter.getView(i, null, listView);
  10. listItem.measure(0, 0);
  11. totalHeight += listItem.getMeasuredHeight();
  12. }
  13. ViewGroup.LayoutParams params = listView.getLayoutParams();
  14. params.height = totalHeight
  15. + (listView.getDividerHeight() * (listAdapter.getCount()-1)) + 10;//加10是为了适配自定义背景
  16. listView.setLayoutParams(params);
  17. }

当需要获取ListView中RadioButton的选择状态时,可以直接看Adapter中的states,具体如下:

  1. // 根据RadioButton的选择情况确定用户名
  2. for (int i = 0, j = searchUserLV.getCount(); i < j; i++) {
  3. View child = searchUserLV.getChildAt(i);
  4. RadioButton rdoBtn = (RadioButton) child
  5. .findViewById(R.id.radio_btn);
  6. if (rdoBtn.isChecked())
  7. searchUser = searchUserList.get(i);
  8. }

这里的searchUserList是调用后台服务获取的用户名列表,通过states获取选中用户名进行后续操作

效果图:

ListView与RadioButton组合——自定义单选列表

 
0
0
 
猜你在找
查看评论
6楼 xuan237812939 2015-12-29 18:58发表 [回复]
ListView与RadioButton组合——自定义单选列表
楼主思路很好
5楼 superyuanzhe 2015-12-26 19:29发表 [回复]
ListView与RadioButton组合——自定义单选列表
4楼 chuanglio 2015-10-27 14:34发表 [回复]
ListView与RadioButton组合——自定义单选列表
当获取ListView中RadioButton的选择状态时循环到看不见的行数
RadioButton rdoBtn = (RadioButton) child .findViewById(R.id.radio_btn); 
会出现空指针
3楼 樱花_殇 2015-05-25 17:14发表 [回复]
ListView与RadioButton组合——自定义单选列表
终于解决了,找了这个多资料,楼主这个是我找的里面最简单改动最少的一个,不错,谢谢楼主...
2楼 淘_tao 2014-06-10 13:55发表 [回复]
ListView与RadioButton组合——自定义单选列表
可以看看。。。。。。。
1楼 duduzaidudumei 2014-03-26 15:35发表 [回复]
ListView与RadioButton组合——自定义单选列表
关于状态的判断,不需要保存全部位置的状态,可以只保存一个值,被选中的position,当重新刷新view的时候判断map是否包含当前的position即可。这样数据比较多的时候,节省遍历的消耗。
Re: KANGOD_KING 2015-09-16 11:47发表 [回复]
ListView与RadioButton组合——自定义单选列表
回复duduzaidudumei:确实。
不过也用不到map了,只用一个int就行。
holder.radioButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
mCheckedPosition = position;
notifyDataSetChanged();
}
});
重新刷新view的时候holder.radioButton.setChecked(position == mCheckedPosition);
Re: hety163 2014-04-23 10:22发表 [回复]
ListView与RadioButton组合——自定义单选列表
回复duduzaidudumei:一楼正解,楼主的方法虽然也能实现,但是比较消耗性能。
 
您还没有登录,请[登录][注册]
http://blog.csdn.net/checkin001/article/details/11519131