Android横竖屏切换和灭屏亮屏时Activity的生命周期探究(1)
研究这个问题的初衷在于项目中碰到了一个问题:横屏的时候灭屏再亮屏,亮屏的时候用户能够清晰的看到先启动竖屏(过程1)再切换到横屏的过程,因为灭屏的时候onSaveInstanceState()保存的时横屏时的状态信息,因此过程1竖屏会使用到横屏的状态參数并且这一过程用户是可见的。因此会导致一些意想不到的Bug的出现。
探究使用的实例中我用了屏幕的横竖屏和宽这两个配置信息来说明生命周期中此时系统所知道的屏幕的客观状态,注意这个客观状态与我们在onSaveInstanceState()中要保存的“状态信息”是不一样的,客观状态由硬件和系统决定。在那一时刻一定是这种状态,“状态信息”是程序猿想要保存的信息,这个由程序猿自己控制。
横竖屏切换通常会由onConfigurationChanged()这个系统函数来响应,但响应这个函数须要在Manifest中为Activity配置例如以下信息(Android3.2及更高版本号的配置方法)
<activity
...
android:configChanges="orientation|screenSize"
... >
本篇先探究没有进行这种配置时Activity的生命状态,从结果中能够看到此时的横竖屏切换时一个全然杀死Activity再重新启动Activity的过程,同一时候横屏的灭屏亮屏都先做了一次切换到竖屏的过程。
源代码例如以下:
package com.vivo.configurationtest;
import android.app.Activity;
import android.content.res.Configuration;
import android.os.Bundle;
import android.util.Log;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
Log.d("vi", "---onCreate()--" + "orientation = " + orientation()
+ "width = " + width());
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
@Override
protected void onSaveInstanceState(Bundle outState) {
// TODO Auto-generated method stub
Log.d("vi", "---onSaveInstanceState()--" + "orientation = "
+ orientation() + "width = " + width());
super.onSaveInstanceState(outState);
}
@Override
protected void onStart() {
// TODO Auto-generated method stub
Log.d("vi", "---onStart()--" + "orientation = " + orientation()
+ "width = " + width());
super.onStart();
}
@Override
protected void onResume() {
// TODO Auto-generated method stub
Log.d("vi", "---onResume()--" + "orientation = " + orientation()
+ "width = " + width());
super.onResume();
}
@Override
protected void onPause() {
// TODO Auto-generated method stub
Log.d("vi", "---onPause()--" + "orientation = " + orientation()
+ "width = " + width());
super.onPause();
}
@Override
public void onConfigurationChanged(Configuration newConfig) {
// TODO Auto-generated method stub
Log.d("vi", "---onConfigurationChanged()--" + "width = " + width());
super.onConfigurationChanged(newConfig);
}
@Override
protected void onStop() {
// TODO Auto-generated method stub
Log.d("vi", "---onStop()--" + "orientation = " + orientation()
+ "width = " + width());
super.onStop();
}
@Override
protected void onRestart() {
// TODO Auto-generated method stub
Log.d("vi", "---onRestart()--" + "orientation = " + orientation()
+ "width = " + width());
super.onRestart();
}
@Override
protected void onDestroy() {
// TODO Auto-generated method stub
Log.d("vi", "---onDestroy()--" + "orientation = " + orientation()
+ "width = " + width());
super.onDestroy();
}
private String orientation() {
int ori = this.getResources().getConfiguration().orientation;
if (ori == Configuration.ORIENTATION_PORTRAIT) {
return "ORIENTATION_PORTRAIT--";
} else if (ori == Configuration.ORIENTATION_LANDSCAPE) {
return "ORIENTATION_LANDSCAPE--";
}
return "-------";
}
private int width() {
int screenWidth = getWindowManager().getDefaultDisplay().getWidth();
return screenWidth;
}
}
//下面为没有在manifest中配置configuration
//竖屏从创建到切换到横屏
C:\Users\Administrator>adb logcat -s vi
--------- beginning of /dev/log/main
--------- beginning of /dev/log/system
D/vi (16610): ---onCreate()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onStart()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onResume()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onPause()--orientation = ORIENTATION_LANDSCAPE--width = 854 //onPause()时已经获取到切换之后的屏幕的配置信息
D/vi (16610): ---onSaveInstanceState()--orientation = ORIENTATION_LANDSCAPE--width = 854
D/vi (16610): ---onStop()--orientation = ORIENTATION_LANDSCAPE--width = 854
D/vi (16610): ---onDestroy()--orientation = ORIENTATION_LANDSCAPE--width = 854 //屏幕切换是一个全然的杀死activity然后重新启动activity的过程
D/vi (16610): ---onCreate()--orientation = ORIENTATION_LANDSCAPE--width =854
D/vi (16610): ---onStart()--orientation = ORIENTATION_LANDSCAPE--width = 854
D/vi (16610): ---onResume()--orientation = ORIENTATION_LANDSCAPE--width =854
//从横屏切换到竖屏
C:\Users\Administrator>adb logcat -s vi
--------- beginning of /dev/log/main
--------- beginning of /dev/log/system
D/vi (16610): ---onPause()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onSaveInstanceState()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onStop()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onDestroy()--orientation = ORIENTATION_PORTRAIT--width =480
D/vi (16610): ---onCreate()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onStart()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onResume()--orientation = ORIENTATION_PORTRAIT--width = 480
//竖屏从灭屏到亮屏
C:\Users\Administrator>adb logcat -s vi
--------- beginning of /dev/log/main
--------- beginning of /dev/log/system
D/vi (16610): ---onPause()--orientation = ORIENTATION_PORTRAIT--width = 480 //灭屏从onPause()处開始
D/vi (16610): ---onSaveInstanceState()--orientation = ORIENTATION_PORTRAIT--width = 480 //暂停并保存当前信息,要保存什么样的信息由用户选择
D/vi (16610): ---onStop()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onRestart()--orientation = ORIENTATION_PORTRAIT--width =480 //亮屏从onRestart()处開始
D/vi (16610): ---onStart()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onResume()--orientation = ORIENTATION_PORTRAIT--width = 480
//横屏的灭屏
C:\Users\Administrator>adb logcat -s vi
--------- beginning of /dev/log/main
--------- beginning of /dev/log/system
D/vi (16610): ---onPause()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onSaveInstanceState()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onStop()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onDestroy()--orientation = ORIENTATION_PORTRAIT--width =480
D/vi (16610): ---onCreate()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onStart()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onResume()--orientation = ORIENTATION_PORTRAIT--width = 480 //横屏的灭屏相当于先切换到竖屏,再灭屏。这个过程用户没看到
D/vi (16610): ---onPause()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onSaveInstanceState()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onStop()--orientation = ORIENTATION_PORTRAIT--width = 480
//横屏的亮屏
C:\Users\Administrator>adb logcat -s vi
--------- beginning of /dev/log/main
--------- beginning of /dev/log/system
D/vi (16610): ---onRestart()--orientation = ORIENTATION_PORTRAIT--width =480
D/vi (16610): ---onStart()--orientation = ORIENTATION_PORTRAIT--width = 480
D/vi (16610): ---onResume()--orientation = ORIENTATION_PORTRAIT--width = 480 //横屏的亮屏相当于先亮到竖屏,再切换到横屏。这个过程用户是能够看到的,灭屏的时候系统也做了一次相同的切换到竖屏的动作,屏灭用户没看到而已
D/vi (16610): ---onPause()--orientation = ORIENTATION_LANDSCAPE--width = 854
D/vi (16610): ---onSaveInstanceState()--orientation = ORIENTATION_LANDSCAPE--width = 854
D/vi (16610): ---onStop()--orientation = ORIENTATION_LANDSCAPE--width = 854
D/vi (16610): ---onDestroy()--orientation = ORIENTATION_LANDSCAPE--width = 854
D/vi (16610): ---onCreate()--orientation = ORIENTATION_LANDSCAPE--width =854
D/vi (16610): ---onStart()--orientation = ORIENTATION_LANDSCAPE--width = 854
D/vi (16610): ---onResume()--orientation = ORIENTATION_LANDSCAPE--width =854
Android横竖屏切换和灭屏亮屏时Activity的生命周期探究(1)的更多相关文章
- 横竖屏切换时,Activity的生命周期
横竖屏切换时,Activity的生命周期 1.新建一个Activity,并把各个生命周期打印出来 2.运行Activity,得到如下信息 onCreate-->onStart-->onRe ...
- 安卓横竖屏切换时activity的生命周期
关于Activity横竖屏切换的声明周期变化: 1.新建一个Activity并把各个生命周期打印出来 2.运行Activity,得到如下信息 onCreate-->onStart-->on ...
- Andriod开发---《横竖屏切换时 Activity的生命周期的总结》
横屏切换竖屏Activity的生命周期详解,下面分析一下切换时具体的生命周期: 1.新建一个Activity,并把各个生命周期打印出来 2.运行Activity,得到如下信息 onCreate--&g ...
- Android(java)学习笔记224:横竖屏切换时Activity的生命周期
1.横竖屏切换的生命周期 默认情况下横竖屏切换,先销毁再创建 2.有的时候,默认情况下的横竖屏切换(先销毁再创建),对应用户体验是不好的,比如是手机游戏横竖屏切换对游戏体验非常不好,下面两种方 ...
- Android(java)学习笔记167:横竖屏切换时Activity的生命周期
1.横竖屏切换的生命周期 默认情况下横竖屏切换,先销毁再创建 2.有的时候,默认情况下的横竖屏切换(先销毁再创建),对应用户体验是不好的,比如是手机游戏横竖屏切换对游戏体验非常不好,下面两种方 ...
- 横竖屏切换时Activity的生命周期
设置横竖屏切换时Activity生命周期的属性设置,在清单文件中的Activity节点中设置.根据具体需求设置: 1.不设置Activity的android:configChanges时,切屏会重新调 ...
- 测试横竖屏切换时activity 的生命周期
对于这个面试题,相信大家都见过,网上给出的答案是: 1.不设置Activity的android:configChanges时,切屏会重新调用各个生命周期,切横屏时会执行一次,切竖屏时会执行两次 2.设 ...
- 【Android开发学习笔记】【第五课】Activity的生命周期-上
今天学习Activity当中的七个生命周期函数: 首先得说一个事情,就是在代码当中如果加入了 System.out.println(" ------");之后,如何查看这里面的输出 ...
- 《android开发艺术探索》读书笔记(一)--Activity的生命周期和启动模式
No1: 如果新Activity采用了透明主题,那么当前Activity不会回调onStop: No2: 新Activity启动之前,栈顶的Activity需要先onPause后,新Activity才 ...
随机推荐
- 更好用的集群限流功能,Sentinel 发布 v1.4.2
摘要: 感谢 Sentinel 社区的贡献者们 ️ Sentinel 发布 v1.4.2 正式发布,该版本主要变更如下: 特性/功能改进 新增 Zuul 1.x 适配模块(sentinel-zuul- ...
- [Array]1. Two Sum(map和unorder_map)
Given an array of integers, return indices of the two numbers such that they add up to a specific ta ...
- c++设计模式:访问者模式(visitor模式)
1.c语言中回调基本都过函数指针来完成.c++中主要通过接口的方式完成回调.而visitor就是实现接口回调的一种方式. 1.首先定义个一个接口visitor类, class classVisitor ...
- SSM-8FastDfs搭建
1. 图片服务器的安装 1.存储空间可扩展. 2.提供一个统一的访问方式. 使用FastDFS,分布式文件系统.存储空间可以横向扩展,可以实现服务器的高可用.支持每个节点有备份机. 1.1. 什么是F ...
- 基于RBAC权限管理的后台管理系统
在摸爬滚打中渐渐理解了RBAC权限管理是个什么玩意. RBAC的基本概念: **RBAC认为权限授权实际上是Who.What.How的问题.在RBAC模型中,who.what.how构成了访问权限三元 ...
- poj1160 动态规划
#include<stdio.h> #include<string.h> #define INF 999999999 #define Min(x,y) (x<y?x:y) ...
- Pycharm 2018激活(Mac版)
第一步,修改host文件 目的:是屏蔽掉Pycharm对激活码的验证 路径:/etc/hosts 在文件最后一行添加文本: 0.0.0.0 account.jetbrains.com 修改后文件如下: ...
- 【Codeforces Round #430 (Div. 2) C】Ilya And The Tree
[链接]点击打开链接 [题意] 给你一棵n个点的树,每个点的美丽值定义为根节点到这个点的路径上的所有权值的gcd. 现在,假设对于每一个点,在计算美丽值的时候,你可以将某一个点的权值置为0的话. 问你 ...
- oracle-DML-2
1.update 语句 update table set [column,column......] where column ='' 示例: update customers set ...
- 数据库Mysql监控及优化
在做 性能测试的时候数据最重要,数据来源于哪里呢,当然是数据库了,数据库中,我们可以知道,数据从磁盘中要比从缓存中读取数据的时间要慢的多的多,还可以知道,同样的一个sql语句,执行的效率也不一样,这是 ...