Use a Background Thread
使用背景執行續("worker thread")移除主執行緒的負擔,如此它可以專注在繪製使用者介面。在許多的例子中,使用AsyncTask提供一個簡單的方法來執行主執行續以外的工作,AsyncTask會自動地將所有execute()排隊並執行它們。
以下的例子,AsyncTask被用來在背景執行緒中載入圖片,載入結束,接著將圖片應用在使用者介面。
// Using an AsyncTask to load the slow images in a background thread new AsyncTask<ViewHolder, Void, Bitmap>() { private ViewHolder v; @Override protected Bitmap doInBackground(ViewHolder... params) { v = params[0]; return mFakeImageLoader.getImage(); } @Override protected void onPostExecute(Bitmap result) { super.onPostExecute(result); if (v.position == position) { // If this item hasn't been recycled already, hide the // progress and set and show the image v.progress.setVisibility(View.GONE); v.icon.setVisibility(View.VISIBLE); v.icon.setImageBitmap(result); } } }.execute(holder);Android3.0開始,AsyncTask有額外的功能可用,所以你可以啟用它運行跨越多處理核心。取代呼叫execute(),你可以指定executeOnExecutor()及多請求可以同時在多個處理核心上被執行。
Hold View Objects in a View Holder
在ListView捲動期間,你的程式可能會經常地呼叫findViewById(),它可能會拖慢執行效率,即使Adapter供回收回傳了膨大的視圖,你仍然需要照料項目及更新它們。重複findViewById()的使用的一個方法是使用"view holder"設計模式。
一個ViewHolder物件儲存了每一個在layout中被標記的視圖元件,所以你可以直接存取它們,不需要重複地找它們。首先,你需要建立一個類別去保留你的具體視圖集。
static class ViewHolder { TextView text; TextView timestamp; ImageView icon; ProgressBar progress; int position; }
接著填充ViewHolder並將它儲存在Layout內。
ViewHolder holder = new ViewHolder(); holder.icon = (ImageView) convertView.findViewById(R.id.listitem_image); holder.text = (TextView) convertView.findViewById(R.id.listitem_text); holder.timestamp = (TextView) convertView.findViewById(R.id.listitem_timestamp); holder.progress = (ProgressBar) convertView.findViewById(R.id.progress_spinner); convertView.setTag(holder);
沒有留言:
張貼留言