Android 自定義ListView示例詳解
本文講實現(xiàn)一個自定義列表的Android程序,程序?qū)崿F(xiàn)一個使用自定義的適配器(Adapter)綁定 數(shù)據(jù),通過contextView.setTag綁定數(shù)據(jù)有按鈕的ListView。
系統(tǒng)顯示列表(ListView)時,首先會實例化一個適配器,本文將實例化一個自定義的適配器。實現(xiàn) 自定義適配器,必須手動映射數(shù)據(jù),這時就需要重寫getView()方法,系統(tǒng)在繪制列表的每一行的時候 將調(diào)用此方法。
ListView在開始繪制的時候,系統(tǒng)自動調(diào)用getCount()函數(shù),根據(jù)函數(shù)返回值得到ListView的長度, 然后根據(jù)這個長度,調(diào)用getView()逐一畫出每一行。
具體使用方法可以參考下面代碼,只需記住Android自定義ListView三步驟:
第一步:準備主布局文件、組件布局文件等
第二步:獲取并整理數(shù)據(jù)
第三步:綁定數(shù)據(jù),這里我們是通過自己編寫Adapter類來完成的
1.首先新建一個list.XML
<?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="vertical" >
<LinearLayout android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" android:background="#f1e4f1">
<ImageView
android:id="@+id/image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
<TextView
android:id="@+id/title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#666872"/>
<Button
android:id="@+id/view"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="詳細"/>
</LinearLayout>
<TextView
android:id="@+id/info"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#666872"/>
</LinearLayout>
2、新建一個適配器類MyAdspter.java
public class MyAdspter extends BaseAdapter {
private List<Map<String, Object>> data;
private LayoutInflater layoutInflater;
private Context context;
public MyAdspter(Context context,List<Map<String, Object>> data){
this.context=context;
this.data=data;
this.layoutInflater=LayoutInflater.from(context);
}
/**
* 組件集合,對應list.xml中的控件
* @author Administrator
*/
public final class Zujian{
public ImageView image;
public TextView title;
public Button view;
public TextView info;
}
@Override
public int getCount() {
return data.size();
}
/**
* 獲得某一位置的數(shù)據(jù)
*/
@Override
public Object getItem(int position) {
return data.get(position);
}
/**
* 獲得唯一標識
*/
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
Zujian zujian=null;
if(convertView==null){
zujian=new Zujian();
//獲得組件,實例化組件
convertView=layoutInflater.inflate(R.layout.list, null);
zujian.image=(ImageView)convertView.findViewById(R.id.image);
zujian.title=(TextView)convertView.findViewById(R.id.title);
zujian.view=(Button)convertView.findViewById(R.id.view);
zujian.info=(TextView)convertView.findViewById(R.id.info);
convertView.setTag(zujian);
}else{
zujian=(Zujian)convertView.getTag();
}
//綁定數(shù)據(jù)
zujian.image.setBackgroundResource((Integer)data.get(position).get("image"));
zujian.title.setText((String)data.get(position).get("title"));
zujian.info.setText((String)data.get(position).get("info"));
return convertView;
}
}
關(guān)于上面LayoutInflater的使用:在實際開發(fā)種LayoutInflater這個類還是非常有用的。它的作用類似 于 findViewById(),不同點是LayoutInflater是用來找layout下xml布局文件,并且會實例化!。
getView()的三個參數(shù):position表示將顯示的是第幾行,covertView是從布局文件中inflate來的布 局。我們用LayoutInflater的方法將定義好的list.xml文件提取成View實例用來顯示。然后將xml文件 中的各個組件實例化,這樣便可以將數(shù)據(jù)對應到各個組件上了。但是按鈕為了響應點擊事件,需要為
它添加點擊監(jiān)聽器,這樣就能捕獲點擊事件。
3、activity_main.xml中添加ListView控件
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >
<ListView
android:id="@+id/list"
android:layout_width="fill_parent"
android:layout_height="fill_parent"></ListView>
</RelativeLayout>
4、在activity中調(diào)用ListView
public class MainActivity extends Activity {
private ListView listView=null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listView=(ListView)findViewById(R.id.list);
List<Map<String, Object>> list=getData();
listView.setAdapter(new MyAdspter(this, list));
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
public List<Map<String, Object>> getData(){
List<Map<String, Object>> list=new ArrayList<Map<String,Object>>();
for (int i = 0; i < 10; i++) {
Map<String, Object> map=new HashMap<String, Object>();
map.put("image", R.drawable.ic_launcher);
map.put("title", "這是一個標題"+i);
map.put("info", "這是一個詳細信息"+i);
list.add(map);
}
return list;
}
}

以上就是對Android ListView 的簡單實現(xiàn),有興趣的小伙伴可以參考下。
相關(guān)文章
Android RecyclerView添加頭部和底部實例詳解
這篇文章主要介紹了Android RecyclerView添加頭部和底部實例詳解的相關(guān)資料,需要的朋友可以參考下2017-06-06
Android?Studio實現(xiàn)簡易計算器App?(Java語言版)
這篇文章主要為大家詳細介紹了Android?Studio實現(xiàn)簡易計算器App,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-05-05
Android App中制作仿MIUI的Tab切換效果的實例分享
這篇文章主要介紹了Android App中制作仿MIUI的Tab切換效果的實例分享,實現(xiàn)具有跟隨手指滾動而滾動功能的ViewPagerIndicator,需要的朋友可以參考下2016-04-04
Android程序開發(fā)通過HttpURLConnection上傳文件到服務器
這篇文章主要介紹了Android程序開發(fā)通過HttpURLConnection上傳文件到服務器的相關(guān)資料,需要的朋友可以參考下2016-01-01
Android通過bin二進制程序調(diào)用jar原理
最近在研究monkey測試,發(fā)現(xiàn)monkey測試的代碼都是JAVA編寫的,通過編譯生成jar包,而我們在執(zhí)行測試時直接執(zhí)行/system/bin/monkey這個二進制程序的,那么它是如何能調(diào)起java程序的呢,本文小編給大家介紹了Android通過bin二進制程序調(diào)用jar原理,需要的朋友可以參考下2023-10-10

