Flutter-Android开发者文档 -Activity和F
喜欢我的小伙伴,一定要关注我的微信公众号啊!!!谢谢啦
AllAboutCoding
AllAboutCoding
此文章为翻译Flutter官网的Flutter for Android Developers - Activities and fragments有兴趣的小伙伴可以移步官网查看。
注意:在Flutter应用中,你永远不会希望Android重启Activity,特别是因为这样直接反对Android文档的建议。例如,如果支持分屏,你需要添加** screenLayout**,还可能需要密度(density)。
Flutter中的Activity和Fragment是什么?
在Android中,Activity代表着用户可以做的集中的事情。Fragment代表用户的一种行为或用户的一部分交互。Fragment是一种将你的代码模块化的方法,通过结合用户的在大屏上的复杂交互,帮助扩展应用的UI。在Flutter中,这两个概念都在Widget的保护伞之下。
就像Intent那节提到的一样,因为在Flutter中一切都是Widget,所以Widget就代表着屏幕(screens)。你可以使用Navigator在两个不同的Route之间跳转,Route代表了不同的页面或是屏幕,或者可能只是不同的状态或相同的数据渲染。
如何监听Android Activity 生命周期事件?
在Android中,你可以重写Activity的方法或者在Application中注册ActivityLifecycleCallbacks来捕获Activity的生命周期。在Flutter中,你没有这些概念,但是你可以通过挂载WidgetsBinding观察监听didChangeAppLifecycleState()*方法的改变事件来达到监听生命周期事件的目的。
可观察的生命周期事件有:
- inactive ——应用已在活跃状态,并且还没有收到用户操作。因为在Android上没有等价的映射,所以这个事件仅仅在iOS上有效。
-
paused——应用对用户已不可见,用户操作已无效,并且在后台运行。等价于Android的
onPause()
方法。 -
resume——应用已显示并且已经可以响应用户的操作。等价于Android的
onPostResume ()
方法。 - suspending——应用暂时处于暂停状态。这等价于Android的onStop;因为在iOS上没有等价的方法,所以这个方法不会在iOS上触发。
关于这些状态的更多详细解释,请看生命周期状态文档
你可能注意到,只有一小部分Activity生命周期事件有效;而FlutterActivity确实捕获了Activity的所有生命周期事件并将它们发送给Flutter引擎,它们绝大多数都被屏蔽了。Flutter关注的是给你starting和stopping引擎,在大多数情况下,Flutter并不是特别需要观察Activity的生命周期。如果你无论如何都需要观察生命周期来获取或者释放Native资源,那你可能需要在Native端做这件事。
这有一个如何监听Activity的生命周期的状态的例子:
import 'package:flutter/widgets.dart';
class LifecycleWatcher extends StatefulWidget {
@override
_LifecycleWatcherState createState() => new _LifecycleWatcherState();
}
class _LifecycleWatcherState extends State<LifecycleWatcher> with WidgetsBindingObserver {
AppLifecycleState _lastLifecyleState;
@override
void initState() {
super.initState();
WidgetsBinding.instance.addObserver(this);
}
@override
void dispose() {
WidgetsBinding.instance.removeObserver(this);
super.dispose();
}
@override
void didChangeAppLifecycleState(AppLifecycleState state) {
setState(() {
_lastLifecyleState = state;
});
}
@override
Widget build(BuildContext context) {
if (_lastLifecyleState == null)
return new Text('This widget has not observed any lifecycle changes.', textDirection: TextDirection.ltr);
return new Text('The most recent lifecycle state this widget observed was: $_lastLifecyleState.',
textDirection: TextDirection.ltr);
}
}
void main() {
runApp(new Center(child: new LifecycleWatcher()));
}