電商項目中經(jīng)常有這樣的需求:在商品列表頁面中,切換列表的展現(xiàn)形式,一般分為列表形式和表格形式。
崇禮ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!
如京東:
本文最終實現(xiàn)的效果:
關鍵詞:RecyclerView
主布局文件:activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
列表形式布局文件:item_list.xml
<?xml version="1.0" encoding="utf-8"?>
表格形式布局文件:item_grid.xml
<?xml version="1.0" encoding="utf-8"?>
實現(xiàn)原理:使用 RecyclerView 的 GridLayoutManager,列表形式指定列數(shù)為1,表格形式指定列數(shù)為具體列值。
默認為列表形式,指定列數(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ù),最后不要忘記 simpleAdapter.notifyItemRangeChanged(0, simpleAdapter.getItemCount()) 刷新數(shù)據(jù)。
Adapter的處理:
定義兩種 view 類型:VIEW_TYPE_LIST 和 VIEW_TYPE_GRID
根據(jù)不同的 view 類型加載相應的布局文件,如下:
@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時,view 類型為 VIEW_TYPE_LIST,列數(shù)為3時, 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)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。