Class FlutterEngine
- java.lang.Object
-
- io.flutter.embedding.engine.FlutterEngine
-
public class FlutterEngine extends Object
A single Flutter execution environment.The
FlutterEngineis the container through which Dart code can be run in an Android application.Dart code in a
FlutterEnginecan execute in the background, or it can be render to the screen by using the accompanyingFlutterRendererand Dart code using the Flutter framework on the Dart side. Rendering can be started and stopped, thus allowing aFlutterEngineto move from UI interaction to data-only processing and then back to UI interaction.Multiple
FlutterEngines may exist, execute Dart code, and render UIs within a single Android app. For better memory performance characteristics, construct multipleFlutterEngines viaFlutterEngineGrouprather than viaFlutterEngine's constructor directly.To start running Dart and/or Flutter within this
FlutterEngine, get a reference to this engine'sDartExecutorand then useDartExecutor.executeDartEntrypoint(DartExecutor.DartEntrypoint). TheDartExecutor.executeDartEntrypoint(DartExecutor.DartEntrypoint)method must not be invoked twice on the sameFlutterEngine.To start rendering Flutter content to the screen, use
getRenderer()to obtain aFlutterRendererand then attach aRenderSurface. Consider using aFlutterViewas aRenderSurface.Instatiating the first
FlutterEngineper process will also load the Flutter engine's native library and start the Dart VM. SubsequentFlutterEngines will run on the same VM instance but will have their own Dart Isolate when theDartExecutoris run. Each Isolate is a self-contained Dart environment and cannot communicate with each other except via Isolate ports.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static interfaceFlutterEngine.EngineLifecycleListenerLifecycle callbacks for Flutter engine lifecycle events.
-
Constructor Summary
Constructors Constructor Description FlutterEngine(Context context)Constructs a newFlutterEngine.FlutterEngine(Context context, FlutterLoader flutterLoader, FlutterJNI flutterJNI)Same asFlutterEngine(Context, FlutterLoader, FlutterJNI, String[], boolean)but with no Dart VM flags and automatically registers plugins.FlutterEngine(Context context, FlutterLoader flutterLoader, FlutterJNI flutterJNI, PlatformViewsController platformViewsController, String[] dartVmArgs, boolean automaticallyRegisterPlugins)Same asFlutterEngine(Context, FlutterLoader, FlutterJNI, String[], boolean), plus the ability to provide a customPlatformViewsController.FlutterEngine(Context context, FlutterLoader flutterLoader, FlutterJNI flutterJNI, PlatformViewsController platformViewsController, String[] dartVmArgs, boolean automaticallyRegisterPlugins, boolean waitForRestorationData)Fully configurableFlutterEngineconstructor.FlutterEngine(Context context, FlutterLoader flutterLoader, FlutterJNI flutterJNI, String[] dartVmArgs, boolean automaticallyRegisterPlugins)Same asFlutterEngine(Context, FlutterLoader, FlutterJNI), plus Dart VM flags indartVmArgs, and control over whether plugins are automatically registered with thisFlutterEngineinautomaticallyRegisterPlugins.FlutterEngine(Context context, String[] dartVmArgs)Same asFlutterEngine(Context)with added support for passing Dart VM arguments.FlutterEngine(Context context, String[] dartVmArgs, boolean automaticallyRegisterPlugins)Same asFlutterEngine(Context)with added support for passing Dart VM arguments and avoiding automatic plugin registration.FlutterEngine(Context context, String[] dartVmArgs, boolean automaticallyRegisterPlugins, boolean waitForRestorationData)Same asFlutterEngine(Context, String[], boolean)with added support for configuring whether the engine will receive restoration data.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddEngineLifecycleListener(FlutterEngine.EngineLifecycleListener listener)Adds alistenerto be notified of Flutter engine lifecycle events, e.g.,onPreEngineStart().voiddestroy()Cleans up all components within thisFlutterEngineand destroys the associated Dart Isolate.AccessibilityChannelgetAccessibilityChannel()System channel that sends accessibility requests and events from Flutter to Android.ActivityControlSurfacegetActivityControlSurface()BroadcastReceiverControlSurfacegetBroadcastReceiverControlSurface()ContentProviderControlSurfacegetContentProviderControlSurface()DartExecutorgetDartExecutor()The Dart execution context associated with thisFlutterEngine.DeferredComponentChannelgetDeferredComponentChannel()System channel that allows manual installation and state querying of deferred components.LifecycleChannelgetLifecycleChannel()System channel that sends Android lifecycle events to Flutter.LocalizationChannelgetLocalizationChannel()System channel that sends locale data from Android to Flutter.io.flutter.plugin.localization.LocalizationPlugingetLocalizationPlugin()The LocalizationPlugin this FlutterEngine created.MouseCursorChannelgetMouseCursorChannel()System channel that sends and receives text input requests and state.NavigationChannelgetNavigationChannel()System channel that sends Flutter navigation commands from Android to Flutter.PlatformChannelgetPlatformChannel()System channel that sends platform-oriented requests and information to Flutter, e.g., requests to play sounds, requests for haptics, system chrome settings, etc.PlatformViewsControllergetPlatformViewsController()PlatformViewsController, which controls all platform views running within thisFlutterEngine.PluginRegistrygetPlugins()Plugin registry, which registers plugins that want to be applied to thisFlutterEngine.FlutterRenderergetRenderer()The rendering system associated with thisFlutterEngine.RestorationChannelgetRestorationChannel()System channel to exchange restoration data between framework and engine.ServiceControlSurfacegetServiceControlSurface()SettingsChannelgetSettingsChannel()System channel that sends platform/user settings from Android to Flutter, e.g., time format, scale factor, etc.SpellCheckChannelgetSpellCheckChannel()System channel that sends and receives spell check requests and results.SystemChannelgetSystemChannel()System channel that sends memory pressure warnings from Android to Flutter.TextInputChannelgetTextInputChannel()System channel that sends and receives text input requests and state.voidremoveEngineLifecycleListener(FlutterEngine.EngineLifecycleListener listener)Removes alistenerthat was previously added withaddEngineLifecycleListener(EngineLifecycleListener).
-
-
-
Constructor Detail
-
FlutterEngine
public FlutterEngine(@NonNull Context context)Constructs a newFlutterEngine.A new
FlutterEnginedoes not execute any Dart code automatically. SeegetDartExecutor()andDartExecutor.executeDartEntrypoint(DartExecutor.DartEntrypoint)to begin executing Dart code within thisFlutterEngine.A new
FlutterEnginewill not display any UI until aRenderSurfaceis registered. SeegetRenderer()andFlutterRenderer.startRenderingToSurface(Surface, boolean).A new
FlutterEngineautomatically attaches all plugins. SeegetPlugins().A new
FlutterEnginedoes come with all default system channels attached.The first
FlutterEngineinstance constructed per process will also load the Flutter native library and start a Dart VM.In order to pass Dart VM initialization arguments (see
FlutterShellArgs) when creating the VM, manually set the initialization arguments by callingFlutterLoader.startInitialization(Context)andFlutterLoader.ensureInitializationComplete(Context, String[])before constructing the engine.
-
FlutterEngine
public FlutterEngine(@NonNull Context context, @Nullable String[] dartVmArgs)Same asFlutterEngine(Context)with added support for passing Dart VM arguments.If the Dart VM has already started, the given arguments will have no effect.
-
FlutterEngine
public FlutterEngine(@NonNull Context context, @Nullable String[] dartVmArgs, boolean automaticallyRegisterPlugins)Same asFlutterEngine(Context)with added support for passing Dart VM arguments and avoiding automatic plugin registration.If the Dart VM has already started, the given arguments will have no effect.
-
FlutterEngine
public FlutterEngine(@NonNull Context context, @Nullable String[] dartVmArgs, boolean automaticallyRegisterPlugins, boolean waitForRestorationData)Same asFlutterEngine(Context, String[], boolean)with added support for configuring whether the engine will receive restoration data.The
waitForRestorationDataflag controls whether the engine delays responding to requests from the framework for restoration data until that data has been provided to the engine viaRestorationChannel.setRestorationData(byte[] data). If the flag is false, the framework may temporarily initialize itself to default values before the restoration data has been made available to the engine. SettingwaitForRestorationDatato true avoids this extra work by delaying initialization until the data is available.When
waitForRestorationDatais set,RestorationChannel.setRestorationData(byte[] data)must be called at a later point in time. If it later turns out that no restoration data is available to restore the framework from, that method must still be called with null as an argument to indicate "no data".If the framework never requests the restoration data, this flag has no effect.
-
FlutterEngine
public FlutterEngine(@NonNull Context context, @Nullable FlutterLoader flutterLoader, @NonNull FlutterJNI flutterJNI)Same asFlutterEngine(Context, FlutterLoader, FlutterJNI, String[], boolean)but with no Dart VM flags and automatically registers plugins.flutterJNIshould be a new instance that has never been attached to an engine before.
-
FlutterEngine
public FlutterEngine(@NonNull Context context, @Nullable FlutterLoader flutterLoader, @NonNull FlutterJNI flutterJNI, @Nullable String[] dartVmArgs, boolean automaticallyRegisterPlugins)Same asFlutterEngine(Context, FlutterLoader, FlutterJNI), plus Dart VM flags indartVmArgs, and control over whether plugins are automatically registered with thisFlutterEngineinautomaticallyRegisterPlugins. If plugins are automatically registered, then they are registered during the execution of this constructor.
-
FlutterEngine
public FlutterEngine(@NonNull Context context, @Nullable FlutterLoader flutterLoader, @NonNull FlutterJNI flutterJNI, @NonNull PlatformViewsController platformViewsController, @Nullable String[] dartVmArgs, boolean automaticallyRegisterPlugins)Same asFlutterEngine(Context, FlutterLoader, FlutterJNI, String[], boolean), plus the ability to provide a customPlatformViewsController.
-
FlutterEngine
public FlutterEngine(@NonNull Context context, @Nullable FlutterLoader flutterLoader, @NonNull FlutterJNI flutterJNI, @NonNull PlatformViewsController platformViewsController, @Nullable String[] dartVmArgs, boolean automaticallyRegisterPlugins, boolean waitForRestorationData)Fully configurableFlutterEngineconstructor.
-
-
Method Detail
-
destroy
public void destroy()
Cleans up all components within thisFlutterEngineand destroys the associated Dart Isolate. All state held by the Dart Isolate, such as the Flutter Elements tree, is lost.This
FlutterEngineinstance should be discarded after invoking this method.
-
addEngineLifecycleListener
public void addEngineLifecycleListener(@NonNull FlutterEngine.EngineLifecycleListener listener)Adds alistenerto be notified of Flutter engine lifecycle events, e.g.,onPreEngineStart().
-
removeEngineLifecycleListener
public void removeEngineLifecycleListener(@NonNull FlutterEngine.EngineLifecycleListener listener)Removes alistenerthat was previously added withaddEngineLifecycleListener(EngineLifecycleListener).
-
getDartExecutor
@NonNull public DartExecutor getDartExecutor()
The Dart execution context associated with thisFlutterEngine.The
DartExecutorcan be used to start executing Dart code from a given entrypoint. SeeDartExecutor.executeDartEntrypoint(DartExecutor.DartEntrypoint).Use the
DartExecutorto connect any desired message channels and method channels to facilitate communication between Android and Dart/Flutter.
-
getRenderer
@NonNull public FlutterRenderer getRenderer()
The rendering system associated with thisFlutterEngine.To render a Flutter UI that is produced by this
FlutterEngine's Dart code, attach aRenderSurfaceto thisFlutterRenderer.
-
getAccessibilityChannel
@NonNull public AccessibilityChannel getAccessibilityChannel()
System channel that sends accessibility requests and events from Flutter to Android.
-
getLifecycleChannel
@NonNull public LifecycleChannel getLifecycleChannel()
System channel that sends Android lifecycle events to Flutter.
-
getLocalizationChannel
@NonNull public LocalizationChannel getLocalizationChannel()
System channel that sends locale data from Android to Flutter.
-
getNavigationChannel
@NonNull public NavigationChannel getNavigationChannel()
System channel that sends Flutter navigation commands from Android to Flutter.
-
getPlatformChannel
@NonNull public PlatformChannel getPlatformChannel()
System channel that sends platform-oriented requests and information to Flutter, e.g., requests to play sounds, requests for haptics, system chrome settings, etc.
-
getRestorationChannel
@NonNull public RestorationChannel getRestorationChannel()
System channel to exchange restoration data between framework and engine.The engine can obtain the current restoration data from the framework via this channel to store it on disk and - when the app is relaunched - provide the stored data back to the framework to recreate the original state of the app.
-
getSettingsChannel
@NonNull public SettingsChannel getSettingsChannel()
System channel that sends platform/user settings from Android to Flutter, e.g., time format, scale factor, etc.
-
getDeferredComponentChannel
@NonNull public DeferredComponentChannel getDeferredComponentChannel()
System channel that allows manual installation and state querying of deferred components.
-
getSystemChannel
@NonNull public SystemChannel getSystemChannel()
System channel that sends memory pressure warnings from Android to Flutter.
-
getMouseCursorChannel
@NonNull public MouseCursorChannel getMouseCursorChannel()
System channel that sends and receives text input requests and state.
-
getTextInputChannel
@NonNull public TextInputChannel getTextInputChannel()
System channel that sends and receives text input requests and state.
-
getSpellCheckChannel
@NonNull public SpellCheckChannel getSpellCheckChannel()
System channel that sends and receives spell check requests and results.
-
getPlugins
@NonNull public PluginRegistry getPlugins()
Plugin registry, which registers plugins that want to be applied to thisFlutterEngine.
-
getLocalizationPlugin
@NonNull public io.flutter.plugin.localization.LocalizationPlugin getLocalizationPlugin()
The LocalizationPlugin this FlutterEngine created.
-
getPlatformViewsController
@NonNull public PlatformViewsController getPlatformViewsController()
PlatformViewsController, which controls all platform views running within thisFlutterEngine.
-
getActivityControlSurface
@NonNull public ActivityControlSurface getActivityControlSurface()
-
getServiceControlSurface
@NonNull public ServiceControlSurface getServiceControlSurface()
-
getBroadcastReceiverControlSurface
@NonNull public BroadcastReceiverControlSurface getBroadcastReceiverControlSurface()
-
getContentProviderControlSurface
@NonNull public ContentProviderControlSurface getContentProviderControlSurface()
-
-