標籤:cal manager end super 添加 rom from 返回 etl
簡介
RecyclerView是support-v7中用來替換ListView的組件。RecyclerView 小工具比 ListView 更進階且更具靈活性。 此小工具是一個用於顯示龐大資料集的容器,可通過保持有限數量的視圖進行非常有效滾動操作。 如果您有資料集合,其中的元素將因使用者操作或網路事件而發生改變,請使用 RecyclerView 小工具。
使用方法
- 如果要使用RecyclerView,首先要添加support-v7的支援。
- 開啟Project Structure選項,在Dependencies添加RecyclerView-v7庫,之後就可以在程式中使用RecyclerView:
public class MainActivity extends Activity { private RecyclerView rv; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); rv = new RecyclerView(this); setContentView(rv);...
rv.setLayoutManager(new LinearLayoutManager(this));
RecyclerView 提供這些內建布局管理器:
-
- LinearLayoutManager 以垂直或水平滾動列表方式顯示項目。
- GridLayoutManager 在網格中顯示項目。
- StaggeredGridLayoutManager 在分散對齊網格中顯示項目。
//rv.setLayoutManager(new LinearLayoutManager(this, LinearLayoutManager.HORIZONTAL, false));//rv.setLayoutManager(new GridLayoutManager(this, 2));//rv.setLayoutManager(new StaggeredGridLayoutManager(3, StaggeredGridLayoutManager.VERTICAL));
- 接著要給RecyclerView添加Adapter,這個Adapter也需要自訂。在這個Adapter中需要定義一個類,繼承自RecyclerView.ViewHolder:
class ViewHolder extends RecyclerView.ViewHolder { private View root; private TextView tvTitle, tvContent; public ViewHolder(View root) { super(root); tvTitle = (TextView) root.findViewById(R.id.tvTitle); tvContent = (TextView) root.findViewById(R.id.tvContent); } public TextView getTvContent() { return tvContent; } public TextView getTvTitle() { return tvTitle; } }
- 並作為onCreateViewHolder的傳回值,這個函數表示每一項的View:
@Overridepublic RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {return new ViewHolder(LayoutInflater.from(parent.getContext()).inflate(R.layout.list_cell, null));}
- 接下來重寫onBindViewHolder, 這個函數用來RecylerView顯示每一項的內容的時候調用。
@Overridepublic void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {ViewHolder vh = (ViewHolder) holder;CellData cd = data[position];vh.getTvTitle().setText(cd.title);vh.getTvContent().setText(cd.content);}
private CellData[] data = new CellData[]{......}
Android的RecyclerView