一、实验目的
将recyclerView的每个item增加点击功能,点击后跳转到一个新的view展示信息
二、使用的技术
开发工具:
主要技术:
使用 RecyclerView 创建动态列表
activity之前的跳转和传值
三、实验过程
实现一:实现页面跳转
步骤一:实现列表页面(同上一篇文章)和跳转页面内容
1.在Fragment1的tab1.xml文件中指定一个RecyclerView组件
新建一个item.xml文件作为RecyclerView组件每一行的内容:
运行之后的tab1页面:
2.新建一个activity作为跳转之后的页面
在对应的.xml文件设置自己想要的内容:
步骤二:实现跳转功能
1.在Myadapater.java文件中设置button,实现点击跳转
(只需要修改onBindViewHolder())
public void onBindViewHolder(@NonNull Myholder holder, int position) {
holder.textView.setText(list1.get(position));
holder.textView1.setText(list2.get(position));//显示列表数据内容
holder.button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent=new Intent();
Toast.makeText(context1,"跳转到歌曲详情页",Toast.LENGTH_LONG).show();//系统提示跳转成功
intent.setClass(context1,Activity3.class);//从本页面跳转到Activity3文件
Bundle bundle=new Bundle();//利用bundle进行传值
bundle.putString("name",list1.get(position));
bundle.putString("author",list2.get(position));
intent.putExtras(bundle);
context1.startActivity(intent);//运行Activity3
}
});
2.在Activity3中设置return按钮实现返回效果
public class Activity3 extends AppCompatActivity {
Button button3;
TextView textView,textView1;
@SuppressLint("MissingInflatedId")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_3);
textView=findViewById(R.id.textView12);
textView1=findViewById(R.id.textView13);
button3=findViewById(R.id.button3);
Intent intent=getIntent();//传递数据
String str1=intent.getExtras().getString("name");
textView.setText(str1);
String str2= intent.getExtras().getString("author");
textView1.setText(str2);
//设置点击效果——返回前一个页面
button3.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
finish();
}
});
Log.d("xr","3:onCreate...");//调试页面显示
}
实现二:实现activity之间的传值
步骤三:实现数据在两个页面之间的传递
1.在Fragment1中定义数据
list = new ArrayList<String>(Arrays.asList("编号89757","爱","血腥爱情故事","黑暗骑士","波斯猫","输情歌","童年"));
list1= new ArrayList<String>(Arrays.asList("林俊杰","莫文蔚","张惠妹","五月天","S.H.E","J.Sheon","罗大佑"));
adapter = new Myadapater(context, list,list1);//作为参数传递给Myadapater
2.在Myadapater的onBindViewHolder函数中包装数据
(使用bundle绑定数据)
Bundle bundle=new Bundle();
bundle.putString("name",list1.get(position));
bundle.putString("author",list2.get(position));
intent.putExtras(bundle);//传递bundle
3.在Activity3中接收并显示数据
Intent intent=getIntent();//接收数据
String str1=intent.getExtras().getString("name");
textView.setText(str1);//显示数据
String str2= intent.getExtras().getString("author");
textView1.setText(str2);//显示数据
四、实验结果
结果分析
问题一:Attempt to invoke virtual method 'void android.widget.Button.setOnClickListener(android.view.View$OnClickListener)' on a null object reference
原因:findViewById()找不到对应的组件。
解决方法:context1.startActivity(intent);
问题二:多个数据的传输并在不同的页面显示不同的内容
解决方法:多个数据用list = new ArrayList<String>(Arrays.asList());
显示不同的内容需要用到bundle.putString("name",list1.get(position));
问题三:不知道在哪里实现跳转功能
解决方法:因为Myadapater是一种适配器,所有列表里的功能都需要通过适配器实现,所以应该在Myadapater中实现跳转功能
结果截图
点击后跳转到另一个页面,在点击return,返回前一个页面
五、代码地址
与之前的类微信界面区分为两个部分,此次上传了整个项目