文章目录
一、设计目标与功能说明
在之前微信界面的基础上,在某一页添加recycleview,并且对recycleview中的某一项点击后可以跳转到activity1,并且在activity1中通过按钮的点击可收到activity2的回传值
对于微信基础界面的设计,可以看我之前的博客使用AS自制建议微信界面
二、代码解析
1.layout文件夹
activity_my1.xml(activity1布局)
点击收藏按钮实现收到activity2的回传值
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MyActivity1">
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center"
android:text="这是新闻详情页面"
android:textSize="50sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.289" />
<Button
android:id="@+id/button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="收藏"
android:textSize="20sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.498"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView"
app:layout_constraintVertical_bias="0.497" />
</androidx.constraintlayout.widget.ConstraintLayout>
activity_my2.xml(activity2布局)
由于activity2只需要提供一个回传值,故可以将其布局设置为空
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MyActivity2">
</androidx.constraintlayout.widget.ConstraintLayout>
item_demo.xml(recycleview中每一条目布局)
text_view1为标题,text_view2为内容
<?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="100dp"
android:orientation="vertical">
<TextView
android:id="@+id/text_view1"
android:text="title"
android:textSize="30sp"
android:textStyle="bold"
android:textColor="@color/black"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="5dp"
android:layout_gravity="center"/>
<TextView
android:id="@+id/text_view2"
android:text="context"
android:textSize="30sp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="5dp"
android:layout_gravity="center"/>
</LinearLayout>
2.java文件夹
Itemben(与item_demo.xml对应)
根据item_demo.xml中的控件设置对应的成员变量
package com.example.myapplication_vx;
public class ItemBean {
public String title;
public String context;
}
ReckycleViewAdapter(自定义recycleview的适配器)
适配器需要完成三个方法的重写以及一个内部类的定义
首先定义成员变量和构造方法,传入的data为ItemBean类型的集合,其中存放了各个条目控件所对应的值
private List<ItemBean> mData;
private Context context;
private View view;
private OnItemClickListener mOnItemClickListener;
public RecyclerViewAdapter(Context context, List<ItemBean> data) {
this.context=context;
this.mData = data;
}
方法重写,其中MyViewHolder为内部类类型,第二个方法中的holder会在后面定义
@NonNull
@Override//创建条目view
public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
view = LayoutInflater.from(context)//实例化LayoutInflater
//传参 刚才创建的item_demo.xml
.inflate(R.layout.item_demo, parent, false);
// View view = View.inflate(parent.getContext(), R.layout.item_demo, null);
return new MyViewHolder(view);
}
@Override//绑定holder,设置数据
public void onBindViewHolder(@NonNull MyViewHolder holder, int position) {
holder.setData(mData.get(position),position);
}
@Override//返回条目个数
public int getItemCount() {
if (mData != null) {
return mData.size();
}
return 0;
}
定义内部类MyViewHolder,setData方法用来设置数据
public class MyViewHolder extends RecyclerView.ViewHolder {
private TextView textView1;
private TextView textView2