Android 列表形式的切換的示例代碼
電商項(xiàng)目中經(jīng)常有這樣的需求:在商品列表頁面中,切換列表的展現(xiàn)形式,一般分為列表形式和表格形式。
如京東:
本文最終實(shí)現(xiàn)的效果:
關(guān)鍵詞:RecyclerView
主布局文件:activity_main.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="match_parent"> <android.support.v7.widget.RecyclerView android:id="@+id/recycler_view" android:layout_width="match_parent" android:layout_height="wrap_content" /> </LinearLayout>
列表形式布局文件:item_list.xml
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="98dp" android:layout_margin="8dp" android:background="@color/colorAccent"> <TextView android:id="@+id/text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textAppearance="@style/TextAppearance.AppCompat.Large.Inverse" android:layout_centerInParent="true" tools:text="1" /> </RelativeLayout>
表格形式布局文件:item_grid.xml
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="98dp" android:layout_margin="8dp" android:background="@color/colorAccent"> <TextView android:id="@+id/text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textAppearance="@style/TextAppearance.AppCompat.Large" android:layout_centerInParent="true" tools:text="1" /> </RelativeLayout>
實(shí)現(xiàn)原理:使用 RecyclerView 的 GridLayoutManager,列表形式指定列數(shù)為1,表格形式指定列數(shù)為具體列值。
默認(rèn)為列表形式,指定列數(shù)為1:
recyclerView = (RecyclerView) findViewById(R.id.recycler_view); // 指定列數(shù)為1 gridLayoutManager = new GridLayoutManager(this, COLUMN_ONE); recyclerView.setLayoutManager(gridLayoutManager);
列表形式和表格形式之間的切換:
@Override public boolean onOptionsItemSelected(MenuItem item) { int id = item.getItemId(); if (id == R.id.action_toggle) { if (gridLayoutManager.getSpanCount() == COLUMN_ONE) { gridLayoutManager.setSpanCount(COLUMN_THREE); item.setIcon(ContextCompat.getDrawable(this, R.drawable.ic_grid)); } else { gridLayoutManager.setSpanCount(COLUMN_ONE); item.setIcon(ContextCompat.getDrawable(this, R.drawable.ic_list)); } simpleAdapter.notifyItemRangeChanged(0, simpleAdapter.getItemCount()); return true; } return super.onOptionsItemSelected(item); }
通過 gridLayoutManager.setSpanCount(int cloumn) 設(shè)置列數(shù),最后不要忘記 simpleAdapter.notifyItemRangeChanged(0, simpleAdapter.getItemCount()) 刷新數(shù)據(jù)。
Adapter的處理:
定義兩種 view 類型:VIEW_TYPE_LIST 和 VIEW_TYPE_GRID
根據(jù)不同的 view 類型加載相應(yīng)的布局文件,如下:
@Override public SimpleViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { View itemView; if (viewType == VIEW_TYPE_LIST) { itemView = LayoutInflater.from(parent.getContext()) .inflate(R.layout.item_list, parent, false); } else { itemView = LayoutInflater.from(parent.getContext()) .inflate(R.layout.item_grid, parent, false); } return new SimpleViewHolder(itemView, viewType); }
獲取 view 類型:列數(shù)為1時(shí),view 類型為 VIEW_TYPE_LIST,列數(shù)為3時(shí), view類型為 VIEW_TYPE_GRID
@Override public int getItemViewType(int position) { final int viewType; int column = layoutManager.getSpanCount(); switch (column) { case COLUMN_ONE: viewType = VIEW_TYPE_LIST; break; case COLUMN_THREE: viewType = VIEW_TYPE_GRID; break; default: throw new RuntimeException("wtf?"); } return viewType;
完整代碼:https://github.com/wangshouquan/list-to-grid
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android Intent啟動(dòng)別的應(yīng)用實(shí)現(xiàn)方法
我們知道Intent的應(yīng)用,可以啟動(dòng)別一個(gè)Activity,那么是否可以啟動(dòng)別外的一個(gè)應(yīng)用程序呢,答案是可以的2013-04-04Android通過wifi連接手機(jī)(不需要root)
這篇文章主要為大家詳細(xì)介紹了Android通過wifi連接手機(jī),不需要root,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06Android實(shí)現(xiàn)一個(gè)簡單的單詞本
大家好,本篇文章主要講的是Android實(shí)現(xiàn)一個(gè)簡單的單詞本,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下2022-01-01Android開發(fā)實(shí)現(xiàn)Launcher3應(yīng)用列表修改透明背景的方法
這篇文章主要介紹了Android開發(fā)實(shí)現(xiàn)Launcher3應(yīng)用列表修改透明背景的方法,結(jié)合實(shí)例形式分析了Launcher3相關(guān)配置文件與功能函數(shù)修改設(shè)置操作技巧,需要的朋友可以參考下2017-11-11Android中ListView分頁加載數(shù)據(jù)功能實(shí)現(xiàn)
本篇文章主要介紹了Android中ListView分頁加載數(shù)據(jù)功能實(shí)現(xiàn),具有一定的參考價(jià)值,有需要的可以了解一下。2016-11-11Android 用戶Session管理的設(shè)計(jì)方案
這篇文章主要介紹了Android 用戶Session管理的設(shè)計(jì)方案,需要的朋友可以參考下2017-12-12Android Studio生成函數(shù)注釋的實(shí)現(xiàn)方法
這篇文章主要介紹了Android Studio生成函數(shù)注釋的實(shí)現(xiàn)方法的相關(guān)資料,希望通過本文大家能夠?qū)崿F(xiàn)這樣的功能,需要的朋友可以參考下2017-09-09