Android ListView实现通讯录的例子

Android ListView实现通讯录的例子

1.png
2011-9-10 16:40:01 上传
下载附件 (167.75 KB)


实现过程。
第一步:布局
list_items.xml:
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout
  3. xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"

  6. >

  7. <TableLayout
  8. android:id="@+id/widget35"
  9. android:layout_width="fill_parent"
  10. android:layout_height="wrap_content"
  11. android:paddingBottom="5px"
  12. xmlns:android="http://schemas.android.com/apk/res/android"
  13. android:orientation="vertical"
  14. android:background="#f8f8f8"

  15. >
  16. <TableRow
  17. android:id="@+id/widget36"
  18. android:layout_width="fill_parent"
  19. android:layout_height="wrap_content"
  20. xmlns:android="http://schemas.android.com/apk/res/android"
  21. android:orientation="horizontal"
  22. >

  23. <FrameLayout
  24. android:id="@+id/widget39"
  25. android:layout_width="wrap_content"
  26. android:layout_height="wrap_content"
  27. xmlns:android="http://schemas.android.com/apk/res/android"
  28. >

  29. <ImageView
  30. android:id="@+id/ItemImage"
  31. android:layout_width="wrap_content"
  32. android:layout_height="wrap_content"
  33. android:src="@drawable/head0"
  34. />

  35. <AbsoluteLayout
  36. android:id="@+id/widget44"
  37. android:layout_width="wrap_content"
  38. android:layout_height="wrap_content"
  39. xmlns:android="http://schemas.android.com/apk/res/android"
  40. >
  41. <ImageView
  42. android:id="@+id/PhoneType"
  43. android:layout_width="wrap_content"
  44. android:layout_height="wrap_content"
  45. android:layout_x="45px"
  46. android:layout_y="15px"
  47. android:src="@drawable/ra11"
  48. />

  49. </AbsoluteLayout>
  50. </FrameLayout>


  51. <TableLayout
  52. android:id="@+id/widget49"
  53. android:layout_width="wrap_content"
  54. android:layout_height="wrap_content"
  55. android:paddingLeft="5px"
  56. android:paddingTop="3px"
  57. android:paddingRight="10px"
  58. xmlns:android="http://schemas.android.com/apk/res/android"
  59. >
  60. <TableRow
  61. android:id="@+id/widget50"
  62. android:layout_width="fill_parent"
  63. android:layout_height="wrap_content"
  64. xmlns:android="http://schemas.android.com/apk/res/android"
  65. android:orientation="horizontal"
  66. >
  67. <TextView
  68. android:id="@+id/ItemName"
  69. android:layout_width="wrap_content"
  70. android:layout_height="wrap_content"
  71. android:textSize="18px"
  72. android:textColor="#1d1d1d"
  73. android:text="TextView"
  74. />

  75. </TableRow>

  76. <TableRow
  77. android:id="@+id/widget51"
  78. android:layout_width="fill_parent"
  79. android:layout_height="wrap_content"
  80. xmlns:android="http://schemas.android.com/apk/res/android"
  81. android:paddingRight="10px"
  82. android:orientation="horizontal"
  83. >
  84. <TextView
  85. android:id="@+id/ItemPhoneNum"
  86. android:layout_width="wrap_content"
  87. android:layout_height="wrap_content"
  88. android:textSize="14px"
  89. android:textColor="#8e8e8e"
  90. android:text="TextView"
  91. />

  92. <TextView
  93. android:id="@+id/ItemCallDate"
  94. android:layout_width="wrap_content"
  95. android:layout_height="wrap_content"
  96. android:textSize="12px"
  97. android:paddingLeft="10px"
  98. android:textColor="#8e8e8e"
  99. android:text="TextView"
  100. />
  101. </TableRow>
  102. </TableLayout>

  103. <ImageView
  104. android:id="@+id/Call"
  105. android:layout_width="wrap_content"
  106. android:layout_height="wrap_content"
  107. android:layout_marginLeft="10px"
  108. android:layout_marginTop="10px"
  109. android:paddingLeft="10px"
  110. android:paddingRight="10px"
  111. android:src="@drawable/phone"
  112. />


  113. </TableRow>
  114. </TableLayout>


  115. </LinearLayout>
复制代码
第二部:Activity
  1. package com.android.lst;

  2. import java.util.ArrayList;
  3. import java.util.HashMap;
  4. import android.app.Activity;
  5. import android.os.Bundle;
  6. import android.widget.ListView;
  7. import android.widget.SimpleAdapter;


  8. /**
  9. * 用ListView实现通讯录的例子
  10. * @author touchAndroid
  11. *http://bbs.droidstouch.com
  12. */
  13. public class Test extends Activity {



  14. public void onCreate(Bundle savedInstanceState) {
  15. super.onCreate(savedInstanceState);
  16. setContentView(R.layout.main);

  17. ListView list = (ListView)this.findViewById(R.id.myListView);
  18. this.setTitle("通话记录");



  19. //参数一:context,
  20. //参数二:数据源
  21. //参数三:布局文件
  22. //参数4:数据源中Map中的Key
  23. //参数5:参数4中Map中的Key的值显示在哪个控件上
  24. SimpleAdapter listItemAdapter = new SimpleAdapter(this, initData(), R.layout.list_items,
  25. new String[] {"ItemImage","PhoneType","ItemName","ItemPhoneNum","ItemCallDate"},
  26. new int[] {R.id.ItemImage,R.id.PhoneType,R.id.ItemName,R.id.ItemPhoneNum,R.id.ItemCallDate}
  27. );


  28. list.setAdapter(listItemAdapter);
  29. }




  30. /**
  31. * 构造数据源
  32. * @return
  33. */
  34. public ArrayList<HashMap<String,Object>> initData()
  35. {

  36. ArrayList<HashMap<String,Object>> listItem = new ArrayList<HashMap<String,Object>>();

  37. for(int i = 0; i < 10; i++)
  38. {
  39. HashMap<String,Object> map = new HashMap<String,Object>();
  40. try {
  41. map.put("ItemImage", R.drawable.class.getField("head"+i).get(this));

  42. } catch (Exception e) {
  43. map.put("ItemImage", R.drawable.head);
  44. }
  45. try {
  46. map.put("PhoneType", R.drawable.class.getField("ra1"+ ((i%2==0)?1:2)).get(this));
  47. } catch (Exception e) {
  48. map.put("PhoneType", R.drawable.ra11);
  49. }
  50. map.put("ItemName", "touchAndroid" + i);
  51. map.put("ItemPhoneNum", "13800138000");
  52. map.put("ItemCallDate", "7天前");
  53. listItem.add(map);
  54. }

  55. return listItem;
  56. }

  57. }
复制代码

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值