詳解Android應(yīng)用中ListView列表選項欄的編寫方法
根據(jù)列表的適配器類型,列表分為三種,ArrayAdapter,SimpleAdapter和SimpleCursorAdapter,這三種適配器的使用大家可學(xué)習(xí)下官網(wǎng)上面的使用或者自行百度谷歌,一堆DEMO?。?!其中以ArrayAdapter最為簡單,只能展示一行字。SimpleAdapter有最好的擴(kuò)充性,可以自定義出各種效果。SimpleCursorAdapter可以認(rèn)為是SimpleAdapter對數(shù)據(jù)庫的簡單結(jié)合,可以方便的把數(shù)據(jù)庫的內(nèi)容以列表的形式展示出來。
系統(tǒng)要繪制ListView了,他首先用getCount()函數(shù)得到要繪制的這個列表的長度,然后開始繪制第一行,怎么繪制呢?調(diào)用getView()函數(shù)。在這個函數(shù)里面首先獲得一個View(這個看實際情況,如果是一個簡單的顯示則是View,如果是一個自定義的里面包含很多控件的時候它其實是一個ViewGroup),然后再實例化并設(shè)置各個組件及其數(shù)據(jù)內(nèi)容并顯示它。好了,繪制完這一行了。那 再繪制下一行,直到繪完為止,前面這些東西做下鋪墊,繼續(xù)…….
現(xiàn)在我們再來了解ListView加載數(shù)據(jù)的原理,有了這方面的了解后再說優(yōu)化才行,下面先跟大家一起來看下ListView加載數(shù)據(jù)的基本原理就直接寫了:
ListView的工作原理如下:
ListView 針對每個item,要求 adapter “返回一個視圖” (getView),也就是說ListView在開始繪制的時候,系統(tǒng)首先調(diào)用getCount()函數(shù),根據(jù)他的返回值得到ListView的長度,然后根據(jù)這個長度,調(diào)用getView()一行一行的繪制ListView的每一項。如果你的getCount()返回值是0的話,列表一行都不會顯示,如果返回1,就只顯示一行。返回幾則顯示幾行。如果我們有幾千幾萬甚至更多的item要顯示怎么辦?為每個Item創(chuàng)建一個新的View?不可能?。?!實際上Android早已經(jīng)緩存了這些視圖,大家可以看下下面這個截圖來理解下,這個圖是解釋ListView工作原理的最經(jīng)典的圖了大家可以收藏下,不懂的時候拿來看看,加深理解,其實Android中有個叫做Recycler的構(gòu)件,順帶列舉下與Recycler相關(guān)的已經(jīng)由Google做過N多優(yōu)化過的東東比如:AbsListView.RecyclerListener、ViewDebug.RecyclerTraceType等等,要了解的朋友自己查下,不難理解,下圖是ListView加載數(shù)據(jù)的工作原理
public class MultipleItemsList extends ListActivity { private MyCustomAdapter mAdapter; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); mAdapter = new MyCustomAdapter(); for (int i = 0; i < 50; i++) { mAdapter.addItem("item " + i); } setListAdapter(mAdapter); } private class MyCustomAdapter extends BaseAdapter { private ArrayList mData = new ArrayList(); private LayoutInflater mInflater; public MyCustomAdapter() { mInflater = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE); } public void addItem(final String item) { mData.add(item); notifyDataSetChanged(); } @Override public int getCount() { return mData.size(); } @Override public String getItem(int position) { return mData.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { System.out.println("getView " + position + " " + convertView); ViewHolder holder = null; if (convertView == null) { convertView = mInflater.inflate(R.layout.item1, null); holder = new ViewHolder(); holder.textView = (TextView)convertView.findViewById(R.id.text); convertView.setTag(holder); } else { holder = (ViewHolder)convertView.getTag(); } holder.textView.setText(mData.get(position)); return convertView; } } public static class ViewHolder { public TextView textView; } }
執(zhí)行程序,查看日志:
getView 被調(diào)用 9 次 ,convertView 對于所有的可見項目是空值(如下):
然后稍微向下滾動List,直到item10出現(xiàn):
convertView仍然是空值,因為recycler中沒有視圖(item1的邊緣仍然可見,在頂端)再滾動列表,繼續(xù)滾動:
此時的convertView非空了,在item11離開屏幕之后,它的視圖(…0f8)作為convertView容納item12了。
自定義MULTIPLE ListView
不過,Android自帶的multiple listview的實現(xiàn)是通過checkedTextView來實現(xiàn)的,但是這個控件很難看,而且一行內(nèi)容布局固定。
以下我們自定義一個:
mListView = (ListView)findViewById(R.id.listview); mListView.setCacheColorHint(0); mListView.setItemsCanFocus(false); mListView.setChoiceMode(ListView.CHOICE_MODE_MULTIPLE);
Adapter定義:
@Override public View getView(int position, View convertView, ViewGroup parent) { Data data = mDataList.get(position); if (convertView == null){ convertView = mInflater.inflate(R.layout.xxxx, null); } TextView nameView = (TextView)convertView.findViewById(R.id.name); nameView.setText(data.FullName); ImageView checkView = (ImageView)convertView.findViewById(R.id.check_view); if (mListView.getAdapter() != null){ SparseBooleanArray checkedArray = mListView.getCheckedItemPositions(); if (0 <= position && position < checkedArray.size()){ if (checkedArray.valueAt(position)){ checkView.setImageResource(R.drawable.checkbox_selected); } else{ checkView.setImageResource(R.drawable.checkbox_unselected); } } } return convertView; }
xxxx.xml布局文件實現(xiàn)
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="wrap_content" > <TextView android:id="@+id/name" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textColor="@color/black" android:layout_marginLeft="10dip" android:gravity="center_vertical" /> <ImageView android:id="@+id/check_view" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:layout_marginRight="10dip" android:layout_centerVertical="true" android:background="@drawable/checkbox_unselected" /> </RelativeLayout>
- Android組件ListView列表簡單使用
- Android自定義ListView實現(xiàn)仿QQ可拖拽列表功能
- Android仿微信列表滑動刪除 如何實現(xiàn)滑動列表SwipeListView
- Android listview動態(tài)加載列表項實現(xiàn)代碼
- Android編程使用ListView實現(xiàn)數(shù)據(jù)列表顯示的方法
- Android開發(fā)之ListView列表刷新和加載更多實現(xiàn)方法
- Android ExpandableListView展開列表控件使用實例
- android開發(fā)教程之使用listview顯示qq聯(lián)系人列表
- Android用ListView顯示SDCard文件列表的小例子
- android listview實現(xiàn)新聞列表展示效果
相關(guān)文章
Android入門之ListView應(yīng)用解析(二)
這篇文章主要介紹了Android入門之ListView應(yīng)用,繼上一篇之后將對Android的ListView用法做更深入的剖析,需要的朋友可以參考下2014-08-08Android性能優(yōu)化之plt?hook與native線程監(jiān)控詳解
這篇文章主要為大家介紹了Android性能優(yōu)化之plt?hook與native線程監(jiān)控詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09Android實戰(zhàn)項目之實現(xiàn)一個簡單計算器
隨著移動互聯(lián)網(wǎng)的普及,手機(jī)應(yīng)用程序已經(jīng)成為人們生活中不可或缺的一部分,計算器是一類被廣泛使用的應(yīng)用程序之一,這篇文章主要給大家介紹了關(guān)于Android實戰(zhàn)項目之實現(xiàn)一個簡單計算器的相關(guān)資料,需要的朋友可以參考下2023-10-10Android?RecyclerBarChart繪制使用教程
這篇文章主要為大家介紹了Android?RecyclerBarChart繪制使用教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12Android RollPagerView實現(xiàn)輪播圖
這篇文章主要介紹了Android RollPagerView實現(xiàn)輪播圖的相關(guān)資料,這里提供實例來實現(xiàn)輪播圖的簡單實例,希望能幫助到大家,需要的朋友可以參考下2017-08-08Android中Bitmap、File與Uri之間的簡單記錄
這篇文章主要給大家介紹了關(guān)于Android中Bitmap、File與Uri之間的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02Android EasyPlayer聲音自動停止、恢復(fù),一鍵靜音等功能
這篇文章主要介紹了Android EasyPlayer聲音自動停止、恢復(fù),一鍵靜音等功能的相關(guān)資料,需要的朋友可以參考下2017-03-03