Android之——ListView最佳化,androidlistview

來源:互聯網
上載者:User

Android之——ListView最佳化,androidlistview

轉載請註明出處:http://blog.csdn.net/l1028386804/article/details/47209253

作為用戶端,其最主要的任務就是最直觀的和使用者互動。從伺服器拿資料,解析過後顯示資料,根據使用者操作按照一定的協議傳回資料,達到使用者想要的結果。這是我自己的理解,所以我們的程式,必須給使用者一個良好的體驗。

listView可以說是安卓開發中很重要的一個控制項。我所做的項目中,幾乎每個頁面都會有listView。Adapter是listView和資料來源間的中間人。當每條資料進入可見地區時,adapter的getview()會被調用,返回代表具體資料的視圖。觸摸滾動時,頻繁調用。支援成百上千條資料。然而listView同時也很複雜,想要做好最佳化也不容易,下面是我自己整理的listView的最佳化方式

1、最簡單的方法,最慢且最不實用

public View getView(int pos, View convertView, ViewGroup parent){ View item = mInflater.inflate(R.layout.list_item, null); ((TextView) item.findViewById(R.id.text)). setText(DATA[pos]); ((ImageView) item.findViewButId(R.id.icon)). setImageBitmap((pos & 1) == 1 ? mIcon1 : mIcon2); return item;}
每條資料我們都會去解析布局。相當於每次都去new一個對象,寫第一個listView的時候我也是這樣寫的,功能自然能實現,但是實際上效率很低我們

2、可以利用convertView回收視圖,效率能提高200%

 public View getView(int pos, View convertView, ViewGroup parent){if (convertView == null) {convertView = mInflater.inflate( R.layout.list_item, null);}//這個地方相當於做了一個緩衝機制。只有convertVIew為空白的時候我們才去解析布局,因為解析布局實際上是很麻煩,很耗時的。我們只解析一次布局,其他的我們用同一個緩衝的布局((TextView) convertView.findViewById(R.id.text)).setText(DATA[pos]);((ImageView) convertView.findViewButId(R.id.icon)).setImageBitmap((pos & 1) == 1 ? mIcon1 : mIcon2);return convertView;}

3、利用viewholder模式,效率在提高50%

static class ViewHolder {TextView text;ImageView icon;}public View getView(int pos, View convertView, ViewGroup parent){ViewHolder holder;if (convertView == null) {convertView = mInflater.inflate(R.layout.list_item, null);holder = new ViewHolder();holder.text = (TextView) convertView.findViewById(R.id.text));holder.icon = (ImageView) convertView.findViewButId(R.id.icon));convertView.setTag(holder);}else{holder = (ViewHolder) convertView.getTag();}holder.text.setText(DATA[pos]);holder.icon.setImageBitmap((pos & 1) == 1 ? mIcon1 : mIcon2);return convertView;}
以上3點是listView中常用的,當然也是最基本的最佳化方式。如果沒有什麼特殊要求,對於android來說這3種最佳化是必須存在的。還有其他的一些最佳化方法:

4、背景和映像

    視圖背景映像總會填充整個視圖地區
    1)映像尺寸不合適會導致自動縮放
    2)避免即時縮放
    3)最好預先縮放到視圖大小

 originalImage = Bitmap.createScaledBitmap(originalImage,    // 縮放映像view.getWidth(),  // 視圖寬度view.getHeight(), // 視圖高度true); // 線性過濾器
預設情況下, 視窗有一個不透明的背景
    有時可以不需要
    最高層的視圖是不透明的      layout_width  = fill_parent
    最高層的視圖覆蓋整個視窗    layout_height = fill_parent
    更新看不見的背景是浪費時間

 5、刪除視窗背景:

    1)修改編碼

 public void onCreate(Bundle icicle){super.onCreate(icicle);setContentView(R.layout.mainview);// 刪除視窗背景getWindow().setBackgroundDrawable(null);...}

 6、修改xml

    首先確定你的res/values/styles.xml有

parent="android:Theme">
然後編輯androidmainfest.xml
 android:theme="@style/NoBackgroundTheme">   ...

7、更新要求

    當螢幕需要更新時,調用invalidate()方法,簡單方便,但是更新了整個視圖,代價太高。  
    最好先找到無效地區,然後調用

invalidate(Rect dirty);invalidate(int left, int top, int right, int bottom);

8、視圖和布局

    如果一個視窗包含很多視圖,啟動太慢,繪製時間長,使用者介面反應速度很慢
解決方案:
1)使用textview的複合drawable減少層次

android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="@string/hello"android:drawableLeft="@drawable/icon"/>
2)使用viewstuf延遲展開視圖

   在xml檔案中定義viewstuf

android:inflatedId="@+id/panel_import"android:layout="@layout/progress_overlay"android:layout_width="fill_parent"android:layout_height="wrap_content"android:layout_gravity="bottom"/>
在需要展開視圖時
findViewById(R.id.stub_import).setVisibility(View.VISIBLE);// 或者View importPanel = ((ViewStub)findViewById(R.id.stub_import)).inflate();

9、使用合并中間視圖

    預設情況下,布局檔案的根作為一個節點,加入到父視圖中,如果使用merge可以避免根節點

"http://schemas.android.com/apk/res/android">

10、減少android的容器布局嵌套

    android的布局嵌套其實在解析的時候也是很花時間的,所以,我們在能實現功能的基礎上盡量避免很多層的嵌套。寫布局的時候養成習慣就跟我們寫java代碼一樣看到重複代碼就盡量想辦法去最佳化一樣。

11、使用自訂視圖

 class CustomView extends View { @Overrideprotected void onDraw(Canvas canvas) {// 加入你的繪圖編碼}@Overrideprotected void onMeasure(int widthMeasureSpec,int heightMeasureSpec) {// 計算視圖的尺寸setMeasuredDimension(widthSpecSize, heightSpecSize);}}

12、記憶體配置:盡量避免在效能敏感的代碼當中建立java對象

測量 onmeasure()布局onlayout()繪圖 ondraw() dispatchdraw()事件處理 ontouchevent() dispatchtouchevent()adapter: getview() bindview()

13、管理好對象:

1)適用軟引用:記憶體緩衝的最佳選擇
2)適用弱引用:避免記憶體泄露

14、記憶體緩衝:

private final HashMap> mCache;public void put(String key, T value) {mCache.put(key, new SoftReference(value));}public T get(String key, ValueBuilder builder) {T value = null;SoftReferece reference = mCache.get(key);if (reference != null) {value = reference.get();}    return value;}

著作權聲明:本文為博主原創文章,未經博主允許不得轉載。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.