码迷,mamicode.com
首页 > 移动开发 > 详细

如何使用Android最新的RecyclerView取代ListView?

时间:2015-04-21 16:10:56      阅读:161      评论:0      收藏:0      [点我收藏+]

标签:android

效果图如下:

技术分享


使用RecyclerView之前需要先导入android.support.v7.widget.RecyclerView所在的jar包。就在support.v7下面,目录结构如下:

...\android-sdk-windows\extras\android\support\v7\recyclerview\libs\android-support-v7-recyclerview.jar


找到自己的SDK目录,按照上述路径找到android-support-v7-recyclerview.jar,然后将其放到Android工程目录下的libs中,即可开始使用:

import android.support.v7.widget.RecyclerView;

给出上面效果图的全部源代码,首先是MainActivity.java:

package zhangphil.recyclerview;

import android.support.v7.app.ActionBarActivity;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.View;
import android.view.ViewGroup;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;
import android.graphics.Color;
import android.os.Bundle;

/**
 * @author Zhang Phil
 * 
 *         本例言简意赅的演示了如何使用Android最新的RecyclerView取代ListView
 *
 */
public class MainActivity extends ActionBarActivity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		RecyclerView mRecyclerView = (RecyclerView) findViewById(R.id.my_recycler_view);

		LinearLayoutManager mLayoutManager = new LinearLayoutManager(this);

		// 设置参数为:LinearLayout.HORIZONTAL ,即可轻松实现水平的“ListView”。
		// 如果竖直(LinearLayout.VERTICAL),就是以前的ListView样式。
		mLayoutManager.setOrientation(LinearLayout.HORIZONTAL);

		mRecyclerView.setLayoutManager(mLayoutManager);

		// 测试数据集
		String[] data = new String[20];
		for (int i = 0; i < data.length; i++) {
			data[i] = "数据-" + i;
		}

		RecyclerView.Adapter mAdapter = new MyAdapter(data);
		mRecyclerView.setAdapter(mAdapter);
	}

	// RecyclerView的适配器
	// RecyclerView和ListView类似,需要给定一个Adapter。
	public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> {

		// 数据集
		private String[] data;

		public MyAdapter(String[] dataset) {
			super();
			data = dataset;
		}

		// 此方法,目的是完成ViewHolder中子View的创建,换句话说,就是初始化ViewHolder中定义的各个对象。
		// 试想,如果没有,那么我们的onBindViewHolder中的set岂不是在null上面操作?!
		@Override
		public ViewHolder onCreateViewHolder(ViewGroup viewGroup, int i) {

			// inflate一个View,出于演示,我们直接使用Android系统提供的布局作为测试布局,
			// 一个用于显示内容的TextView
			View view = View.inflate(getApplication(),
					android.R.layout.simple_list_item_1, null);

			// 创建一个ViewHolder
			// 注意:此处需要把上一步的view实例作为参数传递到ViewHolder作为构造时的参数传递给Android系统使用。
			ViewHolder holder = new ViewHolder(view);
			holder.mTextView = (TextView) view.findViewById(android.R.id.text1);
			holder.mTextView.setTextColor(Color.RED);
			holder.mTextView.setOnClickListener(new View.OnClickListener() {

				@Override
				public void onClick(View v) {
					Toast.makeText(getApplication(), ((TextView) v).getText(),
							Toast.LENGTH_SHORT).show();
				}
			});

			return holder;
		}

		// 在此方法里面,把数据元素和View相关联起来。把数据填到View中。
		// 用数据填充到View中,换句话说,用数据渲染View。
		// 这么做,可以达到松耦合:Data和View的分离。
		@Override
		public void onBindViewHolder(ViewHolder viewHolder, int i) {
			// 渲染数据到ViewHolder上
			viewHolder.mTextView.setText(data[i]);
		}

		// 无需多讲,此处和ListView中的适配器返回长度告诉ListView加载多长数据类似。
		@Override
		public int getItemCount() {
			return data.length;
		}

		// 此处的ViewHolder仅仅作为各类对象的容器即可,仅仅存放缓存数据。
		// 基本上,在这个ViewHolder里面只做定义相关的操作,定义View中的项目。
		// 当然,也可以在里面多做一些相关的动作。
		public class ViewHolder extends RecyclerView.ViewHolder {

			public TextView mTextView;

			public ViewHolder(View itemView) {
				super(itemView);
			}
		}
	}
}

MainActivity.java加载的activity_main.xml:

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <android.support.v7.widget.RecyclerView
        android:id="@+id/my_recycler_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</FrameLayout>




如何使用Android最新的RecyclerView取代ListView?

标签:android

原文地址:http://blog.csdn.net/zhangphil/article/details/45170845

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!