众所周知,Android 有四大组件:
——Activity
——Service
——BroadcastReceiver
——Content Provider
今天我们来学习Activity.Activity是构建用户界面的基础组件,方便用户实现应用交互。可以看作单一的屏幕。
本次学习内容:
1.activity的概念
2.activity的启动与结束
3.activity的生命周期
一、activity的概念
Activity是一个应用程序的组件,他在屏幕上提供了一个区域,允许用户在上面做一些交互性的操作, 比如打电话,照相,发送邮件,或者显示一个地图!Activity可以理解成一个绘制用户界面的窗口, 而这个窗口可以填满整个屏幕,也可能比屏幕小或者浮动在其他窗口的上方!
二、activity的启动与结束
不知道大家还记得第一节中讲到button组件时曾经提到过页面跳转功能的时候吗,那其实就是一个activity启动的过程,我们先来回忆一下代码:
xml:
<?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:id="@+id/main"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<Button
android:id="@+id/btn_act_next"
android:layout_width="match_parent"
android:layout_height="60dp"
android:layout_marginBottom="15dp"
android:text="跳转到下一个页面"
android:textColor="#0968F7"
android:textSize="20sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
java:
package com.example.activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import androidx.activity.EdgeToEdge;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.graphics.Insets;
import androidx.core.view.ViewCompat;
import androidx.core.view.WindowInsetsCompat;
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
findViewById(R.id.btn_act_next).setOnClickListener(this); // 注册点击监听器
}
@Override
public void onClick(View v) { // 实现点击事件的处理方法
if (v.getId() == R.id.btn_act_next) {
// 从当前页面跳到指定的新页面
startActivity(new Intent(this, MainActivity2.class));
}
}
}
通过点击按钮就能够实现页面跳转的功能,此时也就启动了第二个activity。接下来我们再将activity的结束,结束,顾名思义就是不在发生的意思,在Java代码中,我们可以通过finish方法来进行activity的结束(当前这个页面的所有活动比如加载,在线等),并跳回第一个activity。
xml:
<?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:id="@+id/main"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity2">
<ImageView
android:id="@+id/iv_back"
android:layout_width="40dp"
android:layout_height="40dp"
android:layout_marginBottom="688dp"
android:padding="5dp"
android:src="@drawable/ic_back"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.013"
app:layout_constraintStart_toStartOf="parent" />
<Button
android:id="@+id/btn_finish"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="496dp"
android:gravity="center"
android:text="完成"
android:textColor="#000000"
android:textSize="17sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent" />
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="5dp"
android:layout_marginBottom="604dp"
android:text="按返回键,或者点击左上角的箭头图标,或者点击上面的完成按钮,均可关闭当前页面、返回上个页面"
android:textColor="#000000"
android:textSize="17sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="1.0"
app:layout_constraintStart_toStartOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
java:
package com.example.activity;
import android.os.Bundle;
import android.view.View;
import androidx.activity.EdgeToEdge;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.graphics.Insets;
import androidx.core.view.ViewCompat;
import androidx.core.view.WindowInsetsCompat;
public class MainActivity2 extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main2);
// 给箭头图标注册点击监听器,ImageView由View类派生而来
findViewById(R.id.iv_back).setOnClickListener(this);
// 给完成按钮注册点击监听器,Button也由View类派生而来
findViewById(R.id.btn_finish).setOnClickListener(this);
}
public void onClick(View v) { // 点击事件的处理方法
if (v.getId() == R.id.iv_back || v.getId() == R.id.btn_finish) {
finish(); // 结束当前的活动页面
}
}
}
让我们来看下效果:
初始页面,点击按钮后进行跳转:
第二个页面,点击完成或返回图标后返回到第一个页面:
这就是activity的启动与结束。
三.activity的生命周期
这里直接放一张流程图,供大家更方便的理解:
这里介绍一下各个函数的作用:
onCreate: 创建活动。此时会记录活动页面布局加载进内存,进入了初始状态。
onStart: 开启活动。此时会记录活动页面显示在屏幕上,进入就绪状态。
onResume: 恢复活动。此时活动页面进入活跃状态,能够与用户正常交互,例如允许响应用户的点击动作、允许用户输入文字等。
onPause: 暂停活动。此时活动页面进入暂停状态(也就是退回就绪状态),无法与用户正常交互。
onStop: 停止活动。此时活动页面将不在屏幕上显示。
onDestroy: 销毁活动。此时回收活动占用的系统资源,把页面从内存中清除掉。
onRestart: 重启活动。处于停止状态的活动,若想重新开启的话,无须经历onCreate的重复创建过程,而是走onRestart的重启过程。
onNewIntent: 重用已有的活动实例。
打开新活动页面的方法调用顺序为onCreate->onStart->onResume,关闭旧活动页面的方法调用顺序为onPause->onStop->onDestory.为了弄清楚这些方法的调用时机。接下来通过一个实验加以观察。
首先分别创建两个活动页面,它们的Java代码都重写了下列7个生命周期方法:onCreate、onStart、onResume、onStop、onPause、onDestroy、onRestart,每个方法内部均调用新写的refreshLife方法打印日志。其中第一个活动页面的Java代码示例如下,第二个活动页面的Java代码可照猫画虎。
以下是参考代码:
xml:
<?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:id="@+id/main"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity3">
<Button
android:id="@+id/btn_act_next"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="676dp"
android:gravity="center"
android:text="跳到下个页面"
android:textColor="#000000"
android:textSize="17sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent" />
<TextView
android:id="@+id/tv_life"
android:layout_width="425dp"
android:layout_height="188dp"
android:layout_marginLeft="5dp"
android:layout_marginBottom="124dp"
android:textColor="#000000"
android:textSize="17sp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="1.0"
app:layout_constraintStart_toStartOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
java代码:
package com.example.activity;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.TextView;
import androidx.activity.EdgeToEdge;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.graphics.Insets;
import androidx.core.view.ViewCompat;
import androidx.core.view.WindowInsetsCompat;
public class MainActivity3 extends AppCompatActivity implements View.OnClickListener {
private final static String TAG = "ActLifeActivity";
private TextView tv_life; // 声明一个文本视图对象
private String mStr = "";
private void refreshLife(String desc) { // 刷新生命周期的日志信息
Log.d(TAG, desc);
mStr = String.format("%s%s %s %s\n", mStr, DateUtil.getNowTimeDetail(), TAG, desc);
tv_life.setText(mStr);
}
@Override
protected void onCreate(Bundle savedInstanceState) { // 创建活动页面
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main3);
findViewById(R.id.btn_act_next).setOnClickListener(this);
tv_life = findViewById(R.id.tv_life); // 从布局文件中获取名叫tv_life的文本视图
refreshLife("onCreate"); // 刷新生命周期的日志信息
}
@Override
protected void onStart() { // 开始活动
super.onStart();
refreshLife("onStart"); // 刷新生命周期的日志信息
}
@Override
protected void onStop() { // 停止活动
super.onStop();
refreshLife("onStop"); // 刷新生命周期的日志信息
}
@Override
protected void onResume() { // 恢复活动
super.onResume();
refreshLife("onResume"); // 刷新生命周期的日志信息
}
@Override
protected void onPause() { // 暂停活动
super.onPause();
refreshLife("onPause"); // 刷新生命周期的日志信息
}
@Override
protected void onRestart() { // 重启活动
super.onRestart();
refreshLife("onRestart"); // 刷新生命周期的日志信息
}
@Override
protected void onDestroy() { // 销毁活动
super.onDestroy();
refreshLife("onDestroy"); // 刷新生命周期的日志信息
}
@Override
protected void onNewIntent(Intent intent) { // 重用已有的活动实例
super.onNewIntent(intent);
refreshLife("onNewIntent"); // 刷新生命周期的日志信息
}
@Override
public void onClick(View v) {
if (v.getId() == R.id.btn_act_next) {
// 从当前页面跳到指定的活动页面
startActivity(new Intent(this, MainActivity4.class));
}
}
}
我们来看下效果图:
这里就是显示了当前Activity的生命周期的方法,当你点击跳转的时候,会有十几帧,可以看到显示了onPause方法,只不过时间很短。
四、结语
本次更新主要讲述了四大组件的activity,后续也会把其余三个组件补上,未来可能会穿插着中级教程和实战项目,尽情期待,谢谢大家的支持。