Welcome

首页 / 移动开发 / Android / Android UI:ListView - SimpleAdapter实例详解

Android UI:ListView -- SimpleAdapter
SimpleAdapter是扩展性最好的适配器,可以定义各种你想要的布局,而且使用很方便。

layout :
<?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="match_parent"android:orientation="horizontal"><ListViewandroid:layout_width="match_parent"android:layout_height="wrap_content"android:divider="#7f00"    //分割线android:dividerHeight="2dp"android:id="@+id/listview_sample"/></LinearLayout>
header layout:
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:orientation="vertical" android:layout_width="match_parent"android:layout_height="match_parent"><ImageViewandroid:layout_width="match_parent"android:layout_height="wrap_content"android:src="@mipmap/ic_launcher"/></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="match_parent"android:orientation="horizontal"><ImageViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_margin="3px"android:id="@+id/img"/><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="vertical"><TextViewandroid:layout_width="match_parent"android:layout_height="wrap_content"android:textSize="16sp"android:id="@+id/title"/><TextViewandroid:layout_width="match_parent"android:layout_height="wrap_content"android:id="@+id/info"android:textSize="16sp"/></LinearLayout></LinearLayout>
Java 代码:
public class SampleAdapterActivity extends Activity {private ListView mListview;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.sampleadapter_layout);mListview = (ListView) findViewById(R.id.listview_sample);SimpleAdapter adapter = new SimpleAdapter(this,getData(), //数据来源R.layout.item_listview, //对应item viewnew String[]{"img","title","info"}, //data 中对应值new int[]{R.id.img,R.id.title,R.id.info}); //填充layout位置mListview.setHeaderDividersEnabled(true); //是否显示头view 的分割线View header = View.inflate(this,R.layout.listview_header,null);View footer = View.inflate(this,R.layout.listview_header,null);mListview.addHeaderView(header);//添加头部viewmListview.addFooterView(footer); //添加底部viewmListview.setAdapter(adapter);}@Overrideprotected void onResume() {super.onResume();}private List<? extends Map<String,?>> getData() {List<Map<String,Object>> items = new ArrayList<Map<String, Object>>();for (int i = 0; i < 5; i++) {Map<String,Object> item = new HashMap<String,Object>();item.put("img",R.mipmap.ic_launcher);item.put("title","title -- " + i );item.put("info","info -- " + i );items.add(item);}return items;}}
 显示效果
 
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!