Flutter_Boost v0.1.5升級 Android版本

Rx_Re發表於2019-09-16

1.新特性

  1. 支援Flutter 1.5
  2. 從老版的複用FlutterView,到新版的建立新的例項
  3. 新版建立新的的例項Flutter,可以避免白屏,閃屏,黑屏等現象
  4. 推薦使用ContainerLifeCycle observer來監聽APP的生命週期
  5. 移除了xservice通訊外掛

2.主要的API變化

IPlatform

移除一下程式碼

Activity getMainActivity();
boolean startActivity(Context context,String url,int requestCode);
Map getSettings();
複製程式碼

新增加

void registerPlugins(PluginRegistry registry) 方法
void openContainer(Context context,String url,Map<String,Object> urlParams,int requestCode,Map<String,Object> exts);
void closeContainer(IContainerRecord record, Map<String,Object> result, Map<String,Object> exts);
IFlutterEngineProvider engineProvider();
int whenEngineStart();
複製程式碼

這個Api變化主要是在Application初始化的時候的修改

以上是Flutter_boost github上面的說明,具體可以檢視

3.接入指南

接入的方式主要是在V0.0.420版本上面做的修改,V0.0.420的接入方式可以參考我之前的文章

舊版本 Application類的修改

public class MyApplication extends Application {

  @Override
  public void onCreate() {
    super.onCreate();
    FlutterBoostPlugin.init(new IPlatform() {
      @Override
      public Application getApplication() {
        return MyApplication.this;
      }

      /**
       * get the main activity, this activity should always at the bottom of task stack.
       */
      @Override
      public Activity getMainActivity() {
        return MainActivity.sRef.get();
      }

      @Override
      public boolean isDebug() {
        return false;
      }

      /**
       * start a new activity from flutter page, you may need a activity router.
       */
      @Override
      public boolean startActivity(Context context, String url, int requestCode) {
        return PageRouter.openPageByUrl(context,url,requestCode);
      }

      @Override
      public Map getSettings() {
        return null;
      }
    });
  }
}
複製程式碼

可以繼承FlutterApplication,直接使用,不繼承FlutterApplication 的話需要在使用Flutter的Activity中onCreate加入 FlutterMain.startInitialization(this); 如下所示

@CallSuper
  public void onCreate() {
   FlutterMain.startInitialization(this);
    super.onCreate();
  }
複製程式碼

其實對應的FlutterApplication是很簡單的,主要還是在onCreate中

public class FlutterApplication extends Application {
  private Activity mCurrentActivity = null;

  public FlutterApplication() {
  }

  @CallSuper
  public void onCreate() {
    super.onCreate();
    FlutterMain.startInitialization(this);
  }

  public Activity getCurrentActivity() {
    return this.mCurrentActivity;
  }

  public void setCurrentActivity(Activity mCurrentActivity) {
    this.mCurrentActivity = mCurrentActivity;
  }
}
複製程式碼

新版本 Application類的修改

public class MyApplication extends FlutterApplication {
    @Override
    public void onCreate() {
        super.onCreate();

        FlutterBoost.init(new Platform() {

            @Override
            public Application getApplication() {
                return MyApplication.this;
            }

            @Override
            public boolean isDebug() {
                return true;
            }

            @Override
            public void openContainer(Context context, String url, Map<String, Object> urlParams, int requestCode, Map<String, Object> exts) {
                PageRouter.openPageByUrl(context,url,urlParams,requestCode);
            }

            @Override
            public IFlutterEngineProvider engineProvider() {
                return new BoostEngineProvider(){
                    @Override
                    public BoostFlutterEngine createEngine(Context context) {
                        return new BoostFlutterEngine(context, new DartExecutor.DartEntrypoint(
                                context.getResources().getAssets(),
                                FlutterMain.findAppBundlePath(context),
                                "main"),"/");
                    }
                };
            }

            @Override
            public int whenEngineStart() {
                return IMMEDIATELY;
            }
        });
    }
}

複製程式碼

移除和新增程式碼,前面講了,這裡主要講一下whenEngineStart()函式,其返回值有兩個

 int IMMEDIATELY = 0;          //立即啟動引擎
 int ANY_ACTIVITY_CREATED = 1; //當有任何Activity建立時,啟動引擎
複製程式碼

官方demo給的預設值是ANY_ACTIVITY_CREATED 建立Activity 都會啟動,主要是控制引擎的初始化時機

engineProvider()返回一個Flutter引擎提供者,BoostEngineProvider,主要看其內部的createEngine()方法

 @Override
public BoostFlutterEngine createEngine(Context context) {
    return new BoostFlutterEngine(context, new DartExecutor.DartEntrypoint(
            context.getResources().getAssets(),
            FlutterMain.findAppBundlePath(context),
            "main"),"/");
}
複製程式碼

這裡大致講一下其中的main字元,這個主要是在BoostFlutterEngine內部建立引擎的時候,設定對應的Flutter 執行的main函式也就是Flutter程式碼的執行的入口,斜槓主要是初始化路由用的

4.Flutter混合庫函式升級Flutter_boost

修改版本資訊v0.1.52,最新版

移除

FlutterBoost.handleOnStartPage();
複製程式碼

開啟頁面不帶引數

FlutterBoost.singleton.openPage("second", {}, animated: true);
<!--修改成-->
FlutterBoost.singleton.open("second")
複製程式碼

開啟頁面帶引數

  FlutterBoost.singleton.openPage("sample://nativePage", {
                  "query": {"aaa": "bbb"}
                }),
<!--修改成-->
  FlutterBoost.singleton.open("sample://nativePage", urlParams:{
                  "query": {"aaa": "bbb"}
                }),
複製程式碼

關閉頁面

FlutterBoost.singleton.closePageForContext(context);
<!--修改成-->
BoostContainerSettings settings = BoostContainer.of(context).settings;
FlutterBoost.singleton.close(settings.uniqueId,result: {"result":"data from second"});
複製程式碼

相關文章