最近想监听App从后台切换到前台的监听,不巧发现了这个玩意ActivityLifecycleCallbacks
看名字就是一个会被回调的方法。
1 继承Application,并指定
2 实现这个interface
private ActivityLifecycleCallbacks mLifecycleCallback = new ActivityLifecycleCallbacks() {
@Override
public void onActivityCreated(Activity activity, Bundle savedInstanceState) {
LogUtil.i(“onCreate:”+activity.getClass().getSimpleName());
}
@Override
public void onActivityStarted(Activity activity) {
LogUtil.i("onStart:"+activity.getClass().getSimpleName());
}
@Override
public void onActivityResumed(Activity activity) {
LogUtil.i("onResumed:"+activity.getClass().getSimpleName());
}
@Override
public void onActivityPaused(Activity activity) {
LogUtil.i("onPaused:"+activity.getClass().getSimpleName());
}
@Override
public void onActivityStopped(Activity activity) {
LogUtil.i("onStop:"+activity.getClass().getSimpleName());
}
@Override
public void onActivitySaveInstanceState(Activity activity, Bundle outState) {
LogUtil.i("onSaveInstanceState:"+activity.getClass().getSimpleName());
}
@Override
public void onActivityDestroyed(Activity activity) {
LogUtil.i("onDestroyed:"+activity.getClass().getSimpleName());
}
};
</pre>
3 在Application中的onCreate方法,进行注册
public class MyApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
// Create an InitializerBuilder
Stetho.InitializerBuilder initializerBuilder =
Stetho.newInitializerBuilder(this);
// Enable Chrome DevTools
initializerBuilder.enableWebKitInspector(
Stetho.defaultInspectorModulesProvider(this)
);
// Enable command line interface
initializerBuilder.enableDumpapp(
Stetho.defaultDumperPluginsProvider(this)
);
// Use the InitializerBuilder to generate an Initializer
Stetho.Initializer initializer = initializerBuilder.build();
// Initialize Stetho with the Initializer
Stetho.initialize(initializer);
//前面是我继承的Stetho调试工具,大家可以忽略
//前面的LogUtil也是Stetho的,,,so 大家可以替换为Log
registerActivityLifecycleCallbacks(mLifecycleCallback);
}
</pre>
4 运行时log
10-14 09:44:29.760 7491-7506/? I/stetho: Listening on @stetho_aze_zer0.azezer0utils_devtools_remote
10-14 09:44:29.808 7491-7491/? I/stetho: onCreate:MainActivity
10-14 09:44:30.357 7491-7491/? I/stetho: onStart:MainActivity
10-14 09:44:30.357 7491-7491/? I/stetho: onResumed:MainActivity
10-14 09:45:05.139 7491-7491/aze_zer0.azezer0utils I/stetho: onPaused:MainActivity
10-14 09:45:05.165 7491-7491/aze_zer0.azezer0utils I/stetho: onCreate:MainActivity2
10-14 09:45:05.193 7491-7491/aze_zer0.azezer0utils I/stetho: onStart:MainActivity2
10-14 09:45:05.194 7491-7491/aze_zer0.azezer0utils I/stetho: onResumed:MainActivity2
10-14 09:45:05.838 7491-7491/aze_zer0.azezer0utils I/stetho: onSaveInstanceState:MainActivity
10-14 09:45:05.838 7491-7491/aze_zer0.azezer0utils I/stetho: onStop:MainActivity
10-14 09:45:25.157 7491-7491/aze_zer0.azezer0utils I/stetho: onPaused:MainActivity2
10-14 09:45:25.173 7491-7491/aze_zer0.azezer0utils I/stetho: onSaveInstanceState:MainActivity2
10-14 09:45:25.173 7491-7491/aze_zer0.azezer0utils I/stetho: onStop:MainActivity2
10-14 09:45:53.287 7491-7491/aze_zer0.azezer0utils I/stetho: onStart:MainActivity2
10-14 09:45:53.287 7491-7491/aze_zer0.azezer0utils I/stetho: onResumed:MainActivity2
10-14 09:45:57.884 7491-7491/aze_zer0.azezer0utils I/stetho: onPaused:MainActivity2
10-14 09:45:57.892 7491-7491/aze_zer0.azezer0utils I/stetho: onStart:MainActivity
10-14 09:45:57.892 7491-7491/aze_zer0.azezer0utils I/stetho: onResumed:MainActivity
10-14 09:45:58.275 7491-7491/aze_zer0.azezer0utils I/stetho: onStop:MainActivity2
10-14 09:45:58.276 7491-7491/aze_zer0.azezer0utils I/stetho: onDestroyed:MainActivity2