SimpleAdapter是有够Simple的,它只提供了一个构造方法。
SimpleAdapter(Context context, List<? extends Map<String, ?>> data, int resource, String[] from, int[] to)
data 是要显示的数据,它被要求是一个List,List里的每一项是一个Map,每一个Map里装好了一行的数据。
resource 是展示数据的那个layout文件
from 这个数组里收集了data里的Map中要显示的那些内容的key。
to 这个数组收集了resource里要展示内容的view的id。每一个id都根据数组下标对应着from中的一个key。这样就明确的指定了哪项内容展示在哪个view里。
SimpleAdapter的简单实例
主函数:
public class MainActivity extends AppCompatActivity {
private ListView mListView;
private SimpleAdapter simpleAdapter;
private List<Map<String, Object>> data;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mListView = (ListView) findViewById(R.id.listview);
//SimpleAdapter(context,data,resource,from,to)
/**
*context:上下文
* data:数据源(List<? extends Map<String,?>>data)一个Map所组成的List集合
* 每一个Map都会去对应ListView列表中的一行
* 每一个Map(键值-对)中的键必须包含所有在from中指定的键
* resource:列表项的布局id
* from:Map中的键名
* to:绑定数据视图中的ID,与from成对应关系
*/
data = new ArrayList<>();
simpleAdapter = new SimpleAdapter(this, getData(), R.layout.item, new String[]{"pic", "text"}, new int[]{R.id.imageview, R.id.textview_pic});
mListView.setAdapter(simpleAdapter);
}
private List<Map<String, Object>> getData() {
for (int i = 0; i < 20; i++) {
Map<String, Object> map = new HashMap<>();
map.put("pic", R.mipmap.xiao);
map.put("text", "身份" + i);
data.add(map);
}
return data;
}
}
activity_main布局文件:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
tools:context=".MainActivity">
<ListView
android:id="@+id/listview"
android:layout_width="match_parent"
android:layout_height="wrap_content"></ListView>
</LinearLayout>
item布局文件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<ImageView
android:id="@+id/imageview"
android:layout_marginLeft="30dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@mipmap/ic_launcher"/>
<TextView
android:id="@+id/textview_pic"
android:layout_gravity="center_vertical"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="20sp"
android:textColor="#ff00ff"
android:text="头像"/>
</LinearLayout>