前言:
ListView——列表,它作為一個非常重要的顯示方式,不管是在Web中還是移動平臺中,都是一個非常好的、不開或缺的展示資訊的工具。在Android中,ListView控制元件接管了這一重擔,在大量的場合下,我們都需要使用這個控制元件。雖然在Android 5.X時代,RecyclerView在很多地方都在逐漸取代ListView,但ListView的使用範圍依然非常的廣泛,它這萬年老大哥的地位也不是輕易就能撼動的。下面就介紹一下ListView常用優化技巧。
使用ViewHolder模式提高效率
ViewHolder模式是提高ListView效率的一個很重要的方法。ViewHolder模式充分利用了ListView的檢視快取機制,避免了每次在呼叫getView()的時候都去通過findViewById()例項化控制元件。據測試,使用ViewHolder將提高50%以上的效率。使用ViewHolder模式來優化ListView非常簡單,只需要在自定義Adapter中定義一個內部類ViewHolder,並將佈局中的控制元件作為成員變數,程式碼如下所示。
public final class ViewHolder {
public ImageView img;
public TextView title;
}
接下來,只要在getView()方法中通過檢視快取機制來重用以快取即可,完整的使用ViewHolder建立ListView Adapter的例項程式碼如下所示。
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
import java.util.List;
/*********************************************
* author: Blankj on 2016/7/23 15:39
* blog: http://blankj.com
* e-mail: blankj@qq.com
*********************************************/
public class ViewHolderAdapter extends BaseAdapter {
private List<String> mData;
private LayoutInflater mInflater;
public ViewHolderAdapter(Context context, List<String> data) {
this.mData = data;
mInflater = LayoutInflater.from(context);
}
@Override
public int getCount() {
return mData.size();
}
@Override
public Object 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) {
ViewHolder viewHolder = null;
// 判斷是否快取
if (convertView == null) {
viewHolder = new ViewHolder();
// 通過LayoutInflater例項化佈局
convertView = mInflater.inflate(R.layout.viewholder_item, null);
viewHolder.img = (ImageView) convertView.findViewById(R.id.imageView);
viewHolder.title = (TextView) convertView.findViewById(R.id.textView);
convertView.setTag(viewHolder);
}else {
// 通過tag找到快取的佈局
viewHolder = (ViewHolder) convertView.getTag();
}
// 設定佈局中控制元件要顯示的檢視
viewHolder.img.setBackgroundResource(R.mipmap.ic_launcher);
viewHolder.title.setText(mData.get(position));
return convertView;
}
public final class ViewHolder {
public ImageView img;
public TextView title;
}
}
ListView 初始化:
listView =(ListView)findViewById(R.id.cities_list);
adapter = new ArrayAdapter<String>(City_Column.this,android.R.layout.simple_list_item_1,cities);
listView.setAdapter(adapter);
//長按listView中的某個ITEM會彈出menu
this.registerForContextMenu(listView);
過載類中的方法,長按ListView中某個ITEM會有一個帶兩個 選擇的menu,一個刪除一個設定,效果如下:
@Override
public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
super.onCreateContextMenu(menu, v, menuInfo);
menu.setHeaderTitle("刪除+設定");
menu.add(1,1,1,"刪除");
menu.add(1,2,1,"設定");
}
@Override
public boolean onContextItemSelected(MenuItem item) {
ContextMenu.ContextMenuInfo info = item.getMenuInfo();
AdapterView.AdapterContextMenuInfo contextMenuinfo = (AdapterView.AdapterContextMenuInfo)info;
int position = contextMenuinfo.position;
String city = cities.get(position);
switch (item.getItemId()){
case 1: //點選刪除後進行的操作
MainActivity.deleteCityThread deletecityThread = new MainActivity.deleteCityThread(city);
Thread threadDeleteCity = new Thread(deletecityThread);
threadDeleteCity.start();
Toast.makeText(City_Column.this,city+"is deltede",Toast.LENGTH_SHORT).show();
cities.remove(position);
adapter.notifyDataSetChanged();
//清除 刪除城市下的 提醒
SharedPreferences shareDates = getSharedPreferences(city,MODE_PRIVATE);
SharedPreferences.Editor editorShareDates = shareDates.edit();
editorShareDates.clear();
break;
case 2: // 點選設定後進行的操作
Intent toRemindPage = new Intent(this,RemindPageActivity.class);
toRemindPage.putExtra("toRemindPage",city);
startActivity(toRemindPage);
break;
default:
break;
}
return super.onContextItemSelected(item);
}
ListView 的重新整理:
上述程式碼中case 1: 進行刪除操作會刪掉ListView中的某個ITEM,然後重新整理列表,操作如下: cities為adapter初始化的 陣列
cities.remove(position);
adapter.notifyDataSetChanged();
ListView 載入的優化:
http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2014/1021/1815.html