一、Activity详解
(1)Activity从创建到销毁的一个完整的生命周期,包含七种方法和四种状态。
(2)Activity生命周期方法
- onCreate:Activity正在被创建
- onStart:Activity正在变为可见,无法和用户交互
- onResume:Activity已经变为可见 & 可以与用户交互
- onPause:Activity被另一个Activity部分或全部覆盖 & 不可与用户交互
- onStop:Activity已经暂停不可见
- onRestart:Activity被停止后再次启动
- onDestroy:Activity已经被销毁
- onSaveInstanceState:系统异常终止时,调用onSavaInstanceState来保存状态
- onRestoreInstanceState:Activity异常终止被重新创建时,调用onRestoreInstanceState方法
- onConfigurationChanged:屏幕方向发生改变的回调方法,需要在AndroidMainfest.xml中设置android:configChanges="orientation"
(3)Activity状态
- 活动状态:Activity处于页面最顶端
- 暂停状态:Activity失去焦点,但此时对用户可见无法和用户交互
- 停止状态:Activity完全被遮挡,但此时还保留所有状态和成员信息
- 非活动状态:Activity被销毁
(4)Activity生命周期的各阶段
- 完整生命周期:从onCreate()方法开始到onDestroy()方法结束
- 可见生命周期:从onStart()方法开始到onStop()方法结束
- 前台生命周期:从onResume()方法开始到onPause()方法结束
(5)Activity屏幕横竖屏切换分析
- 在activity中设置
//获取屏幕的方向,数值1表示竖屏,数值2表示横屏
int screenNum = getResources().getConfiguration().orientation;
//设置屏幕横屏
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
//设置屏幕竖屏
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
- 在AndroidManifest.xml中设置横竖屏属性
android:configChanges="orientation|keyboardHidden|screenSize"
(6)Activity优先级
- 前台Activity:正在和用户交互的Activity
- 可见但非前台Activity:Activity可见但无法与用户交互
- 后台Activity:不可见已经被暂停的Activity
(7)Activity界面跳转的实现
private void start() {
Intent intent = new Intent(MainActivity.this, AActivity.class);
//无结果的界面跳转
startActivity(intent);
//有结果的界面跳转
startActivityForResult(intent, 1000);
//隐式启动界面
/**
* IntentFilter匹配规则
* 一个intent只有同时匹配某个Activity的intent-filter中的action、category、data才算完全匹配,才能启动该Activity。
* 一个Activity可以有多个intent-filter,一个intent只要成功匹配任意一组 intent-filter,就可以启动该Activity。
* 在AndroidManifest.xml中设置intent-filter的的action、category、data
* </intent-filter>
* <action android:name="amain_activity_action" />
* <category android:name="main_activity_category" />
* <data android:scheme="something" android:host="project.example.com" android:port="80"/>
* </intent-filter>
* action匹配规则:系统也有预定义action也可以自定义action。如果采用自定的action那么在启动Activity的时候必须保证Intent中的action和intent-filter中的action完全一致
* category匹配规则:系统默认给intent中的category添加属性值。除此之外有其他category,则要求intent中的category和intent-filter中的所有category 相同
* data匹配规则:如果没有指定URI,默认值为content和file; 有多组data规则时,匹配其中一组即可。Uri的格式:scheme://host:port
*/
Intent intent = new Intent("main_activity_action");
intent.addCategory("main_activity_category");
intent.setData(Uri.parse("something://project.example.com:80"));
startActivity(intent);
}
//用方法setResult回传数据,用finish()结束AActivity页面的进程
private void setResult() {
Intent intent = new Intent();
intent.putExtra("text", "text");
setResult(1001, intent);
finish();
}
//在MainActivity界面用方法onActivityResult接收回传数据
@Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == 1000 && resultCode == 1001) {
if (data != null) {
String text = data.getStringExtra("text");
}
}
}
(8)Activity四种启动模式
- standard:标准模式、默认模式。每次启动一个Activity就会创建一个新的实例
- singleTop:栈顶复用模式。如果Activity已经位于任务栈的栈顶,就不会重新创建,并回调onNewIntent(intent)方法。
- singleTask:栈内复用模式。如果Activity已经位于任务栈中存在,就不会重新创建,把栈中在其之上的其它Activity destory掉并回调onNewIntent(intent)方法。
- singleInstance:单实例模式。Activity只能单独位于一个任务栈中,且此任务栈中只有唯一一个实例
- Intent.FLAG_ACTIVITY_NEW_TASK:使用一个新的Task来启动Activity
- Intent.FLAG_ACTIVITY_CLEAR_TOP:类似singleTask
- Intent.FLAG_ACTIVITY_SINGLE_TOP:类似singleTop
- Intent.FLAG_ACTIVITY_NO_HISTORY:使用这种模式启动的Activity,当该Activity启动其他Activity后,该Activity就消失了,不会保留在Task栈中