【定义】

看到这个标题,也许你会问什么是RecyclerView?其实开始的时候我也不知道- -,下面小编将带领大家领略RecyclerView的强大之处

【描述】

看完这个我想大家应该知道了吧,这个东西和ListView一样,只不过,这个…在设计的时候不需要考虑上述几个功能,即使要实现这几个功能,也是很简单的,仅仅需要几句话就可以搞定的

【使用】

使用的时候需要导入recyclerview-v7-21.0.0的jar包,然后在布局文件中添加这个控件

<android.support.v7.widget.RecyclerView/>

---------------------------------------------------------------我是一个帅帅的分割线-------------------------------------------------------

【案例】

小编将通过一个案例实现RecyclerView的使用,下面请看这个案例的实现效果

【关键步骤】

1.在布局文件中添加了对用的控件后,我们需要书写代码,既然和ListView肯定需要适配器,下面我们来看下适配器

package org.monster.recyclerviewdemo;

import android.content.Context;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView; import java.util.List; /**
* Created by monster on 2015/7/9.
* 继承RecyclerView,实现ListView的效果
* RecyclerView中google强烈要求使用ViewHolder
*/
public class SimpleAdapter extends RecyclerView.Adapter<MyViewHolder>{
private List<String> mData;
private Context context;
private LayoutInflater mInflater; /**
* 声明一个接口,用于实现点击事件
*/
public interface OnItemClickListener{
void OnItemClick(int position,View view);
void OnItemLongClick(int position,View view);
} private OnItemClickListener mOnItemClickListener; public void setOnItemClickListener(OnItemClickListener listener){
this.mOnItemClickListener=listener;
} /**构造方法的实现**/ public SimpleAdapter(List<String> mData,Context context){
this.mData=mData;
this.context=context;
mInflater=LayoutInflater.from(context);
} /**
* 创建ViewHolder
* @param parent
* @param viewType
* @return
*/
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view=mInflater.inflate(R.layout.recycler_item,parent,false);
MyViewHolder viewHolder=new MyViewHolder(view);
return viewHolder;
} /**
* 绑定ViewHolder类,即给控件赋值
* @param holder
* @param position
*/
@Override
public void onBindViewHolder(final MyViewHolder holder, final int position) {
holder.tv.setText(mData.get(position));
if (mOnItemClickListener!=null){ holder.itemView.setOnClickListener(new View.OnClickListener() { @Override
public void onClick(View v) {
int LayoutPosition=holder.getLayoutPosition(); //得到布局的position
mOnItemClickListener.OnItemClick(LayoutPosition,holder.itemView); }
}); //longclickListener
holder.itemView.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
int LayoutPosition=holder.getLayoutPosition(); //得到布局的position
mOnItemClickListener.OnItemLongClick(LayoutPosition,holder.itemView);
return false;
}
});
} } @Override
public int getItemCount() {
return mData.size();
} public void addData(int position){
mData.add(position,"Insert One");
notifyItemInserted(position);
} public void deleteData(int position){
mData.remove(position);
notifyItemRemoved(position);
}
} /**
* ViewHolder类,这个类的作用主要用于实例化控件
*/
class MyViewHolder extends RecyclerView.ViewHolder{
TextView tv; //声明控件
public MyViewHolder(View itemView) {
super(itemView);
/**初始化控件**/
tv= (TextView) itemView.findViewById(R.id.tv);
}
}

ps:

代码中我们可以看到我们继承了RecyclerView.Adapter<MyViewHolder>,实现了未实现的方法,但是一定要注意,google在这里要求必须实现ViewHolder这个类,我们通过代码知道,通过设计了ViewHolder使我们的类更加的简洁了,更重要的是我们的代码更加的实用了。

2.我们来看下MainActivity中的代码:

package org.monster.recyclerviewdemo;

