设置适配器来设置RecyclerView的表现形式
public class RecycleViewActivity extends Activity {
@BindView(R.id.recycleview)
RecyclerView recycleview;
List<People> DataList;
@BindView(R.id.removeButton)
Button removeButton;
@BindView(R.id.addButton)
Button addButton;
//定义适配器
private MyAdapter adapter;
public void onCreate(Bundle bunle) {
super.onCreate( bunle );
setContentView( R.layout.recycleviewlayout );
ButterKnife.bind( this );
//初始化子项数组数据
DataList = new ArrayList<People>();
initData();
//设置适配器,同时传入数据
adapter = new MyAdapter( this, DataList );
recycleview.setAdapter( adapter );
//创建LinearLayoutManager 对象 这里使用 LinearLayoutManager 是线性布局的意思
LinearLayoutManager layoutmanager = new LinearLayoutManager( this );
//滚动至索引值处的子项,此方法需要使用new LinearLayoutManager(this,LinearLayoutManager.VERTICAL,false )构造方法
//第二个参数指定布局垂直或水平,false为是否倒序
//LinearLayoutManager layoutmanager = new LinearLayoutManager(this,LinearLayoutManager.VERTICAL,false );
//layoutmanager.scrollToPosition( 19 );
//设置子项布局为横向
//layoutmanager.setOrientation( LinearLayoutManager.HORIZONTAL );
//设置RecyclerView 布局
recycleview.setLayoutManager( layoutmanager );
//使用网格布局,第二个参数为每行拥有的子项数
//GridLayoutManager gridLayoutManager=new GridLayoutManager( this,4,GridLayoutManager.HORIZONTAL,false);
//recycleview.setLayoutManager(gridLayoutManager);
//添加分割线,第一个参数上下文,第二个参数为布局方向
recycleview.addItemDecoration( new DividerItemDecoration( this, DividerItemDecoration.VERTICAL ) );
//使用自定义接口在外部设置点击事件
adapter.setItemClickListener( new MyAdapter.ItemClickListener() {
@Override
public void onItemClick(int position) {
if (position > 2) {
Toast.makeText( RecycleViewActivity.this, "我是大于3的地方", Toast.LENGTH_SHORT ).show();
} else if (position == 2) {
Toast.makeText( RecycleViewActivity.this, "我是=于3的地方", Toast.LENGTH_SHORT ).show();
} else
Toast.makeText( RecycleViewActivity.this, "我是小于3的地方", Toast.LENGTH_SHORT ).show();
}
} );
}
//初始化数据方法,同时传入适配器
private void initData() {
for (int i = 0; i < 6; i++) {
DataList.add( new People( "真理惟一可靠的标准就是永远自相符合。 —— 欧文", R.drawable.ouwen ) );
DataList.add( new People( "土地是以它的肥沃和收获而被估价的;才能也是土地,不过它生产的不是" +
"粮食,而是真理。如果只能滋生瞑想和幻想的话,即使再大的才能也只是砂地或盐池,那上面连小草也长不出来的。"
, R.drawable.bielin ) );
}
}
//添加子项和删除子项
@OnClick({R.id.removeButton, R.id.addButton})
public void onViewClicked(View view) {
switch (view.getId(http://www.my516.com)) {
case R.id.removeButton:
adapter.removeItem( 0 );
break;
case R.id.addButton:
adapter.addItem( 0, new People( "添加的数据", R.drawable.bielin ) );
//还需要滚动至添加位置
recycleview.scrollToPosition( 0 );
break;
}
}
}
原文地址:https://www.cnblogs.com/hyhy904/p/11373119.html
- 如何实现CDH元数据库MySQL的主主互备
- 在Kerberos环境使用Hue通过Oozie执行Sqoop作业报错异常分析
- 如何在Hue中配置已启用SSL的HttpFS服务
- 如何使用Nginx实现CDSW的跨网段访问
- 7.如何在OpenLDAP中实现将一个用户添加到多个组
- 如何使用java代码通过JDBC访问Sentry环境下的Hive
- 如何为HttpFS服务配置SSL
- 如何使用Java访问集成OpenLDAP并启用Sentry的Impala和Hive
- 如何向Hive表加载数据
- 如何使用Spark Streaming读取HBase的数据并写入到HDFS
- Hive Load本地数据文件异常分析
- 使用Java代码通过JDBC连接只启用Sentry的Impala异常分析
- 如何在CDSW中定制Docker镜像
- 干货:排名前 16 的 Java 工具类!
- 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 数组属性和方法
- 数据分析入门系列教程-常用图表
- PyTorch中的model.zero_grad() vs optimizer.zero_grad()
- Flask 入门系列教程(四)
- 代码审计
- ELF文件格式的详解
- 一个开源的RTOS的Chibios的评测
- CS学习笔记 | 25、邮件防御
- CS学习笔记 | 26、杀毒软件
- Python-pymysql
- 我又踩坑了!如何为HttpClient请求设置Content-Type标头?
- 在CentOS7上安装开源Verilog仿真工具EpicSim
- 【CS学习笔记】27、applet渗透测试手法
- Python-WSGI接口
- CentOS7-Nginx配置Let's-Encrypt-SSL证书
- CentOS7-Nginx编译安装