使用RecyclerView展示GrideView效果
来源:互联网 发布:剑网三检查网络 编辑:程序博客网 时间:2024/05/27 06:53
第一步:
关联库文件:
第二步:布局.xml
<android.support.v7.widget.RecyclerView android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/recyler_view"> </android.support.v7.widget.RecyclerView>
第三步:在主类中初始化控件
//查找我们的控件函数
private void initView() {
mRecyclerView = (RecyclerView) findViewById(R.id.recyler_view);
}
第四步:在主类中通过方法,添加一个menu菜单选项,效果如下:
方法:
//加载一个menu菜单 @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.activity_menu,menu); return true; } //菜单按钮点击事件处理函数 @Override public boolean onOptionsItemSelected(MenuItem item) { int itemId=item.getItemId(); //grideView显示 if (itemId==R.id.action_gride_normal){ //标准显示 loadgrideDate(false,true); //自定义的一个bean类 return true; }// B 垂直反向显示 else if (itemId==R.id.action_gride_normal_reverse){ loadgrideDate(true,true); }// C 水平标准显示 else if (itemId==R.id.action_gride_horizontal){ loadgrideDate(false,false); }// D 水平反向显示 else if (itemId==R.id.action_gride_horizontal_reverse){ loadgrideDate(true,false); } return super.onOptionsItemSelected(item); }
loadgrideDate函数:
// D RecyclerView实现GridView效果,实际上就是布局管理器参数改为GridViewManager private void loadgrideDate(Boolean isversion,Boolean orientation) { //创建一个集合,泛型是DetaBean ArrayList<DateBean> dates=new ArrayList<>(); //给Bean类放数据,最后把装好数据的Bean类放到集合里面!! for(int x=0; x< 35; x++){ //创建Bean类对象 DateBean dateBean=new DateBean(); //DateBean是一个Bean类!! dateBean.icon=R.drawable.zx_img; dateBean.name="wsw你好"+x; //把Bean类放入集合 dates.add(dateBean); } //创建适配器对象 参数一般有两个,上下文和数据加载集合 RecyclerViewGridAdapter recyclerViewGridAdapter = new RecyclerViewGridAdapter(this, dates); // 1 设置适配器 mRecyclerView.setAdapter(recyclerViewGridAdapter); //布局管理器所需参数,上下文 GridLayoutManager gridLayoutManager = new GridLayoutManager(this, 3); //B 通过布局管理器,可以控制条目排列顺序 true:反向显示 false:正常显示(默认) gridLayoutManager.setReverseLayout(isversion); //C 设置RecyclerView显示的方向,是水平还是垂直!! GridLayoutManager.VERTICAL(默认) false gridLayoutManager.setOrientation(orientation ? GridLayoutManager.VERTICAL: LinearLayoutManager.HORIZONTAL); //设置布局管理器 , 参数 linearLayout mRecyclerView.setLayoutManager(gridLayoutManager); }
RecyclerViewGridAdapter是我们自定义的适配器类,就是为了展示listview效果
//提示 RecyclerViewGridViewAdapter和RecyclerViewListAdapter代码一样//RecyclerView的适配器,主要是指定泛型, 一般我们就是类名的ViewHolder继承Viewholder (内部已经实现了复用机制)public class RecyclerViewGridAdapter extends RecyclerView.Adapter<RecyclerViewGridAdapter.GridViewHolder>{ private Context mContext; //泛型是RecylerView所需的Bean类 private List<DateBean> mDateBeen; //构造方法,一般需要接受两个参数,上下文,集合对象(包含我们所需要的数据) public RecyclerViewGridAdapter(Context context, ArrayList<DateBean> dates) { mContext = context; mDateBeen = dates; } //创建ViewHolder也就是说创建出来一条,并把ViewHolder(item)返回出去 @Override public GridViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { //转换一个View布局对象,决定了item的样子, 参数1:上下文 2. xml布局对象 3.为null View view = View.inflate(mContext, R.layout.activity_gridview, null); //创建一个ViewHolder对象 GridViewHolder gridViewHolder = new GridViewHolder(view); //把ViewHolder对象传出去 return gridViewHolder; } @Override public void onBindViewHolder(GridViewHolder holder, int position) { //从集合里拿对应item的数据对象 DateBean dateBean = mDateBeen.get(position); //给holder里面的控件对象设置数据 holder.setData(dateBean); } @Override public int getItemCount() { //数据不为null,有几条数据就显示几条数据 if (mDateBeen != null && mDateBeen.size() > 0) { return mDateBeen.size(); } return 0; } public class GridViewHolder extends RecyclerView.ViewHolder{ private final ImageView mIvIcon; private final TextView mTvName; public GridViewHolder(View itemView) { super(itemView); mIvIcon = (ImageView) itemView.findViewById(R.id.item_list_iv_icon); mTvName = (TextView) itemView.findViewById(R.id.item_list_tv_icon); } public void setData(DateBean data) { //给imageView设置图片 mIvIcon.setImageResource(data.icon); //给TextView设置文本 mTvName.setText(data.name); } }}
activity_gridview.xml代码如下:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:gravity="center" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="wrap_content"> <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/item_list_iv_icon" android:src="@drawable/zx_img"/> <TextView android:id="@+id/item_list_tv_icon" android:layout_width="wrap_content" android:layout_height="25dp" android:textSize="20sp" android:textStyle="bold" android:text="图片描述" /></LinearLayout>
效果展示:
0 0
- 使用RecyclerView展示GrideView效果
- RecyclerView分别展示ListView,GrideView,瀑布流效果之总结
- 使用RecyclerView展示瀑布流的效果
- RecyclerView表格展示GridView加HeadView效果
- Grideview的高级使用
- GrideView简单使用
- 使用RecyclerView展示checkBox全选反选
- MVP登录+recyclerview列表展示(带刷新效果)
- GrideView
- 使用GrideView实现日历控件
- ScrollView,ListView,GrideView,RecyclerView,ViewPager等多种view嵌套问题
- 使用ScrollView制作Title渐变,配合RecyclerView展示列表
- RecyclerView的多条目展示,使用OkHttp解析数据
- 使用Cnskype的预期效果展示
- 使用Recycler控件展示listview效果·
- 使用RecyclerView实现ListView,GridView效果
- 使用RecyclerView实现瀑布流效果
- 使用RecyclerView实现时间轴效果
- 线程生命周期状态图
- Thinkphp在iis环境下中文参数乱码
- 项目连续几天突然挂掉
- Prime Cuts UVA 406
- 科克曼女生问题
- 使用RecyclerView展示GrideView效果
- A
- 有趣的电脑技巧_电脑常用技巧
- 【技巧】百度地图搜周边
- 【tensorflow系列之(一)】win7下安装tensorflow
- HDFS之SequenceFile的读写操作
- 北邮OJ-278. 图像识别-14计院上机C
- tyvj 1505 打砖头
- uboot下init_sequence_f函数之reserve_arch