Android ListView常用小技巧匯總
ListView在我們Android項(xiàng)目中的地位是有目共睹的,相信幾乎每一個(gè)App中都有它的身影。
ListView主要是用列表形式來加載數(shù)據(jù),在特定情況下需要實(shí)現(xiàn)一些特殊功能:如刷新數(shù)據(jù),加載數(shù)據(jù),實(shí)現(xiàn)動(dòng)畫效果等。
作為我們常用的控件,有哪些需要注意的呢?
**為L(zhǎng)istView的每一Item設(shè)置分隔線
第一種方法:也是最簡(jiǎn)單地方法,在布局文件中設(shè)置ListView的
divider屬性
如:android:divider=”@color/black”
第二種方法:設(shè)置android:divider=”@null”表示不要分隔線,然后,自己在Item布局中添加分隔線。
<ListView> android:id="@+id/test_lv" android:layout_width="match_parent" android:layout_height="wrap_content" android:divider="#d1d1d1"<!--設(shè)置分隔線顏色--> android:dividerHeight="1px"<!--設(shè)置分隔線高度--> > </ListView>
** 默認(rèn)情況下,ListView的item有點(diǎn)擊效果,怎么樣改變這種效果呢?
設(shè)置ListViewr的android:listSelector屬性,比如可以設(shè)置透明取消這種效果android:listSelector=”@android:color/transparent”
也可以設(shè)置自己想要的效果,添加對(duì)應(yīng)的color資源或drawble資源 就可以了。
** 當(dāng)數(shù)據(jù)比較多的時(shí)候,ListView在滾動(dòng)時(shí)候會(huì)顯示一個(gè)默認(rèn)的滾動(dòng)條,要取消這個(gè)滾動(dòng)條的話,可以設(shè)置android:scrollbars屬性
如:android:scrollbars=”none”
** ListView性能優(yōu)化,必用ViewHolder來充分發(fā)揮ListView的recycle機(jī)制
** ListView中數(shù)據(jù)動(dòng)態(tài)變化,添加或刪除數(shù)據(jù)操作,效果顯而易見。
//實(shí)現(xiàn)ListView數(shù)據(jù)添加刪除 public class MainActivity extends Activity implements View.OnClickListener { private ListView test_lv; private List<TestBean> dataList; private TestAdapter adapter; private Button add_btn, del_btn; private ImageView emptyIv; private LinearLayout operator_ll; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initDatas(); initViews(); } private void initDatas() { dataList = new ArrayList<>(); for (int i = 0; i < 5; i++) { TestBean bean = new TestBean(); bean.setTitle("標(biāo)題_" + i); bean.setContent("這是內(nèi)容_" + i); bean.setType(i % 2 == 0 ? 1 : 2); dataList.add(bean); } } private void initViews() { this.test_lv = (ListView) findViewById(R.id.test_lv); this.add_btn = (Button) findViewById(R.id.add_btn); this.del_btn = (Button) findViewById(R.id.del_btn); emptyIv = (ImageView) findViewById(R.id.empty_iv); operator_ll=(LinearLayout)findViewById(R.id.operator_ll); this.add_btn.setOnClickListener(this); this.del_btn.setOnClickListener(this); if (dataList.size() == 0) { emptyIv.setVisibility(View.VISIBLE); operator_ll.setVisibility(View.GONE); test_lv.setEmptyView(emptyIv); } else { emptyIv.setVisibility(View.GONE); operator_ll.setVisibility(View.VISIBLE); adapter = new TestAdapter(this, dataList); test_lv.setAdapter(adapter); } test_lv.setSelection(15); } @Override public void onClick(View v) { switch (v.getId()) { case R.id.add_btn: //默認(rèn)增加在第一個(gè)位置 TestBean bean = new TestBean(); bean.setTitle("增加項(xiàng)"); bean.setContent("這是增加內(nèi)容"); bean.setType(1); dataList.add(0, bean); break; case R.id.del_btn: //默認(rèn)刪除第一條數(shù)據(jù) dataList.remove(0); break; } adapter.notifyDataSetChanged();//刷新ListView數(shù)據(jù) } } //ListView對(duì)應(yīng)Adapter public class TestAdapter extends BaseAdapter { private Context mContext; private List<TestBean> listDatas; public TestAdapter(Context mContext, List<TestBean> listDatas) { this.mContext = mContext; this.listDatas = listDatas; } @Override public int getCount() { return listDatas.size(); } @Override public Object getItem(int position) { return listDatas.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder = null; if (convertView == null) { holder = new ViewHolder(); convertView = LayoutInflater.from(mContext).inflate(R.layout.test_item, null); holder.title = (TextView) convertView.findViewById(R.id.item_title); holder.content = (TextView) convertView.findViewById(R.id.item_content); convertView.setTag(holder); } else { holder = (ViewHolder) convertView.getTag(); } holder.content.setText(listDatas.get(position).getContent()); holder.title.setText(listDatas.get(position).getTitle()); return convertView; } final class ViewHolder { TextView title; TextView content; } }
** 類似聊天界面,ListView中有多種item樣式效果
//實(shí)現(xiàn)ListView中多種item樣式 public class TypeActivity extends Activity { private ListView type_lv; private List<TestBean> dataList; private TypeAdapter adapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_type); initDatas(); initViews(); } private void initDatas() { dataList = new ArrayList<>(); for (int i = 0; i < 9; i++) { TestBean bean = new TestBean(); bean.setTitle("標(biāo)題_" + i); bean.setContent("這是內(nèi)容_" + i); bean.setType(i % 2 == 0 ? 1 : 2); dataList.add(bean); } } private void initViews() { this.type_lv = (ListView) findViewById(R.id.type_lv); adapter = new TypeAdapter(this, dataList); type_lv.setAdapter(adapter); } } //對(duì)應(yīng)Adapter public class TypeAdapter extends BaseAdapter { private Context mContext; private List<TestBean> listDatas; public TypeAdapter(Context mContext, List<TestBean> listDatas) { this.mContext = mContext; this.listDatas = listDatas; } @Override public int getCount() { return listDatas.size(); } @Override public Object getItem(int position) { return listDatas.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder = null; //根據(jù)樣式設(shè)置不同的布局及數(shù)據(jù)展示 int type = getItemViewType(position); if (convertView == null) { holder = new ViewHolder(); if (type == 1) { convertView = LayoutInflater.from(mContext).inflate(R.layout.test_item, null); holder.title = (TextView) convertView.findViewById(R.id.item_title); holder.content = (TextView) convertView.findViewById(R.id.item_content); } else { convertView = LayoutInflater.from(mContext).inflate(R.layout.type_item, null); holder.title = (TextView) convertView.findViewById(R.id.type_title); holder.content = (TextView) convertView.findViewById(R.id.type_title); } convertView.setTag(holder); } else { holder = (ViewHolder) convertView.getTag(); } holder.content.setText(listDatas.get(position).getContent()); holder.title.setText(listDatas.get(position).getTitle()); return convertView; } //關(guān)鍵方法之getViewTypeCount:獲取有多少種樣式 @Override public int getViewTypeCount() { return 2; } //關(guān)鍵方法之getItemViewType:獲取item類型 @Override public int getItemViewType(int position) { return listDatas.get(position).getType(); } final class ViewHolder { TextView title; TextView content; } }
相關(guān)布局
activity_main.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <LinearLayout android:id="@+id/operator_ll" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <Button android:id="@+id/add_btn" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:gravity="center" android:text="添加" /> <Button android:id="@+id/del_btn" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:gravity="center" android:text="刪除" /> </LinearLayout> <ListView android:id="@+id/test_lv" android:layout_width="match_parent" android:layout_height="wrap_content" android:divider="#d1d1d1"<!--分隔線顏色--> android:dividerHeight="1px"<!--分隔線高度--> android:listSelector="@android:color/transparent"<!--取消默認(rèn)點(diǎn)擊效果--> android:scrollbars="none"><!--隱藏滾動(dòng)條--> </ListView> <ImageView android:id="@+id/empty_iv" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:layout_marginTop="100dp" android:src="@mipmap/empty" android:visibility="gone" /> </LinearLayout>
activity_type.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <ListView android:id="@+id/type_lv" android:layout_width="match_parent" android:layout_height="wrap_content" ></ListView> </LinearLayout>
test_item.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" android:paddingLeft="15dp" android:layout_marginTop="5dp" android:layout_marginBottom="5dp"> <TextView android:id="@+id/item_title" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Hello World!" /> <TextView android:id="@+id/item_content" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="5dp" android:text="Hello World!" /> </LinearLayout>
以上就是搜集的Android ListView常用小技巧全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。
- Android應(yīng)用中通過Layout_weight屬性用ListView實(shí)現(xiàn)表格
- 詳解Android中實(shí)現(xiàn)ListView左右滑動(dòng)刪除條目的方法
- 詳解Android應(yīng)用中ListView列表選項(xiàng)欄的編寫方法
- Android ListView物流獲取追蹤功能實(shí)現(xiàn)
- Android應(yīng)用中ListView利用OnScrollListener分頁(yè)加載數(shù)據(jù)
- Android實(shí)現(xiàn)簡(jiǎn)單的分批加載ListView
- Android改變ExpandableListView的indicator圖標(biāo)實(shí)現(xiàn)方法
- Android實(shí)現(xiàn)仿網(wǎng)易今日頭條等自定義頻道listview 或者grideview等item上移到另一個(gè)view中
- Android中ListView下拉刷新的實(shí)現(xiàn)方法
- Android ListView異步加載圖片方法詳解
- 實(shí)例講解Android app開發(fā)中ListView的基本使用及優(yōu)化
- Android編程實(shí)現(xiàn)動(dòng)態(tài)更新ListView的方法
- Android listview多視圖嵌套多視圖
- Android中ListView用法實(shí)例分析
- Android App界面的ListView布局實(shí)戰(zhàn)演練
相關(guān)文章
Android使用Notification實(shí)現(xiàn)通知功能
這篇文章主要為大家詳細(xì)介紹了Android使用Notification實(shí)現(xiàn)通知功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11Android自定義view實(shí)現(xiàn)圓形與半圓形菜單
這篇文章主要介紹了Android自定義view實(shí)現(xiàn)圓形與半圓形菜單的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11Android實(shí)現(xiàn)淘寶倒計(jì)時(shí)功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)淘寶倒計(jì)時(shí),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-02-02Android 使用<layer-list>實(shí)現(xiàn)微信聊天輸入框功能
<layer-list> 標(biāo)簽可以設(shè)置LayerDrawable,一種有層次的Drawable疊加效果,<layer-list> 可以包含多個(gè) <item>標(biāo)簽。這篇文章主要介紹了Android 使用<layer-list>實(shí)現(xiàn)微信聊天輸入框,需要的朋友可以參考下2017-05-05