研究这个问题的初衷在于项目中碰到了一个问题:横屏的时候灭屏再亮屏,亮屏的时候用户能够清晰的看到先启动竖屏(过程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)的更多相关文章

  1. 横竖屏切换时,Activity的生命周期

    横竖屏切换时,Activity的生命周期 1.新建一个Activity,并把各个生命周期打印出来 2.运行Activity,得到如下信息 onCreate-->onStart-->onRe ...

  2. 安卓横竖屏切换时activity的生命周期

    关于Activity横竖屏切换的声明周期变化: 1.新建一个Activity并把各个生命周期打印出来 2.运行Activity,得到如下信息 onCreate-->onStart-->on ...

  3. Andriod开发---《横竖屏切换时 Activity的生命周期的总结》

    横屏切换竖屏Activity的生命周期详解,下面分析一下切换时具体的生命周期: 1.新建一个Activity,并把各个生命周期打印出来 2.运行Activity,得到如下信息 onCreate--&g ...

  4. Android(java)学习笔记224:横竖屏切换时Activity的生命周期

    1.横竖屏切换的生命周期     默认情况下横竖屏切换,先销毁再创建 2.有的时候,默认情况下的横竖屏切换(先销毁再创建),对应用户体验是不好的,比如是手机游戏横竖屏切换对游戏体验非常不好,下面两种方 ...

  5. Android(java)学习笔记167:横竖屏切换时Activity的生命周期

    1.横竖屏切换的生命周期     默认情况下横竖屏切换,先销毁再创建 2.有的时候,默认情况下的横竖屏切换(先销毁再创建),对应用户体验是不好的,比如是手机游戏横竖屏切换对游戏体验非常不好,下面两种方 ...

  6. 横竖屏切换时Activity的生命周期

    设置横竖屏切换时Activity生命周期的属性设置,在清单文件中的Activity节点中设置.根据具体需求设置: 1.不设置Activity的android:configChanges时,切屏会重新调 ...

  7. 测试横竖屏切换时activity 的生命周期

    对于这个面试题,相信大家都见过,网上给出的答案是: 1.不设置Activity的android:configChanges时,切屏会重新调用各个生命周期,切横屏时会执行一次,切竖屏时会执行两次 2.设 ...

  8. 【Android开发学习笔记】【第五课】Activity的生命周期-上

    今天学习Activity当中的七个生命周期函数: 首先得说一个事情,就是在代码当中如果加入了 System.out.println(" ------");之后,如何查看这里面的输出 ...

  9. 《android开发艺术探索》读书笔记(一)--Activity的生命周期和启动模式

    No1: 如果新Activity采用了透明主题,那么当前Activity不会回调onStop: No2: 新Activity启动之前,栈顶的Activity需要先onPause后,新Activity才 ...

随机推荐

  1. mybatis深入理解(二)-----Mybatis数据源与连接池

    对于ORM框架而言,数据源的组织是一个非常重要的一部分,这直接影响到框架的性能问题.本文将通过对MyBatis框架的数据源结构进行详尽的分析,并且深入解析MyBatis的连接池.本文首先会讲述MyBa ...

  2. hdu 2087剪花布条 (KMP入门 子串出现的次数和子串个数)

    剪花布条 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  3. arcgis信息窗口

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  4. ASP.NET自定义控件组件开发 第一章 第一章:从一个简单的控件谈起

    第一章:从一个简单的控件谈起 系列文章链接: ASP.NET自定义控件组件开发 第一章 待续 ASP.NET自定义控件组件开发 第一章 第二篇 接着待续 ASP.NET自定义控件组件开发 第一章 第三 ...

  5. js 详解setTimeout定时器

    setTimeout: 定时器函数 第一个参数是匿名函数,第二个参数是延迟执行时间 setTimeout(function(){},time) 注意: 1.setTimeout函数是Window对象提 ...

  6. 【python小随笔】Django+错误日志(配置Django报错文件指定位置)

    1:  自定义日志文件.py----------几个文件需要创建日志,就需要重新定义几份 # 定义一个日志文件 创建一个操作日志对象logger file_1 = logging.FileHandle ...

  7. ie8或9下ajax跨域问题

    ie8或9下ajax跨域支持,添加如下代码 <!--[if (IE 8)|(IE 9)]><script src="https://cdn.bootcss.com/jque ...

  8. UE4碰撞规则详解

    UE4的碰撞设置在官方的文档的 物理模拟模块(链接:点击打开链接).但是操作起来感觉坑还是比较多,所以这里总结一下,以防平时经常会漏掉或忽略某些条件.如果想看关于碰撞响应触发,可以参考链接( UE4蓝 ...

  9. python深、浅拷贝

    1.首先对于数字和字符串而言,深浅拷贝无实际意义,两者同时指向同一个内存地址. a = 123 print(id(a)) b = a print(id(b)) 495849744 495849744 ...

  10. JavaScript--函数对象的属性caller与callee

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...