import android.content.Intent;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.support.v7.widget.DefaultItemAnimator;
import android.support.v7.widget.GridLayoutManager;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.StaggeredGridLayoutManager;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Switch;
import android.widget.Toast; import java.util.ArrayList;
import java.util.List; public class MainActivity extends ActionBarActivity {
private RecyclerView recyclerView;
private List<String> mDatas;
private SimpleAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); initDatas(); initView(); adapter=new SimpleAdapter(mDatas,this);
recyclerView.setAdapter(adapter); //设置RecyclerView的布局管理
LinearLayoutManager layoutManager=new LinearLayoutManager(this,LinearLayoutManager.VERTICAL,false);
recyclerView.setLayoutManager(layoutManager); //设置RecyclerView的item间的分割线
// recyclerView.addItemDecoration(new DividerItemDecoration(this,DividerItemDecoration.VERTICAL_LIST)); //设置RecyclerView的动画
recyclerView.setItemAnimator(new DefaultItemAnimator()); //设置监听事件
adapter.setOnItemClickListener(new SimpleAdapter.OnItemClickListener() {
@Override
public void OnItemClick(int position, View view) {
Toast.makeText(MainActivity.this,"Click: "+position,Toast.LENGTH_SHORT).show();
} @Override
public void OnItemLongClick(int position, View view) {
Toast.makeText(MainActivity.this,"Long click: "+position,Toast.LENGTH_SHORT).show();
}
});
} private void initView() {
recyclerView= (RecyclerView) findViewById(R.id.RecyclerView); } /**
* 加载数据源
*/
private void initDatas() {
mDatas=new ArrayList<String>();
for(int i='A';i<'z';i++){
mDatas.add(" "+(char)i);
}
} @Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
} @Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId(); switch (id){
case R.id.action_add:
adapter.addData(1);
break; case R.id.action_delete:
adapter.deleteData(1);
break;
case R.id.action_listview:
recyclerView.setLayoutManager(new LinearLayoutManager(this));
break;
case R.id.action_gridview:
recyclerView.setLayoutManager(new GridLayoutManager(this,3));
break;
case R.id.action_hor_gridview:
recyclerView.setLayoutManager(new StaggeredGridLayoutManager(3,StaggeredGridLayoutManager.HORIZONTAL));
break;
case R.id.action_staggered:
Intent i=new Intent(this,StaggerActivity.class);
startActivity(i);
break; } return super.onOptionsItemSelected(item);
}
}

PS:

适配器的使用和ListView的使用一样,但是这时候当我们运行程序会发现没有分割线,整个页面成一个了,所以我们需要使用addItemDecoration添加分割线

      设置RecyclerView的item间的分割线
recyclerView.addItemDecoration(new DividerItemDecoration(this,DividerItemDecoration.VERTICAL_LIST));

Comic Sans MS在分割线的部分我们需要引入github中的一个分割线文件:

package org.monster.recyclerviewdemo;

/*
* Copyright (C) 2014 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/ import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Canvas;
import android.graphics.Rect;
import android.graphics.drawable.Drawable;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.util.Log;
import android.view.View; /**
* This class is from the v7 samples of the Android SDK. It's not by me!
* <p/>
* See the license above for details.
*/
public class DividerItemDecoration extends RecyclerView.ItemDecoration
{ private static final int[] ATTRS = new int[] { android.R.attr.listDivider }; public static final int HORIZONTAL_LIST = LinearLayoutManager.HORIZONTAL; public static final int VERTICAL_LIST = LinearLayoutManager.VERTICAL; private Drawable mDivider; private int mOrientation; public DividerItemDecoration(Context context, int orientation)
{
final TypedArray a = context.obtainStyledAttributes(ATTRS);
mDivider = a.getDrawable(0);
a.recycle();
setOrientation(orientation);
} public void setOrientation(int orientation)
{
if (orientation != HORIZONTAL_LIST && orientation != VERTICAL_LIST)
{
throw new IllegalArgumentException("invalid orientation");
}
mOrientation = orientation;
} @Override
public void onDraw(Canvas c, RecyclerView parent)
{
if (mOrientation == VERTICAL_LIST) {
drawVertical(c, parent);
} else {
drawHorizontal(c, parent);
}
} public void drawVertical(Canvas c, RecyclerView parent)
{
final int left = parent.getPaddingLeft();
final int right = parent.getWidth() - parent.getPaddingRight(); final int childCount = parent.getChildCount(); for (int i = 0; i < childCount; i++)
{
final View child = parent.getChildAt(i);
RecyclerView v = new RecyclerView(
parent.getContext());
final RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) child
.getLayoutParams();
final int top = child.getBottom() + params.bottomMargin;
final int bottom = top + mDivider.getIntrinsicHeight();
mDivider.setBounds(left, top, right, bottom);
mDivider.draw(c);
}
} public void drawHorizontal(Canvas c, RecyclerView parent)
{
final int top = parent.getPaddingTop();
final int bottom = parent.getHeight() - parent.getPaddingBottom(); final int childCount = parent.getChildCount();
for (int i = 0; i < childCount; i++)
{
final View child = parent.getChildAt(i);
final RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) child
.getLayoutParams();
final int left = child.getRight() + params.rightMargin;
final int right = left + mDivider.getIntrinsicHeight();
mDivider.setBounds(left, top, right, bottom);
mDivider.draw(c);
}
} @Override
public void getItemOffsets(Rect outRect, int itemPosition,
RecyclerView parent)
{
if (mOrientation == VERTICAL_LIST)
{
outRect.set(0, 0, 0, mDivider.getIntrinsicHeight());
} else
{
outRect.set(0, 0, mDivider.getIntrinsicWidth(), 0);
}
}
}

