xml代码
listview_layout.xml
<!-- 直接使用数组资源给出列表项,设置使用红色分割条 -->
<!--
<ListView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:entries="@array/love"
android:divider="#f00"
android:dividerHeight="2px"
android:headerDividersEnabled="false"></ListView>
-->
<!-- 使用红色分割条 -->
<ListView
android:id="@+id/list1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:divider="#f00"
android:dividerHeight="2px"
android:headerDividersEnabled="false" />
<!-- 使用绿色分隔条 -->
<ListView
android:id="@+id/list2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:divider="#0f0"
android:dividerHeight="2px"
android:headerDividersEnabled="false" >
</ListView>
***array_item.xml*** <?xml version="1.0" encoding="utf-8"?>
checked_item.xml
<?xml version="1.0" encoding="utf-8"?>JAVA实现代码
package com.example.lovemia;
import android.R.string;
import android.app.Activity;
import android.app.ActionBar;
import android.app.Fragment;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.os.Build;
public class MiaActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// setContentView(R.layout.activity_mia);
setContentView(R.layout.listview_layout);
ListView li = (ListView) findViewById(R.id.list1);
// 定义一个数组
String[] str1 = new String[] { "mia", "love mia", "princess", "my love" };
// 将数组包装为ArrayAdapter
ArrayAdapter<String> aa = new ArrayAdapter<String>(this,
R.layout.array_item, str1);
// 为ListView设置Adapter
li.setAdapter(aa);
ListView li2 = (ListView) findViewById(R.id.list2);
// 定义数组
String[] str2 = new String[] { "010802", "love", "mia", "miss" };
// 将数组包装为ArrayAdapter
ArrayAdapter<String> aa2 = new ArrayAdapter<String>(this,
R.layout.checked_item, str2);
// 为listView设置Adapter
li2.setAdapter(aa2);
}
}
界面效果
// 基于ListActivity实现列表 不使用xml文件
public class MiaActivity extends ListActivity{
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
// 注意这个是在只有一个listview的情况下可以使用的
//无需使用布局文件
String[] str3=new String[]{
“mia”,“miss mia”,“love mia”,“010802”
};
//创建ArrayAdapter对象
ArrayAdapter aa3=new ArrayAdapter(this, android.R.layout.simple_list_item_multiple_choice,str3);
//设置窗口显示列表
setListAdapter(aa3);
}
}
界面效果
使用SimpleAdapter创建listview
xml代码
<!-- 直接使用数组资源给出列表项,设置使用红色分割条 -->
<!--
<ListView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:entries="@array/love"
android:divider="#f00"
android:dividerHeight="2px"
android:headerDividersEnabled="false"></ListView>
-->
<!-- 使用红色分割条 -->
<ListView
android:id="@+id/list1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:divider="#f00"
android:dividerHeight="2px"
android:headerDividersEnabled="false" />
<!-- 使用绿色分隔条 -->
<!--
定义布局文件 -->
<TextView
android:id="@+id/mialist"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
simple_item.xml
<?xml version="1.0" encoding="utf-8"?><!-- 定义一个imageview 用于列表项的一部分 -->
<ImageView
android:id="@+id/head"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="10dp" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
<!-- 定义一个textview 用于作为列表项的一部分 -->
<TextView
android:id="@+id/name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="10dp"
android:textColor="#f0f"
android:textSize="20dp" />
<!-- 定义一个textview作为列表项的一部分 -->
<TextView
android:id="@+id/desc"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="10dp"
android:textSize="14dp" />
</LinearLayout>
java代码
public class MiaActivity extends Activity {
private String[] name = new String[] { “mia”, “princess”, “miss”, “010802” };
private String[] descs = new String[] { “my love”, “公主殿下”, “我想你了”, “生日” };
private int[] iv = new int[] { R.drawable.mia5, R.drawable.mia5,
R.drawable.mia5, R.drawable.mia5 };
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.listview_layout);
// 创建一个list集合 list 集合元素是Map
List<Map<String, Object>> listItems = new ArrayList<Map<String, Object>>();
for (int i = 0; i < name.length; i++) {
Map<String, Object> listItem = new HashMap<String, Object>();
listItem.put("head", iv[i]);
listItem.put("personName", name[i]);
listItem.put("desc", descs[i]);
listItems.add(listItem);
}
// 创建一个SimpleAdapter
SimpleAdapter sa = new SimpleAdapter(this, listItems,
R.layout.simple_item, new String[] { "personName", "head",
"desc" }, new int[] { R.id.name, R.id.head, R.id.desc });
ListView lv = (ListView) findViewById(R.id.list1);
// 为ListView设置Adapter
lv.setAdapter(sa);
}
}
页面效果