使用RecyclerView实现水平列表
时间:2022-07-27
本文章向大家介绍使用RecyclerView实现水平列表,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
本文实例为大家分享了RecyclerView实现水平列表的具体代码,供大家参考,具体内容如下
1、效果图
2、activity_horizontallistview.xml
<?xml version="1.0" encoding="utf-8"?
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerview_horizontal1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:overScrollMode="never"
android:scrollbars="none"
/
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerview_horizontal2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:overScrollMode="never"
android:scrollbars="none"
/
<android.support.v7.widget.RecyclerView
android:id="@+id/recyclerview_horizontal3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:overScrollMode="never"
android:scrollbars="none"
/
</LinearLayout
3、activity代码
package ivan.com.appbackendtest;
import android.content.Context;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
/**
* Created by ivan on 2017/6/9.
*/
public class HorizontalListviewActivity extends AppCompatActivity {
private RecyclerView recyclerview_horizontal1;
private GalleryAdapter mAdapter1;
private RecyclerView recyclerview_horizontal2;
private GalleryAdapter mAdapter2;
private RecyclerView recyclerview_horizontal3;
private GalleryAdapter mAdapter3;
private List<Integer mDatas1;
private List<Integer mDatas2;
private List<Integer mDatas3;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_horizontallistview);
initDatas();
//得到控件
recyclerview_horizontal1 = (RecyclerView)findViewById(R.id.recyclerview_horizontal1);
//设置布局管理器
LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
linearLayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
recyclerview_horizontal1.setLayoutManager(linearLayoutManager);
//设置适配器
mAdapter1 = new GalleryAdapter(this, mDatas1);
recyclerview_horizontal1.setAdapter(mAdapter1);
//得到控件
recyclerview_horizontal2 = (RecyclerView)findViewById(R.id.recyclerview_horizontal2);
//设置布局管理器
LinearLayoutManager linearLayoutManager2 = new LinearLayoutManager(this);
linearLayoutManager2.setOrientation(LinearLayoutManager.HORIZONTAL);
recyclerview_horizontal2.setLayoutManager(linearLayoutManager2);
//设置适配器
mAdapter2 = new GalleryAdapter(this, mDatas2);
recyclerview_horizontal2.setAdapter(mAdapter2);
//得到控件
recyclerview_horizontal3 = (RecyclerView)findViewById(R.id.recyclerview_horizontal3);
//设置布局管理器
LinearLayoutManager linearLayoutManager3 = new LinearLayoutManager(this);
linearLayoutManager3.setOrientation(LinearLayoutManager.HORIZONTAL);
recyclerview_horizontal3.setLayoutManager(linearLayoutManager3);
//设置适配器
mAdapter3 = new GalleryAdapter(this, mDatas3);
recyclerview_horizontal3.setAdapter(mAdapter3);
}
private void initDatas()
{
mDatas1 = new ArrayList< (Arrays.asList(R.mipmap.ic_launcher));
mDatas2 = new ArrayList< (Arrays.asList(R.mipmap.ic_launcher,R.mipmap.ic_launcher));
mDatas3 = new ArrayList< (Arrays.asList(R.mipmap.ic_launcher,R.mipmap.ic_launcher,R.mipmap.ic_launcher,R.mipmap.ic_launcher,R.mipmap.ic_launcher,R.mipmap.ic_launcher));
}
public class GalleryAdapter extends
RecyclerView.Adapter<GalleryAdapter.ViewHolder
{
private LayoutInflater mInflater;
private List<Integer mDatas;
public GalleryAdapter(Context context, List<Integer datats)
{
mInflater = LayoutInflater.from(context);
mDatas = datats;
}
public class ViewHolder extends RecyclerView.ViewHolder
{
public ViewHolder(View arg0)
{
super(arg0);
}
ImageView mImg;
TextView mTxt;
}
@Override
public int getItemCount()
{
return mDatas.size();
}
/**
* 创建ViewHolder
*/
@Override
public ViewHolder onCreateViewHolder(ViewGroup viewGroup, int i)
{
View view = mInflater.inflate(R.layout.item_listview,
viewGroup, false);
ViewHolder viewHolder = new ViewHolder(view);
viewHolder.mImg = (ImageView) view
.findViewById(R.id.id_index_gallery_item_image);
return viewHolder;
}
/**
* 设置值
*/
@Override
public void onBindViewHolder(final ViewHolder viewHolder, final int i)
{
viewHolder.mImg.setImageResource(mDatas.get(i));
}
}
}
4、核心代码
//得到控件
recyclerview_horizontal1 = (RecyclerView)findViewById(R.id.recyclerview_horizontal1);
//设置布局管理器
LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
linearLayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
recyclerview_horizontal1.setLayoutManager(linearLayoutManager);
//设置适配器
mAdapter1 = new GalleryAdapter(this, mDatas1);
recyclerview_horizontal1.setAdapter(mAdapter1);
以上就是本文的全部内容,希望对大家的学习有所帮助。
- 剑指OFFER之打印1到最大的N位数(九度OJ1515)
- GridView实战二:使用ObjectDataSource数据源控件
- javascript实例:逐条记录停顿的走马灯
- Python标准库05 存储对象 (pickle包,cPickle包)
- macOS平台下虚拟摄像头的研发总结
- 网页优化系列三:使用压缩后置viewstate
- 网页优化系列三:使用压缩后置viewstate
- macOS下利用dSYM文件将crash文件中的内存地址转换为可读符号
- 微信小程序的大动作
- Python标准库04 文件管理 (部分os包,shutil包)
- 手把手教你Dojo入门
- location的hash部分和使用window.onhashchange实现ajax请求内容时使用浏览器后退和前进功能
- 协议森林01 邮差与邮局 (网络协议概观)
- Mac OS平台下应用程序安装包制作工具Packages的使用介绍
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法