如何在RecyleView中设计布局管理?这个布局管理可以让你的页面实现ListView和GridView的自由切换

       //设置RecyclerView的布局管理
LinearLayoutManager layoutManager=new LinearLayoutManager(this,LinearLayoutManager.VERTICAL,false);
recyclerView.setLayoutManager(layoutManager);

如何咋RecyclerView中增加添加item和删除item的动画?

(附录动画效果的Github链接:https://github.com/gabrielemariotti/RecyclerViewItemAnimators

      //设置RecyclerView的动画
recyclerView.setItemAnimator(new DefaultItemAnimator());

如何在对Recycler中的item设置监听事件?这个监听事件系统不提供,需要我们手动编写

--->我们需要在适配器添加一个接口:

/**
* 声明一个接口,用于实现点击事件
*/
public interface OnItemClickListener{
void OnItemClick(int position,View view);
void OnItemLongClick(int position,View view);
} private OnItemClickListener mOnItemClickListener; public void setOnItemClickListener(OnItemClickListener listener){
this.mOnItemClickListener=listener;
} /**构造方法的实现**/ public SimpleAdapter(List<String> mData,Context context){
this.mData=mData;
this.context=context;
mInflater=LayoutInflater.from(context);
}

--->在onBindViewHolder中设置监听事件的方法

/**
* 绑定ViewHolder类,即给控件赋值
* @param holder
* @param position
*/
@Override
public void onBindViewHolder(final MyViewHolder holder, final int position) {
holder.tv.setText(mData.get(position));
if (mOnItemClickListener!=null){ holder.itemView.setOnClickListener(new View.OnClickListener() { @Override
public void onClick(View v) {
int LayoutPosition=holder.getLayoutPosition(); //得到布局的position
mOnItemClickListener.OnItemClick(LayoutPosition,holder.itemView); }
}); //longclickListener
holder.itemView.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
int LayoutPosition=holder.getLayoutPosition(); //得到布局的position
mOnItemClickListener.OnItemLongClick(LayoutPosition,holder.itemView);
return false;
}
});
} }

--->>在MainActivity中调用如

//设置监听事件
adapter.setOnItemClickListener(new SimpleAdapter.OnItemClickListener() {
@Override
public void OnItemClick(int position, View view) {
Toast.makeText(MainActivity.this,"Click: "+position,Toast.LENGTH_SHORT).show();
} @Override
public void OnItemLongClick(int position, View view) {
Toast.makeText(MainActivity.this,"Long click: "+position,Toast.LENGTH_SHORT).show();
}
});

上述即为RecyclerView的简单实用,程序中的其他样式敬请参考【源码】

【视频】

http://www.imooc.com/learn/424

【源码】

https://github.com/monsterLin/recyclerviewdemo

