Android类微信界面在列表页上点击跳转到另一详情页面

目录

0 实验环境

1 功能说明

2 设计原理

3 核心代码

3.1 新建一个Activity类leimuActivity.java

3.2 在res/layout中增加一个布局配置文件leimu_tab.xml

3.3 修改AndroidManifest.xml,将leimuActivity添加进去

3.4 在res/values/strings中增加所用的字符串名称

3.5 修改RecyclerViewAdapter.java

4 最终实现效果

5 代码仓库

6 项目总结


0 运行环境

在Android Studio中进行有关代码的编写和界面效果展示

1 功能说明

(1)在上次微信界面设计的基础上,对有recycleView的页面进行点击跳转设计;
比如,某一tab页是联系人列表,则点击某一行能跳转到联系人详情页面。
(2)在进行跳转事件设计时,还需实现跳转返回;

注:只实现了一个联系人的详情页面设计!

2 设计原理

Android studio活动在其生命周期的四种状态分别是:

运行状态
暂停状态
停止状态
销毁状态
Activity与生命周期的有关的几个方法:

onCreate方法:创建页面。把页面上的各个元素加载到内存中。
onStart方法:开始页面。把页面显示在屏幕上。
onResume方法:恢复页面。让页面在屏幕上活动起来,例如开机动画,开始任务。
onPause方法:暂停页面。让页面在屏幕上的动作停下来。
onStop方法:停止页面。把页面从内存上撤下来。
onDestroy方法。销毁页面。把页面琮内存中清除掉。
onRestart方法。重新加载内存中的页面数据。

Task是一个存放Activity的一个栈,遵循先进后出的原则,分有压栈(进栈)和盘栈(出栈)两个操作。Activity都会作为元素存放在Task里面,遵循先进后出的原则。每运行一个Activity都会将此Activity压栈,从第一个运行Activity中跳转到第二个Activity,第二个Activity会压栈到第一个Activity的顶部,然后把运行在第二个Activity、第三个、第四个等依次类推。如果在跳转Activity之前当前的Activity没有执行finish()方法,此Activity就不会在Task中被销毁。

如果要在两Activity之间传递信息,可以使用bundle参数。
 

3 核心代码

3.1 新建一个Activity类leimuActivity.java

用于联系人详情页面的初始化及跳转返回事件的监听,当前的Activity的销毁

package com.example.mychat__recycleview;

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 leimuActivity extends AppCompatActivity {
    //好友名字
    private TextView friend_name;
    //好友信息
    private TextView friend_info;
    //好友照片
    private ImageView friend_pic;
    //返回上个页面按钮
    private Button btn_back;

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

    public void init() {
        friend_name = (TextView) findViewById(R.id.friend_name);
        friend_info = (TextView) findViewById(R.id.friend_info);
        friend_pic = (ImageView) findViewById(R.id.friend_pic);
        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) {
            leimuActivity.this.finish();
        }
    };

}

3.2 在res/layout中增加一个布局配置文件leimu_tab.xml

用于联系人详情界面的UI设计

<?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">

    <TextView
        android:id="@+id/friend_name"
        android:layout_width="match_parent"
        android:layout_height="15dp"
        android:layout_margin="10dp"
        android:layout_weight="1"
        android:background="@color/ivory"
        android:fontFamily="@font/huawencaiyun"
        android:gravity="center"
        android:text="雷姆"
        android:textColor="@color/blue"
        android:textSize="30sp" />

    <TextView
        android:id="@+id/friend_info"
        android:layout_width="match_parent"
        android:layout_height="200dp"
        android:layout_weight="1"
        android:layout_margin="10dp"
        android:text="  雷姆,轻小说《Re:从零开始的异世界生活》及其衍生作品的主要角色,在罗兹沃尔的宅邸中一手担当全部杂务的双胞胎女仆中的妹妹,小时候家人被魔女教所杀,姐姐角被斩断,从而憎恨魔女教,初识昴因其身上有魔女气味不待见昴,之后解开误会被昴拯救,认定昴是她的英雄,一心一意的相信并照顾昴,看似毒舌冷漠,其实内心很坚强,很温柔。"
        android:fontFamily="@font/huawenxingkai"
        android:textSize="22sp" />

    <ImageView
        android:id="@+id/friend_pic"
        android:layout_width="match_parent"
        android:layout_height="200dp"
        android:layout_weight="1"
        app:srcCompat="@drawable/leimu" />

    <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>

3.3 修改AndroidManifest.xml,将leimuActivity添加进去

用于新建的Activity手动注册

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

    <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.MyChat__RecycleView">
        <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=".leimuActivity"
            android:label="@string/tab_name">
        </activity>

    </application>

</manifest>

3.4 在res/values/strings中增加所用的字符串名称

用来存放用到的一些字符串名称,便于之后的直接修改

<resources>
    <string name="app_name">MyChat_RecycleView</string>
    <string name="tab_name">雷姆</string>
</resources>

3.5 修改RecyclerViewAdapter.java

主要是onBindViewHolder方法中重写onClick方法对联系人列表的点击事件(跳转事件),并创建一个新的Activity页面

@Override
public void onBindViewHolder(@NonNull Myviewholder holder, int position) {
    holder.counter.setText(position + 1 + " ");
    holder.nickname.setText(mList.get(position));
    holder.personalized_signature.setText(nList.get(position));

    //实现对点击item的事件函数
    final String content = mList.get(position);
    holder.itemView.setContentDescription(content);
    holder.itemView.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            Toast.makeText(context, "您点击的联系人是:" + content, Toast.LENGTH_SHORT).show();

            //跳转到好友详情页面
            Intent intent = new Intent();
            intent.setClass(context,leimuActivity.class);
            context.startActivity(intent);
        }
    });

4 最终展现效果

5 代码仓库

具体代码已上传jiangge/zj - Gitee.com

6 项目总结

Android应用开发是一个不断发展和变化的领域,为了熟练掌握Android开发技术,需要不断进行实际项目和实验。本次实验的目标是在Android应用中创建一个类似微信的界面,其中包括列表页和详情页,实现从列表页点击跳转到详情页的功能。通过这个实验,我深入了解了Android的UI设计、Activity生命周期、界面布局和页面导航等方面的知识。

这次实验带来了很多宝贵的经验和知识:

1. Android UI设计: 我学习了如何设计一个吸引人的用户界面,包括颜色、布局和字体选择。这对于吸引用户并提供良好的用户体验至关重要。

2. Activity生命周期: 了解了Android Activity的生命周期,以便在合适的时候执行必要的操作。这对于应用的正确运行至关重要。

3. RecyclerView和适配器: 学会了使用RecyclerView控件来显示列表数据,并创建了自定义适配器来绑定数据。

4. 页面导航: 了解了如何使用意图(Intent)来实现页面之间的导航,以及在清单文件中的配置。

5. 测试和调试: 学会了进行应用程序的测试和调试,以确保应用的质量和可靠性。

结论:本次实验让我更深入地了解了Android应用开发的许多方面,包括UI设计、Activity生命周期、适配器和页面导航。通过创建一个类似微信的应用,我获得了宝贵的经验,这将对我的Android开发技能产生积极的影响。通过不断实践和学习,我将能够构建更加复杂和功能丰富的Android应用。这次实验是我Android开发学习旅程中的一站,我期待在将来的项目中应用这些新的知识和技能。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值