ios 配置文件info.plist
info.plist 实则是一个字典,可在Xcode中可视化。
它指定了比如一个应用应该怎样启动,它如何被本地化,应用的名称,要显示的图标,启动的图片。
字段列表详解请参考:cocoachina
android配置文件 AndroidManifest.xml
和info.plist类似,项目的清单文件,用来配置一些类似于包名、权限、程序组件等重要信息。
字段列表详解请参考:android-doc
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.sample.teapot"
android:versionCode="1"
android:versionName="1.0.0.1" >
<uses-feature android:glEsVersion="0x00020000"></uses-feature>
<application
android:allowBackup="false"
android:fullBackupContent="false"
android:supportsRtl="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme"
android:name="com.sample.teapot.TeapotApplication"
>
<!-- Our activity is the built-in NativeActivity framework class.
This will take care of integrating with our NDK code. -->
<activity android:name="com.sample.teapot.TeapotNativeActivity"
android:label="@string/app_name"
android:configChanges="orientation|keyboardHidden">
<!-- Tell NativeActivity the name of our .so -->
<meta-data android:name="android.app.lib_name"
android:value="TeapotNativeActivity" />
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
flutter app 的生命周期
Flutter提供了WidgetsBindingObserver来监听AppLifecycleState, 而AppLifecycleState有4种状态:
flutter状态名称 | 状态 | 对应ios | 对应安卓 |
---|---|---|---|
resumed | 可见并能响应用户的输入 | applicationDidBecomeActive | onResume |
inactive | 处在并不活动状态,无法处理用户响应 | applicationWillResignActive、applicationWillEnterForeground | onPause |
paused | 不可见并不能响应用户的输入,但是在后台继续活动中 | applicationDidEnterBackground | onStop |
suspending | iOS中没用,安卓里就是挂起,不会再执行drawframe回调 | _ | 挂起 |
1、初次打开widget时,不执行AppLifecycleState的回调;
2、按home键或Power键, AppLifecycleState inactive---->AppLifecycleState pause
3、从后台到前台:AppLifecycleState inactive--->ApplifecycleState resumed
4、back键退出应用: AppLifecycleState inactive--->AppLifecycleState paused
class _MyHomePageState extends State<MyHomePage> with WidgetsBindingObserver {
AppLifecycleState _lastLifecycleState;
void dispose() {
super.dispose();
WidgetsBinding.instance.removeObserver(this);
}
@override
void initState() {
super.initState();
WidgetsBinding.instance.addObserver(this);
}
@override
void didChangeAppLifecycleState(AppLifecycleState state) {
print(state);
}
...
}
flutter界面
flutter | ios | android |
---|---|---|
flutterView | ViewController | Activity |
Android 的activity必须在AndroidManifest.xml注册,并设置好入口。
在Android中,Activity代表了用户界面的一部分,最常用于一个屏幕。View是屏幕上显示的所有内容的基础, 按钮、工具栏、输入框等一切都是View。 在Flutter中,View相当于是Widget。activity调用setContentView将view绘画到activity上。
在 iOS 中,一个 ViewController 类型于android的Activity,代表了用户界面的一部分,最常用于一个屏幕,或是其中一部分。它们被组合在一起用于构建复杂的用户界面,并帮助你拆分 App 的 UI。在 Flutter 中,这一任务回落到了 widgets 中。就像在界面导航部分提到的一样,一个屏幕也是被 widgets 来表示的,因为“万物皆 widget!”。