Flutter の ios vs android

ios 配置文件info.plist

info.plist 实则是一个字典,可在Xcode中可视化。
它指定了比如一个应用应该怎样启动,它如何被本地化,应用的名称,要显示的图标,启动的图片。
字段列表详解请参考:cocoachina

也可以open as source code

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!”。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。