為您解碼網(wǎng)站建設(shè)的點(diǎn)點(diǎn)滴滴
發(fā)表日期:2018-11 文章編輯:小燈 瀏覽次數(shù):2659
https://github.com/flutter/flutter/wiki/Add-Flutter-to-existing-apps
第一個(gè)步:
新建一個(gè)標(biāo)準(zhǔn)的APP工程testFlutterInAPP,APP目錄下面通過(guò)命令創(chuàng)建flutter模塊工程
flutter create -t module my_flutter
編譯flutter 代碼生成Android的AAR文件
$ cd .android/ $ ./gradlew flutter:assembleDebug
AAR 文件生成到.android/Flutter/build/outputs/aar/目錄下面
添加Host APP 依賴flutter module 模塊,在setting.gradle 文件中加入
include ':app' // assumed existing content setBinding(new Binding([gradle: this])) // new evaluate(new File(// new settingsDir.parentFile, // new 'my_flutter/.android/include_flutter.groovy'// new ))
app/build.gradle 增加對(duì)flutter 工程依賴
// testFlutterInAPP/app/build.gradledependencies { implementation project(':flutter') }
構(gòu)建成功后,執(zhí)行Android的run啟動(dòng)應(yīng)用 ,點(diǎn)擊打開(kāi)flutter 。
Java 層代碼
openFlutter.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { View flutterView = Flutter.createView( MainActivity.this, getLifecycle(), "route1" ); FrameLayout.LayoutParams layout = new FrameLayout.LayoutParams(600, 800); layout.leftMargin = 100; layout.topMargin = 200; addContentView(flutterView, layout); } });
flutter 代碼
import 'dart:ui';import 'package:flutter/material.dart';void main() => runApp(_widgetForRoute(window.defaultRouteName)); Widget _widgetForRoute(String route) { switch (route) { case 'route1': return new MyApp(); case 'route2': return new MyApp(); default: return Center( child: Text('Unknownroute1 : $route', textDirection: TextDirection.ltr), ); } return new MyApp(); } class MyApp extends StatelessWidget { // This widget is the root of your application. @override Widget build(BuildContext context) { return new MaterialApp( title: 'Flutter Demo', theme: new ThemeData( primarySwatch: Colors.blue, ), home: new MyHomePage(title: 'Flutter Demo 1111' 'Home Page'), ); } }class MyHomePage extends StatefulWidget { MyHomePage({Key key, this.title}) : super(key: key);final String title;@override _MyHomePageState createState() => new _MyHomePageState(); }class _MyHomePageState extends State<MyHomePage> { int _counter = 0;void _incrementCounter() { setState(() {_counter++; }); }@override Widget build(BuildContext context) { return new Scaffold( appBar: new AppBar(title: new Text(widget.title), ), body: new Center( mainAxisAlignment: MainAxisAlignment.center, children: <Widget>[ new Text( 'You have pushed the button this many times:', ), new Text( '$_counter', style: Theme.of(context).textTheme.display1, ), ], ), ), floatingActionButton: new FloatingActionButton( onPressed: _incrementCounter, tooltip: 'Increment', child: new Icon(Icons.add), ), // This trailing comma makes auto-formatting nicer for build methods. ); } }
運(yùn)行 flutter 工程 ,進(jìn)入my_flutter 目錄執(zhí)行flutter run 命令
即可啟動(dòng)flutter ,r == hot reload R == hot restart
q == quit d == detach,
或者啟動(dòng)Android應(yīng)用調(diào)試
但是,好像DEBUG無(wú)效??
連接 https://zhuanlan.zhihu.com/p/40528502