您的位置:首頁技術文章
文章詳情頁

Flutter 和 Android 互相傳遞數據的實現

瀏覽:84日期:2022-09-21 18:24:35

(一)Android代碼設置

1,打開Android Studio 創建一個應用程序,包名dev.android.book 2, 創建一個MyApplication ,應用在AndroidManifest.xml文件中的application的android:name屬性上 3,創建FlutterEngine的實例,然后把這個實例添加到緩存的FlutterEngine當中 4,創建MethodChannel的實例,指定一個此實例的唯一字符串,例如dev.android.book/add 5, 設置methodChannel方法回調函數,接收Flutter通過MethodChannel發過來的消息 6,Flutter發過來的消息眾多,是通過 MethodCall對象中的方法名來判斷 7,Android端向Flutter發送消息,也是通過methodChannel對象的的invokeMethod方法

針對以上的各個步驟添加說明

1,很簡單就是打開Android studio =>File=>New Project=>Select a Project Template=>input Name, Package name等=>Finish

2,創建BookApplication 目的是 預初始化FlutterEngine,啟動Flutter有三種方式

a,第一種方式,就是創建默認的FlutterEngine 比如 FlutterActivity.createDefaultIntent(this) b, 第二種方式,就是創建新的FlutterEngine 比如 FlutterActivity.withNewEngine().build(this) c, 第三種方式,就是使用緩存FlutterEngine 比如 FlutterActivity.withCachedEngine(ENGINE_ID).build(this)

簡單解析這三種方式 a和b其實是一樣的,FlutterActivity.createDefaultIntent其實調用的還是FlutterActivity.withNewEngine()方法 如下圖所示,

Flutter 和 Android 互相傳遞數據的實現

如果在開發中不建議使用a,b方法,是因為在開發過程中,在原聲當中打開Flutter頁面,會有一段時間的黑屏,這是因為FlutterEngine在初始化,初始化完成之后,就可以顯示Flutter頁面

3,創建FlutterEngine的實例 有兩種方法,直接傳Context,或者傳Context dartVmArgs

Flutter 和 Android 互相傳遞數據的實現

4,創建MethodChannel的實例,提供兩種構造方法 messenger和name, message和name 和 MethodCodec

Flutter 和 Android 互相傳遞數據的實現

5,設置MethodChannel方法的回調,接收Flutter傳過來的內容,提供一個參數 MethodCallHandler

Flutter 和 Android 互相傳遞數據的實現

6,Flutter傳過來的值各種各樣,是通過接口 MethodCallHandler

Flutter 和 Android 互相傳遞數據的實現

MethodCallHandler里面的抽象方法onMethodCall來區分,onMethodCall方法里面有兩個參數 MethodCall包含傳過來參數的一些信息 比如方法名,參數等信息,

Flutter 和 Android 互相傳遞數據的實現

result表示成功或者失敗的一些回調信息

Flutter 和 Android 互相傳遞數據的實現

7,Android端向Flutter端發送消息,是通過注冊的MethodChannel 調用invokeMethod方法,有兩個參數,方法的名字,和參數

Flutter 和 Android 互相傳遞數據的實現

c,建議使用這種提前初始化FlutterEngine的方法,使用過程中,頁面幾乎沒有停頓打開Flutter頁面,所以要在Application中提前初始化 初始化代碼如下

Flutter 和 Android 互相傳遞數據的實現

(二)Flutter代碼設置

1,打開VSCODE 創建一個應用程序,包名my_flutter 2,創建MethodChannel的實例,指定一個此實例的唯一字符串,例如dev.android.book/add 3, 設置methodChannel方法回調函數,接收Flutter通過MethodChannel發過來的消息 4,Android發過來的消息眾多,是通過 MethodCall對象中的方法名來判斷 5,Android端向Flutter發送消息,也是通過methodChannel對象的的invokeMethod方法

針對以上的各個步驟添加說明

1,創建一個flutter model,最后要作為依賴添加到原聲代碼當中,通過命令 flutter create -t module --org com.flutter my_flutter,執行完成之后如圖所示

Flutter 和 Android 互相傳遞數據的實現

2,在所在的類中直接初始化 MethodChannel ,比如 final _channel = MethodChannel(channel_name); 參數是一個唯一的字符串,這個字符串必須和Android端中的字符串保持一致

Flutter 和 Android 互相傳遞數據的實現

3,給MethodChannel設置方法調用回調 ,參數和Android端基本上一致

Flutter 和 Android 互相傳遞數據的實現

4,Android端發送過來的消息 也是通過 MethodCall來判斷,可以更具方法名來判斷

Flutter 和 Android 互相傳遞數據的實現

5,Flutter端向Android端發送消息,也是通過注冊的MethodChannel調用invokeMethod,發送消息

Flutter 和 Android 互相傳遞數據的實現

(三)向Android工程中引入剛才創建的FLutter工程

在Android工程中的settings.gradle中添加如下代碼

Flutter 和 Android 互相傳遞數據的實現

然后在依賴當中添加Flutter工程模塊

Flutter 和 Android 互相傳遞數據的實現

完成以上步驟,就完成了向已有的Android工程中添加flutter模塊,以及Android端和Flutter端數據是怎么傳遞的。

到此這篇關于Flutter 和 Android 互相傳遞數據的實現的文章就介紹到這了,更多相關Flutter Android 互相傳遞數據內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Android
相關文章:
国产综合久久一区二区三区