Android Adapter以及getView()方法的理解

Android Adapter基本理解:

我的理解是:

1、一個有許多getter的類(就是getView(),getCount()....這些方法)

2、有多少個get方法?都是什麼?

這些getter是特定的,你可以複寫他們,全部的方法如下


其中一般我們只用複寫getCount(),getView(),getItemId(),getItem()這四個方法

3、這些被誰調用?

這些getter是被android系統自行調用的(具體如何調用,作爲像我這樣的新手做稍微瞭解就好)

4、爲什麼要複寫這些get方法?

複寫這些getter是爲了返回給android系統,自己想給的結果

5、android系統通過這些getter能得到什麼?

得到這個view自身的一些信息

eg:以ListView中的Adapter爲例,其中

public int getCount() 

返回ListView中要顯示的子View數量,就是item的總數量

public Object getItem(int position)

返回一個子View,即ListView中的一個子條目

public long getItemId(int position)

返回一個item的id,由參數position決定是哪個id

public View getView(int position, View convertView, ViewGroupparent)

後做詳解

….

6android系統得到這些爲了幹什麼?

得到這些信息以便繪製出這個View,以及以怎麼樣的方式繪製



View getview(int position, View convertview, ViewGroup parent )的理解:

引用自:http://www.cnblogs.com/xiaowenji/archive/2010/12/08/1900579.html其中也有一案例幫助理解

一、原理的理解

工作原理:

  1. ListView 針對List中每個item,要求 adapter “給我一個視圖” (getView)。
  2. 一個新的視圖被返回並顯示

如果我們有上億個項目要顯示怎麼辦?爲每個項目創建一個新視圖?NO!這不可能!

實際上Android爲你緩存了視圖。

Android中有個叫做Recycler的構件,下圖是他的工作原理:


  1. 如果你有10億個項目(item),其中只有可見的項目存在內存中,其他的在Recycler中。
  2. ListView先請求一個type1視圖(getView)然後請求其他可見的項目。convertView在getView中是空(null)的。
  3. 當item1滾出屏幕,並且一個新的項目從屏幕低端上來時,ListView再請求一個type1視圖。convertView此時不是空值了,它的值是item1。你只需設定新的數據然後返回convertView,不必重新創建一個視圖。

二、代碼的理解

Google官方的demo代碼:

<span style="font-family:Courier New;font-size:12px;">public View getView(int position, View convertView, ViewGroup parent) 
{ 
    // A ViewHolder keeps references to children views to avoid unneccessary calls 
    // to findViewById() on each row. 

    ViewHolder holder; 
    // When convertView is not null, we can reuse it directly, there is no need 
    // to reinflate it. We only inflate a new View when the convertView supplied 
    // by ListView is null. 

    if (convertView == null) 
	{ 
        convertView = mInflater.inflate(R.layout.list_item_icon_text, null); 
        Log.v("tag", "positon "+position+" convertView is null, "+"new: "+convertView); 
        // Creates a ViewHolder and store references to the two children views 
        // we want to bind data to. 
        holder = new ViewHolder(); 
        holder.text = (TextView) convertView.findViewById(R.id.text); 
        holder.icon = (ImageView) convertView.findViewById(R.id.icon); 
        convertView.setTag(holder); 
    } 
	else 
	{ 
        // Get the ViewHolder back to get fast access to the TextView 
        // and the ImageView. 
        holder = (ViewHolder) convertView.getTag(); 
        Log.v("tag", "positon "+position+" convertView is not null, "+convertView); 
    } 

    // Bind the data efficiently with the holder. 
    holder.text.setText(DATA[position]); 
    holder.icon.setImageBitmap((position & 1) == 1 ? mIcon1 : mIcon2); 
    return convertView; 
} 
 
static class ViewHolder 
{ 
    TextView text; 
    ImageView icon; 
} </span>


下兩段引用自:http://blog.csdn.net/pkxiuluo01/article/details/7380974

convertView參數的理解:

每次顯示一個item都調用一次getview方法但是每次調用的時候covertview爲空(因爲還沒有舊的view),當顯示完了之後。如果屏幕移動了之後,並且導致有些Item(也可以說是view)跑到屏幕外面,此時如果還有新的item需要產生,則這些item顯示時調用的getview方法中的convertview參數就不是null,而是那些移出屏幕的view(舊view),我們所要做的就是將需要顯示的item填充到這些回收的view(舊view)中去,最後注意convertview爲null的不僅僅是初始顯示的那些item,還有一些是已經開始移入屏幕但是還沒有view被回收的那些item。


setTag()和getTag()的理解:

view的setTag和getTag方法其實很簡單,在實際編寫代碼的時候一個view不僅僅是爲了顯示一些字符串、圖片,有時我們還需要他們攜帶一些其他的數據以便我們對該view的識別或者其他操作。於是android 的設計者們就創造了setTag(Object)方法來存放一些數據和view綁定,我們可以理解爲這個是view 的標籤也可以理解爲view 作爲一個容器存放了一些數據。而這些數據我們也可以通過getTag() 方法來取出來。

到這裏setTag和getTag大家應該已經明白了。再回到上面的話題,我們通過convertview的setTag方法和getTag方法來將我們要顯示的數據來綁定在convertview上。如果convertview 是第一次展示我們就創建新的Holder對象與之綁定,並在最後通過return convertview 返回,去顯示;如果convertview 是回收來的那麼我們就不必創建新的holder對象,只需要把原來的綁定的holder取出加上新的數據就行了。



我理解過程中所看的文章:

源頭上理解Adapter,以及一個案例

http://blog.csdn.net/chunqiuwei/article/details/39934169

幫助理解

http://blog.csdn.net/primer_programer/article/details/23064767

發佈了31 篇原創文章 · 獲贊 43 · 訪問量 21萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章