Android程序设计-RecyclerView的使用的更多相关文章

  1. [Android]使用RecyclerView替代ListView(三)

    以下内容为原创,转载请注明: 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/4268097.html  这次来使用RecyclerView实现Pinn ...

  2. [Android]使用RecyclerView替代ListView(二)

    以下内容为原创,转载请注明: 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/4242541.html 以前写过一篇“[Android]使用Adapte ...

  3. [Android]使用RecyclerView替代ListView(一)

    以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/4232560.html RecyclerView是一个比List ...

  4. Android程序设计-简单手机通讯录

    在微信中,手机QQ中你会发现软件读取手机通讯录这个功能,这个功能使得软件更好的与手机联系人绑定,从而达到分享,拨打电话,读取用户信息等操作.下面我们将通过一个demo实现这个功能 首先我们看一下效果图 ...

  5. [Android]使用RecyclerView替代ListView(四:SeizeRecyclerView)

    以下内容为原创,欢迎转载,转载请注明 来自天天博客:<> [Android]使用RecyclerView替代ListView(四:SeizeRecyclerView) 在RecyclerV ...

  6. 20155212 实验四 《Android程序设计》 实验报告

    20155212 实验四 <Android程序设计> 实验报告 (一)Android Stuidio的安装测试 参考<Java和Android开发学习指南(第二版)(EPUBIT,J ...

  7. 20162330 实验四 《Android程序设计》 实验报告

    2016-2017-2 实验报告目录: 1 2 3 4 5 20162330 实验四 <Android程序设计> 实验报告 课程名称:<程序设计与数据结构> 学生班级:1623 ...

  8. 实验四 Android程序设计 实验报告

    实验四 Android程序设计 实验报告 目录 代码托管地址 Android程序设计-1 Android程序设计-2 Android程序设计-3 Android程序设计-4 Android程序设计-5 ...

  9. 20162302 实验四《Android程序设计》实验报告

    实 验 报 告 课程:程序设计与数据结构 姓名:杨京典 班级:1623 学号:20162302 实验名称:Android程序设计 实验器材:装有Android Studio的联想拯救者80RQ 实验目 ...

随机推荐

  1. Html网页使用jQuery传递参数并获取Web API的数据

    昨天Insus.NET有开始学习Web API,<ASP.NET MVC的Web Api的实练>http://www.cnblogs.com/insus/p/4334316.html .其 ...

  2. 职责链(Chain of Responsibility)模式在航空货运中的运用实例

    设计模式这东西,基本上属于“看懂一瞬间,用会好几年”.只有实际开发中,当某一模式很好的满足了业务需求时,才会有真切的感觉.借用一句<闪电侠>中,绿箭侠教导闪电侠的台词:“不是你碰巧遇到了它 ...

  3. 谈谈软件项目的dependency

    说到软件项目的依赖管理,可以从三个方面来考虑: 一.由build system控制的dependency 现在的build system,都支持一定程度上的dependency management, ...

  4. 海王星给你好看!FineUI v4.0公测版发布暨《你找BUG我送书》活动开始(活动已结束!)

    <FineUI v4.0 你找BUG我送书>活动已结束,恭喜如下三位网友获得由 FineUI 作者亲自翻译的图书<jQuery实战 第二版>! 奋斗~ 吉吉﹑ purplebo ...

  5. Theano2.1.14-基础知识之理解为了速度和正确性的内存别名

    来自:http://deeplearning.net/software/theano/tutorial/aliasing.html Understanding Memory Aliasing for ...

  6. JSON简介以及用法汇总

    什么是JSON? JavaScript 对象表示法(JavaScript Object Notation). JSON是一种轻量级的数据交换格式,某个JSON格式的文件内部譬如可以长成这样: { &q ...

  7. unity3d CarWaypoints插件

    编写初衷: 1.网上没有现成的好用的waypoints插件 2.自己在做一个赛车游戏,如果没有这款插件的话在制作游戏的过程中会被累成狗 3.从来没有接触过插件方面的东西,所以想自己尝试一下 插件用途: ...

  8. web性能优化——简介

    简介 性能优化的第一准则:加缓存.几乎绝大部分优化都围绕这个来进行的.让用户最快的看到结果. 性能优化的第二准则:最小原则.绝不提供多余的信息.比如,静态资源(图片.css.js)压缩,图片的滚动加载 ...

  9. .Net分布式异常报警系统-客户端及服务端API

    客户端 客户端的作用就是捕获未处理异常, 发送异常到服务端. 关于捕获未处理异常的方法参考 http://www.cnblogs.com/youring2/archive/2012/04/25/246 ...

  10. hihocoder [Offer收割]编程练习赛4

    描述 最近天气炎热,小Ho天天宅在家里叫外卖.他常吃的一家餐馆一共有N道菜品,价格分别是A1, A2, ... AN元.并且如果消费总计满X元,还能享受优惠.小Ho是一个不薅羊毛不舒服斯基的人,他希望 ...