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才 ...
随机推荐
- tmux使用教程
1.安装 2.操作 如何操作快捷键呢? 比如新建一个窗口的命令是:ctrl+b+c 那么,先按住ctrl不放,接着按下b键,然后ctrl和b键都完全松开后,再立马按下c键. 3.使用命令行 tmux ...
- SmartSQL
- Centos Apache 多站点配置
首先明白APACHE配置文件位置 /etc/httpd/ 系统会自动加载 "/etc/httpd/conf.d" 目录下面的 "*.conf"文件 创建多个 & ...
- HDU1950
//虽然是一道LIS问题,但是还是第一次用O(n*lgn)这种算法,赶角波错哈哈哈哈....至少今天有所收获 #include<cstdio> #include<cstring> ...
- jeecms使用小结
前言: 使用jeecmsV9已经有一段时间,现在PC端的二次开发基本进入尾声,手机端的开发即将开始 ,由于项目时间比较紧,开发时不是每个人都会使用它自带的标签,所以在PC端开发的时候浪费了大量时间,为 ...
- C# WPF 仿QQ靠近屏幕上方自动缩起功能实现
碰到了类似需求,但是上网查了一圈发现感觉要么很复杂,要么代码很臃肿,索性自己实现了一个 几乎和QQ是一模一样的效果,而且核心代码只有20行左右. 代码如下: using System; using S ...
- JAVA数据库连接池的革命 -- 从BoneCP到HikariCP(转)
从BoneCP到HikariCP 今天笔者本想更新一下项目中使用到的BoneCP版本的.却无意发现jolbox网站打不开了.起初以为是被墙掉了,经过一番查找,居然在BoneCP的Github站看到了如 ...
- webpack 4.X 创建 react项目
1. 新建一个文件夹2. 运行 npm init -y 快速初始化项目3. 在跟目录创建src文件夹 dist文件夹4. 在src下创建 index.html main.js // index.htm ...
- bzoj1823满汉全席
2-sat模板 这篇博客写得非常好 传送门 //Achen #include<algorithm> #include<iostream> #include<cstring ...
- listview显示固定条数
看了很多网上其他大神的,感觉还是在listview的adapter中的getCount中下手比较好点 毕竟计算高度等等,那会让辅助的布局会一团糟,例如下面的搜索历史只显示四条,布局中有横向listvi ...