Flutter混合开发(一):Android项目集成Flutter模块详细指南,看看这篇文章吧

293 阅读5分钟

然后打开app/build.gradle在dependencies标签中添加依赖:

implementation project(':flutter')

这样两步就完成了依赖的添加,这里为什么添加的叫“flutter” 而不是 “flutter_module”呢?因为项目编译完成后会在Android项目的目录下生成叫Flutter的目录,这就是需要我们依赖的。还有个需要注意是gradle中的minSdkVersion必须要大于等于16,因为这个flutter支持的最低版本。同时添加使用java8来编译。在app/build.gradle中的android标签中添加:

compileOptions {

sourceCompatibility JavaVersion.VERSION_1_8

targetCompatibility JavaVersion.VERSION_1_8

}

调用Flutter module

===================================================================================

依赖完成后我们就可以调用flutter模块来创建UI了。Flutter为我们提供了两种方式调用,一种是createView,以view的形式加载。另一种是createFragment,以Android中的fragment的形式加载。

createView方式:

public class MainActivity extends AppCompatActivity {

@Override

protected void onCreate(@Nullable Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

// setContentView(R.layout.activity_main);

FlutterView flutterView = Flutter.createView(this, getLifecycle(), "initialRoute");

setContentView(flutterView);

}

}

createFragment方式:

public class MainActivity extends AppCompatActivity {

@Override

protected void onCreate(@Nullable Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();

//container为activity_main布局中的占位符FrameLayout

transaction.replace(R.id.container, Flutter.createFragment("initialRoute"));

transaction.commit();

}

}

这样就将Flutter默认的首页加载到应用上了。

从上面两部分代码中我们可以看到都有一个 “initialRoute” 参数,这个参数是用来告诉Dart代码在Flutter视图中显示哪个小部件。下面我们就来修改module中的main.dart代码来加载我们自己的页面。

我们设置两个route,分别展示route1Widget,和route2Widget,当没有匹配的时候展示提醒文字。

import 'package:flutter/material.dart';

import 'dart:ui';

void main() => runApp(MyApp(

//通过window.defaultRouteName获取从native传递过来的参数,需要导入dart:ui包

initParams: window.defaultRouteName,

));

class MyApp extends StatelessWidget {

final String initParams;

MyApp({Key key, this.initParams}) : super(key: key);

@override

Widget build(BuildContext context) {

return MaterialApp(

title: 'Flutter_Android混合开发',

theme: ThemeData(

primarySwatch: Colors.blue,

),

home: HomePage(initParams: initParams),

);

}

}

class HomePage extends StatefulWidget {

final String initParams;

const HomePage({Key key, this.initParams}) : super(key: key);

@override

_HomePageState createState() => _HomePageState();

}

class _HomePageState extends State {

@override

Widget build(BuildContext context) {

return Scaffold(

body: Center(

child: _widgetRoute(widget.initParams),

),

);

}

}

///路由转发

Widget _widgetRoute(String route) {

switch (route) {

case "route1":

return route1Widget();

case "route2":

return route2Widget();

default:

return notFoundWidget();

}

}

Widget route1Widget() {

return Center(

child: Text(

"this is route1Widget",

style: TextStyle(color: Colors.red, fontSize: 20),

),

);

}

Widget route2Widget() {

return Center(

child: Text(

"this is route2Widget",

style: TextStyle(color: Colors.blue, fontSize: 20),

),

);

}

Widget notFoundWidget() {

return Center(

child: Text(

"未匹配到路由111",

style: TextStyle(fontSize: 40),

),

);

}

我们现在将加载Flutter时的initialRoute参数替换为 “route1”,那页面将加载route1Widget,替换为 “route2”,将加载route2Widget。否则将展示notFoundWidget。当然我们可以直接传路由参数,但是因为这个参数本身是一个字符串,所以我们可以来搞事情。比如传递一个json串,那么是不是可以做很多事呢?这里我就不贴demo了,因为和上面的逻辑基本一样,大家可以去试试看。

热重启/重新加载

===========================================================================

大家在写纯Flutter应用的时候,知道是有热重启/重新加载功能的,但是在做混合开发的过程中,你会发现热重启/重新加载功能失效了。那么如何在混合开发中开启热重启/重新加载功能呢?

  • 首先接入我们的设备或者模拟器

  • 将我们的App关闭,退出后台,在terminal中运行 flutter attach命令

$ flutter attach

Waiting for a connection from Flutter on Android SDK built for x86...

此时就在等待设备的连接。这里要注意的是,如果电脑连接了多台设备需要使用 -d 命令来指定一台设备,参数为设备的id。

flutter attach -d '你的设备id'

  • 然后启动我们的应用会看到控制台输出:

Done.

Syncing files to device Android SDK built for x86... 1,393ms

🔥 To hot reload changes while running, press "r". To hot restart (and rebuild state), press "R".

An Observatory debugger and profiler on Android SDK built for x86 is available at: http://127.0.0.1:59354/zRsDBfpesrk=/

For a more detailed help message, press "h". To detach, press "d"; to quit, press "q".

这样就表示我们连接成功了。在输出的日志中也告诉了我们如何使用热重启/重新加载功能。

在Terminal中输入以下命令​:​

r : 热加载;

尾声

最后,我再重复一次,如果你想成为一个优秀的 Android 开发人员,请集中精力,对基础和重要的事情做深度研究。

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

这里,笔者分享一份从架构哲学的层面来剖析的视频及资料分享给大家梳理了多年的架构经验,筹备近6个月最新录制的,相信这份视频能给你带来不一样的启发、收获。

Android进阶学习资料库

一共十个专题,包括了Android进阶所有学习资料,Android进阶视频,Flutter,java基础,kotlin,NDK模块,计算机网络,数据结构与算法,微信小程序,面试题解析,framework源码!