Flutter开发之——Android-Flutter添加到Activity(1)

本文介绍了在Android应用中使用Flutter进行自定义路由启动,包括默认启动、使用缓存FlutterEngine减少延迟的方法,并提供了创建FlutterEngine并在Activity中使用的示例。同时提到了Android开发中的核心知识点和资源分享。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

启动方式

startActivity(

FlutterActivity

.withNewEngine()

.initialRoute(“/my_route”)

.build(currentActivity)

);

2.3 路由启动示例

flutter/lib/main.dart

默认路由

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {

// This widget is the root of your application.

@override

Widget build(BuildContext context) {

return MaterialApp(

title: ‘Flutter Demo’,

theme: ThemeData(

primarySwatch: Colors.blue,

),

home: MyHomePage(title: ‘Flutter Demo Home Page’),

);

}

}

添加路由页面

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {

// This widget is the root of your application.

@override

Widget build(BuildContext context) {

return MaterialApp(

title: ‘Flutter Demo’,

theme: ThemeData(

primarySwatch: Colors.blue,

),

routes: <String,WidgetBuilder>{

“/”:(context)=>MyHomePage(title: ‘Flutter Demo Home Page’),

‘/a’:(context)=> MyPage(title:‘Page A’),

‘/b’:(context)=> MyPage(title:‘Page B’)

},

//home: MyHomePage(title: ‘Flutter Demo Home Page’),

);

}

}

class MyPage extends StatelessWidget{

var title;

MyPage({Key? key, required this.title}) : super(key: key);

@override

Widget build(BuildContext context) {

return Scaffold(

appBar: AppBar(title: Text(title),),

body: Center(child: Text(title),)

);

}

}

设置启动

startActivity(FlutterActivity

.withNewEngine()

.initialRoute(“/a”)

.build(this)

)

效果图

三 默认启动FlutterActivity


3.1 默认启动方式

myButton.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View v) {

startActivity(

FlutterActivity.createDefaultIntent(currentActivity)

);

}

});

2.3 缺点

  • 启动Flutter模块时,会有明显延迟

  • 会有一段时间的白屏

四 使用缓存的FlutterEngine启动FlutterActivity


4.1 说明

  • 默认情况下,每个FlutterActivity都会创建自己的FlutterEngine

  • 每个FlutterEngine都有预热时间,这意味着在FlutterActivity在可视之前,都会有延迟

  • 为了减少延迟,在创建FlutterActivity之前,预先创建FlutterEngine,然后使用预先创建的FlutterEngine

  • 要预先创建FlutterEngine,可以在应用程序中找到一个合适的位置来实例化FlutterEngine,一般在Application中完成

4.2 创建FlutterEngine(Application中)

public class MyApplication extends Application {

public FlutterEngine flutterEngine;

@Override

public void onCreate() {

super.onCreate();

// Instantiate a FlutterEngine.

flutterEngine = new FlutterEngine(this);

// Start executing Dart code to pre-warm the FlutterEngine.

flutterEngine.getDartExecutor().executeDartEntrypoint(

DartEntrypoint.createDefault()

);

// Cache the FlutterEngine to be used by FlutterActivity.

FlutterEngineCache

.getInstance()

.put(“my_engine_id”, flutterEngine);

}

}

说明:

  • my_engine_id:是个ID标识

  • 请确保传递到FlutterActivity或FlutterFragment的ID跟通过FlutterEngine创建的是同一个

4.3 Activity页面中使用FlutterEngine

startActivity(

FlutterActivity

.withCachedEngine(“my_engine_id”)

.build(this)

);

说明:

  • withCachedEngine(“my_engine_id”)跟Application中定义的my_engine_id是同一个

4.4 效果图

最后

这里我特地整理了一份《Android开发核心知识点笔记》,里面就包含了自定义View相关的内容

除了这份笔记,还给大家分享 Android学习PDF+架构视频+面试文档+源码笔记,高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料这几块的内容。非常适合近期有面试和想在技术道路上继续精进的朋友。

分享上面这些资源,希望可以帮助到大家提升进阶,如果你觉得还算有用的话,不妨把它们推荐给你的朋友~

喜欢本文的话,给我点个小赞、评论区留言或者转发支持一下呗~
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
14817500987)]

除了这份笔记,还给大家分享 Android学习PDF+架构视频+面试文档+源码笔记,高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料这几块的内容。非常适合近期有面试和想在技术道路上继续精进的朋友。

[外链图片转存中…(img-4vHg5GJj-1714817500988)]

分享上面这些资源,希望可以帮助到大家提升进阶,如果你觉得还算有用的话,不妨把它们推荐给你的朋友~

喜欢本文的话,给我点个小赞、评论区留言或者转发支持一下呗~
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值