recyclerview的简单使用
2015-12-31 13:55
459 查看
xml布局文件代码
activity代码
适配器代码
viewHolder
<android.support.v7.widget.RecyclerView android:id="@+id/id_recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" >
activity代码
mRecyclerView = (RecyclerView)findViewById(R.id.id_recyclerView); /**纵向的ListView*/ //mRecyclerView.setLayoutManager(new LinearLayoutManager(this)); /**横向listView*/ /*LinearLayoutManager mLinear = new LinearLayoutManager(this); mLinear.setOrientation(LinearLayoutManager.HORIZONTAL); mRecyclerView.setLayoutManager(mLinear);*/ /**网格布局GridView*/ //mRecyclerView.setLayoutManager(new GridLayoutManager(this,4)); /**瀑布流布局 注意StaggeredGridLayoutManager.HORIZONTAL横 VERTICAL列 对应第一个参数*/ mRecyclerView.setLayoutManager(new StaggeredGridLayoutManager(4,StaggeredGridLayoutManager.VERTICAL)); mRecyclerView.setAdapter(new MyAdapter()); mRecyclerView.setItemAnimator(new DefaultItemAnimator()); mRecyclerView.setHasFixedSize(true);
适配器代码
class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyViewHolder>{ @Override public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { MyViewHolder holder = new MyViewHolder(LayoutInflater.from(MainActivity.this).inflate(R.layout.tv_muban,parent,false)); return holder; } @Override public void onBindViewHolder(MyViewHolder holder, int position) { holder.tv.setText(data.get(position)); /**动态设置itemView的宽高*/ ViewGroup.LayoutParams params = holder.itemView.getLayoutParams(); params.height = (int)(200+Math.random()*400); params.width = (int)(200+Math.random()*400); holder.itemView.setLayoutParams(params);//把params设置给item布局 } @Override public int getItemCount() { return data.size(); }
}
viewHolder
class MyViewHolder extends RecyclerView.ViewHolder{ TextView tv; public MyViewHolder(View view){ super(view); tv = (TextView) view.findViewById(R.id.tv_muban); } }
相关文章推荐
- Android布局的小窍门?
- Web布局连载——两栏固定布局(五)
- 样式表CSS布局经验
- css网页布局中注意的几个问题小结
- DL.DT.DD实现左右的布局简单例子第1/2页
- 使用CSS框架布局的缺点和优点小结
- div+CSS网页布局的意义与副作用原因小结第1/2页
- Android编程之代码创建布局实例分析
- CSS顶级技巧大放送,div+css布局必知
- 用div实现像table一样的布局方法
- 精彩的Bootstrap案例分享 重点在注释!(选项卡、栅格布局)
- jQuery EasyUI 布局之动态添加tabs标签页
- android自定义RadioGroup可以添加多种布局的实现方法
- 瀑布流布局并自动加载实现代码
- Android代码实现图片和文字上下布局
- SWT(JFace)体验之RowLayout布局
- Bootstrap每天必学之栅格系统(布局)
- Android布局之LinearLayout线性布局
- Extjs学习笔记之七 布局
- android布局属性详解分享