可是, 大家须要注意一些细节, 才干在使用中得心应手.
Android 的生命周期改变主要有两种情况, 一是用户參与 Activity 生命周期的改变, 二是系统回收或配置改动导致的改变.
本文演示样例的 GitHub 下载地址
Android 的生命周期:
1. 用户參与
用户最常见的两种操作, 按 Home 键或 Back 键.
(1) 点击 Home 键, 暂停当前 Activity, 调用 onPause -> onStop; 再次返回, 恢复当前页面, 调用 onRestart -> onStart -> onResume.
(2) 点击 Back 键, 关闭当前 Activity, 调用 onPause -> onStop -> onDestroy; 再次启动则为重建, 从 onCreate 開始调用.
onStart() 是 Activity 可见, 无法交互; onResume() 是 Activity 可见, 能够交互. onPause 是 Activity 无法交互, 必须运行前一个 Activity 的 onPause 完毕, 后一个 Activity 才干启动, 在 onPause 中, 不能运行复杂的操作, 否则会影响下一个 Activity 启动速度. onStop 是 Activity 关闭显示.
注意: 启动透明页面仅仅调用 onPause, 不会调用 onStop, 即仅仅是不能够交互, 但仍在前台显示. 启动非透明页, 会调用 onPause -> onStop.
运行操作, 启动透明页, 关闭透明页, 启动非透明页, 关闭非透明页.
E/DEBUG-WCL: MainActivity: onPause
E/DEBUG-WCL: MainActivity: onSaveInstanceState
E/DEBUG-WCL: TranslateActivity: onPause
E/DEBUG-WCL: MainActivity: onResume
E/DEBUG-WCL: TranslateActivity: onStop
E/DEBUG-WCL: TranslateActivity: onDestroy
E/DEBUG-WCL: MainActivity: onPause
E/DEBUG-WCL: SecondActivity: onCreate
E/DEBUG-WCL: MainActivity: onSaveInstanceState
E/DEBUG-WCL: MainActivity: onStop
E/DEBUG-WCL: SecondActivity: onPause
E/DEBUG-WCL: MainActivity: onRestart
E/DEBUG-WCL: MainActivity: onStart
E/DEBUG-WCL: MainActivity: onResume
E/DEBUG-WCL: SecondActivity: onStop
E/DEBUG-WCL: SecondActivity: onDestroy
注意透明页启动, 主页仅仅会调用 onPause, 而不调用 onStop.
onSaveInstanceState 方法, 在关闭时, 都会运行, 但非系统调用启动, 不会运行恢复数据的操作, 即 onRestoreInstanceState 方法.
2. 系统重建
在系统配置发生改变时, Activity 就会重建, 因为是系统控制的关闭和启动, 会调用 onSaveInstanceState 保存数据, onRestoreInstanceState 恢复数据.
E/DEBUG-WCL: MainActivity: onPause
E/DEBUG-WCL: MainActivity: onSaveInstanceState
E/DEBUG-WCL: MainActivity: onStop
E/DEBUG-WCL: MainActivity: onDestroy
E/DEBUG-WCL: MainActivity: onCreate
E/DEBUG-WCL: MainActivity: onStart
E/DEBUG-WCL: MainActivity: onRestoreInstanceState
E/DEBUG-WCL: MainActivity: onResume
onRestoreInstanceState 在能够交互之前 (onResume) 运行, onSaveInstanceState 在停止交互 (onPause) 之后运行.
系统会保存关闭之前的视图结构和暂存数据. 视图详细保存的数据项, 能够通过阅读文档, 也能够直接阅读代码. 搜索视图类的 onSaveInstanceState 方法, 类 SavedState 就是保存的数据.
TextView 的 onSaveInstanceState
@Override public Parcelable onSaveInstanceState() {
Parcelable superState = super.onSaveInstanceState();
// Save state if we are forced to
boolean save = mFreezesText;
int start = 0;
int end = 0;
if (mText != null) {
start = getSelectionStart();
end = getSelectionEnd();
if (start >= 0 || end >= 0) {
// Or save state if there is a selection
save = true;
}
}
if (save) {
SavedState ss = new SavedState(superState);
// XXX Should also save the current scroll position!
ss.selStart = start;
ss.selEnd = end;
if (mText instanceof Spanned) {
Spannable sp = new SpannableStringBuilder(mText);
if (mEditor != null) {
removeMisspelledSpans(sp);
sp.removeSpan(mEditor.mSuggestionRangeSpan);
}
ss.text = sp;
} else {
ss.text = mText.toString();
}
if (isFocused() && start >= 0 && end >= 0) {
ss.frozenWithFocus = true;
}
ss.error = getError();
if (mEditor != null) {
ss.editorState = mEditor.saveInstanceState();
}
return ss;
}
return superState;
}
TextView 主要保存了内容 Text 和焦点 Focus, 另一些位置和错误信息.
假设是恢复自己定义数据, 恢复时机, 能够选择 onCreate 或 onRestoreInstanceState, 差别是 onCreate 须要推断 savedInstanceState 是否为空, 而 onRestoreInstanceState 的參数 savedInstanceState 是一定非空, 否则不会调用. 推荐使用 onRestoreInstanceState.
onCreate 判空
if (savedInstanceState != null) {
String txt = savedInstanceState.getString(EXTRA_TEXT);
Log.e(TAG, "[onCreate]savedInstanceState: " + txt);
}
在 AndroidManifest 的 Activity 属性中加入
android: configChanges = "orientation|screenSize"
防止在旋转屏幕时, 重绘页面, 但屏幕仍能够旋转.
不会调用生命周期, 而是调用 onConfigurationChanged 处理旋转屏幕事件.
使用 android:screenOrientation="portrait" 会使屏幕保持竖直, 无法旋转.
动画
參考
OK, that's all! Enjoy it!
来源: http://www.bubuko.com/infodetail-2467822.html