移动开发作业2:实现recyclerView页面的每个item点击跳转

作业目标

依托作业1,将recyclerView的每个item增加点击功能,点击后跳转到一个新的view展示信息

开发技术

ArrayList<Map<String,Object>>(),HashMap,recyclerView,intent,startActivity()

思路分析
1.设计recyclerView页面

2.创建新的activity来实现点击跳转

设计过程

一、设计recyclerView页面

1.修改作业1中的item.xml,使其成为类微信消息界面

2.编写对应的适配器Myadapter,配置消息界面里recyclerView的内容展示和点击跳转功能

package com.example.myapplication;

import android.annotation.SuppressLint;
import android.content.Context;
import android.content.Intent;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;

import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;

import java.util.List;
import java.util.Map;

public class Myadapter extends RecyclerView.Adapter <Myadapter.Myholder> {
    Context context1;
    //List<String> list1;
    List<Map<String,Object>> data1;
    public Myadapter(Context context,List<Map<String,Object>> data) {
        context1=context;
        data1=data;
    }

    @NonNull
    @Override
    public Myholder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View view=LayoutInflater.from(context1).inflate(R.layout.item,parent,false);

        Myholder myholder=new Myholder(view);
        return myholder;
    }

    @Override
    public void onBindViewHolder(@NonNull Myholder holder,
                                 @SuppressLint("RecyclerView") int position) {
        holder.avatar.setImageResource((int)(data1.get(position).get("头像")));
        holder.name.setText(data1.get(position).get("联系人").toString());
        holder.content.setText(data1.get(position).get("消息").toString());
        holder.tipView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent=new Intent(context1,MessageDetailActivity.class);
                intent.putExtra("消息内容",data1.get(position).get("消息内容").toString());

                context1.startActivity(intent);
            }
        });
    }

    @Override
    public int getItemCount() {
        return data1.size();
    }
    public class Myholder extends RecyclerView.ViewHolder{
        LinearLayout tipView;
        TextView name;
        TextView content;
        ImageView avatar;
        public Myholder(@NonNull View itemView){

            super(itemView);
            tipView=itemView.findViewById(R.id.M_layout);
            name=itemView.findViewById(R.id.textViewM1);
            content=itemView.findViewById(R.id.textViewM2);
            avatar=itemView.findViewById(R.id.imageViewM);
        }
    }
}

3.在消息界面对应的java文件(即作业1中的fragment1)中写入并管理我们所要展示的消息内容

package com.example.myapplication;
import android.os.Bundle;
import androidx.fragment.app.Fragment;

import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;

import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class fragment1 extends Fragment{
    private View view;
    private Myadapter myadapter;
    private RecyclerView recyclerView;
    private List<String> list1;
    List <Map<String,Object>> data;

    @Override
    public View onCreateView(LayoutInflater inflater,ViewGroup container,
                             Bundle savedInstanceState) {
        view = inflater.inflate(R.layout.tab1, container, false);
        recyclerView = view.findViewById(R.id.recycleview);

        data=new ArrayList<Map<String,Object>>();
        String[] names={"爸爸","妈妈","哥哥","姐姐","弟弟","妹妹"};
        String[] message={"这是爸爸的消息","这是妈妈的消息","这是哥哥的消息",
                "这是姐姐的消息","这是弟弟的消息","这是妹妹的消息"};
        String[] M_detail={"爸爸的消息内容","妈妈的消息内容","哥哥的消息内容",
                "姐姐的消息内容","弟弟的消息内容","妹妹的消息内容"};
        int[] image={R.drawable.picturef,R.drawable.picturem,R.drawable.pictureb,
                R.drawable.pictures,R.drawable.pictureyb,R.drawable.pictureys};
        /*list1 = new ArrayList<>();
        for (int i = 0; i < 9; i++) {
            list1.add("这是第" + i + "条消息");
        }*/
        for(int i=0;i<names.length;i++){
            Map<String,Object> map=new HashMap<String,Object>();
            map.put("联系人",names[i]);
            map.put("消息",message[i]);
            map.put("头像",image[i]);
            map.put("消息内容",M_detail[i]);
            data.add(map);
        }
        myadapter = new Myadapter(view.getContext(), data);
        LinearLayoutManager manager = new LinearLayoutManager(view.getContext());
        manager.setOrientation(LinearLayoutManager.VERTICAL);
        recyclerView.setLayoutManager(manager);
        recyclerView.setAdapter(myadapter);
        return view;
    }
}

二、新建activity实现item的点击跳转

1.新建activity用来展现跳转后的内容

2.设计其对应的activity_message_detail.xml文件,实现我们想要的页面布局

3.实现页面跳转和参数传递

为了方便,我只创建了一个activity,但要实现点击不同item跳转到对应的内容,我们可以通过intent来传递和接收对应的参数。

(1)在Myadapter中写一个startActivity()函数,实现点击item跳转到其详细内容页面

    public void onBindViewHolder(@NonNull Myholder holder,
                                 @SuppressLint("RecyclerView") int position) {
        holder.avatar.setImageResource((int)(data1.get(position).get("头像")));
        holder.name.setText(data1.get(position).get("联系人").toString());
        holder.content.setText(data1.get(position).get("消息").toString());
        holder.tipView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent=new Intent(context1,MessageDetailActivity.class);
                intent.putExtra("消息内容",data1.get(position).get("消息内容").toString());

                context1.startActivity(intent);
            }
        });
    }

(2)在Myadapter里面使用函数putExtra()向MessageDetailActivity传递参数,在MessageDetailActivity里使用getStringExtra()来接收intent传来的内容

Myadapter.java:

    holder.tipView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent=new Intent(context1,MessageDetailActivity.class);
                intent.putExtra("消息内容",data1.get(position).get("消息内容").toString());

                context1.startActivity(intent);
            }
        });
    }

MessageDetailActivity.java:

package com.example.myapplication;

import androidx.appcompat.app.AppCompatActivity;

import android.annotation.SuppressLint;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

public class MessageDetailActivity extends AppCompatActivity {
    TextView textView;
    Button button;

    @SuppressLint("MissingInflatedId")
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_message_detail);
        Intent intent=getIntent();
        String detail=intent.getStringExtra("消息内容");
        textView=findViewById(R.id.M_detail);
        button=findViewById(R.id.M_returnback);
        textView.setText(detail);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                finish();
            }
        });
    }
}

(3)MessageDetailActivity.java通过返回按钮button的监听使用finish()函数来退出当前页面,回到初始的recyclerView页面

        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                finish();
            }
        });

三、效果展示

AS_Work2

四、总结

这次实验我分两次完成的:第一次我初步实现了跳转的功能,也就是通过startActivity()函数跳转到一个新页面,但是所有item跳转后的内容是一样的;第二次在前一次的基础上我实现了参数传递的效果,从而达到点击不同item跳转到不同消息内容的效果。实现页面跳转这一项并不难实现,但是实现参数传递的时候很容易因为粗心导致项目出错,所以参数传递花费了我较长的时间,但是实现以后发现就是putExtra()和getStringExtra()有没有对应,还有就是recyclerView页面的展示内容要注意数据对应。

五、源代码地址

https://github.com/chenruiecho/-Work2

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值