用Android Studio实现对带RecycleView页面的点击跳转

实验环境:

windows操作系统、Android Studio

界面展示

用RecycleView创建一个内地歌手列表

点击后跳转到歌曲页面,点击返回可以返回到歌手列表

Activity的生命周期

1.启动Activity:系统会先调用onCreate方法,然后调用onStart方法,最后调用onResume,Activity进入运行状态。

2.当前Activity被其他Activity覆盖其上或被锁屏:系统会调用onPause方法,暂停当前Activity的执行。

3.当前Activity由被覆盖状态回到前台或解锁屏:系统会调用onResume方法,再次进入运行状态。

4.当前Activity转到新的Activity界面或按Home键回到主屏,自身退居后台:系统会先调用onPause方法,然后调用onStop方法,进入停滞状态。

5.用户后退回到此Activity:系统会先调用onRestart方法,然后调用onStart方法,最后调用onResume方法,再次进入运行状态。

6.当前Activity处于被覆盖状态或者后台不可见状态,即第2步和第4步,系统内存不足,杀死当前Activity,而后用户退回当前Activity:再次调用onCreate方法、onStart方法、onResume方法,进入运行状态。

7.用户退出当前Activity:系统先调用onPause方法,然后调用onStop方法,最后调用onDestory方法,结束当前Activity。

核心代码

在上一次实验的基础上作修改

新增歌曲页面cuijian.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_margin="5dp"
    android:background="@color/light_blue"
    android:orientation="vertical">


    <ImageView
        android:id="@+id/cuijian_pic"
        android:layout_width="match_parent"
        android:layout_height="100dp"
        android:layout_weight="1"
        app:srcCompat="@drawable/cuijian2" />

    <TextView
        android:id="@+id/remengequ"
        android:layout_width="match_parent"
        android:layout_height="20dp"
        android:layout_margin="10dp"
        android:layout_weight="1"
        android:gravity="center"
        android:text="热门歌曲"
        android:textSize="30sp" />

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="75dp"
        android:orientation="horizontal"
        android:padding="6dp">

        <ImageView
            android:id="@+id/music1"
            android:layout_width="60dp"
            android:layout_height="60dp"
            app:srcCompat="@drawable/music" />

        <TextView
            android:id="@+id/song1"
            android:layout_width="match_parent"
            android:layout_height="75dp"
            android:text="一无所有"
            android:textSize="50dp" />
    </LinearLayout>

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="75dp"
        android:orientation="horizontal"
        android:padding="6dp">

        <ImageView
            android:id="@+id/music2"
            android:layout_width="60dp"
            android:layout_height="60dp"
            app:srcCompat="@drawable/music" />

        <TextView
            android:id="@+id/song2"
            android:layout_width="match_parent"
            android:layout_height="75dp"
            android:text="假行僧"
            android:textSize="50dp" />
    </LinearLayout>

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="75dp"
        android:orientation="horizontal"
        android:padding="6dp">

        <ImageView
            android:id="@+id/music3"
            android:layout_width="60dp"
            android:layout_height="60dp"
            app:srcCompat="@drawable/music" />

        <TextView
            android:id="@+id/song3"
            android:layout_width="match_parent"
            android:layout_height="75dp"
            android:text="光冻"
            android:textSize="50dp" />
    </LinearLayout>

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_width="match_parent"
        android:layout_height="75dp"
        android:orientation="horizontal"
        android:padding="6dp">

        <ImageView
            android:id="@+id/music4"
            android:layout_width="60dp"
            android:layout_height="60dp"
            app:srcCompat="@drawable/music" />

        <TextView
            android:id="@+id/song4"
            android:layout_width="match_parent"
            android:layout_height="75dp"
            android:text="花房姑娘"
            android:textSize="50dp" />
    </LinearLayout>

    <Button
        android:id="@+id/btn_back"
        android:layout_width="100dp"
        android:layout_height="5dp"
        android:layout_gravity="center"
        android:layout_weight="1"
        android:alpha="0.5"
        android:text="返回"
        android:textColor="#000000"
        android:textSize="18sp" />
</LinearLayout>

歌曲页面对应的java文件cuijianActivity.java

package com.example.project1;

import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;

public class cuijianActivity extends AppCompatActivity {
    //好友名字
    private TextView song1;
    //好友信息
    private TextView song2;
    //好友照片
    private TextView song3;
    private TextView song4;
    private ImageView cuijian_pic;
    private ImageView music1;
    private ImageView music2;
    private ImageView music3;
    private ImageView music4;

    //返回上个页面按钮
    private Button btn_back;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.cuijian);
        init();
        setListeners();
    }

    public void init() {
        song1 = (TextView) findViewById(R.id.song1);
        song2 = (TextView) findViewById(R.id.song2);
        song3 = (TextView) findViewById(R.id.song3);
        song4 = (TextView) findViewById(R.id.song4);
        cuijian_pic = (ImageView) findViewById(R.id.cuijian_pic);
        music1 = (ImageView) findViewById(R.id.music1);
        music2 = (ImageView) findViewById(R.id.music2);
        music3 = (ImageView) findViewById(R.id.music3);
        music4 = (ImageView) findViewById(R.id.music4);
        btn_back = (Button) findViewById(R.id.btn_back);
    }

    private void setListeners() {
        btn_back.setOnClickListener(backMain);
    }

    private Button.OnClickListener backMain = new Button.OnClickListener() {
        @Override
        public void onClick(View arg0) {
            cuijianActivity.this.finish();
        }
    };

}

把cuijianActivity添加到mainfest中

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.project1">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/Theme.Project1">
        <activity
            android:name=".MainActivity"
            android:exported="true">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".cuijianActivity" />
    </application>

</manifest>

修改Adapter中的onBindViewHolder

@Override
    public void onBindViewHolder(myViewHodler holder, int position) {
        //根据点击位置绑定数据
        GoodsEntity data = goodsEntityList.get(position);
        //        holder.mItemGoodsImg;
        holder.mItemGoodsName.setText(data.goodsName);//获取实体类中的name字段并设置
        //holder.mItemGoodsPrice.setText(data.goodsPrice);//获取实体类中的price字段并设置

        //设置按钮
        holder.itemView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Toast.makeText(context, "您点击的歌手是:" + data.goodsName, Toast.LENGTH_SHORT).show();
                //跳转到好友详情页面
                Intent intent = new Intent();
                intent.setClass(context,cuijianActivity.class);
                context.startActivity(intent);
            }

        });


    }

小结

1.在本次实验中,在上次实验基础上对原有recycleView的页面进行点击跳转设计,并对页面布局和背景颜色稍作修饰,另外还实现了跳转返回功能。

2.暂不支持跳转到其他歌手详情页面。

代码已上传至gitee

  • 0
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值