Flutter調(diào)原生View

之前寫(xiě)過(guò)通過(guò)MethodChannel來(lái)調(diào)取原生方法摹菠。http://www.reibang.com/p/6b677ff3350e
但是這次是直接在Flutter里面調(diào)用一個(gè)android view病瞳。

一、Flutter項(xiàng)目中嵌入單個(gè)的Android View,步驟如下:

  • 首先找到flutter項(xiàng)目下的android目錄,點(diǎn)擊包名下面的MainActivity,在編輯器的右上角有一個(gè)Open forEditing in Android studio 按鈕辣之,點(diǎn)擊它可以進(jìn)入純android的項(xiàng)目中。


    android studio
  • 在包名下創(chuàng)建一個(gè)原生view皱炉,代碼如下
package com.example.flutter_demo

import android.content.Context
import android.view.View
import android.widget.TextView
import io.flutter.plugin.common.BinaryMessenger
import io.flutter.plugin.platform.PlatformView
class MyFlutterView(context: Context,messager : BinaryMessenger,
viewId: Int,argus: Map<String,Any>) : PlatformView{
    var  text : TextView =  TextView(context)
    init {
        text.text = "原生的textvieww"
    }
    override fun getView(): View {
        return text
    }

    override fun dispose() {
    }

}
  • 在創(chuàng)建一個(gè)PlatformViewFactory怀估,把原生view提供出去。代碼如下
package com.example.flutter_demo

import android.content.Context
import io.flutter.plugin.common.BinaryMessenger
import io.flutter.plugin.common.StandardMessageCodec
import io.flutter.plugin.platform.PlatformView
import io.flutter.plugin.platform.PlatformViewFactory

class MyFlutterViewFactory(private val messager : BinaryMessenger) : PlatformViewFactory(StandardMessageCodec.INSTANCE) {
    override fun create(context: Context?, viewId: Int, args: Any?): PlatformView {
        return MyFlutterView(context!!, messager,viewId,args as Map<String,Any>)
    }

}
  • 在創(chuàng)建一個(gè)FlutterPlugin,用來(lái)注冊(cè)PlatformViewFactory娃承,代碼如下
package com.example.flutter_demo

import io.flutter.embedding.engine.plugins.FlutterPlugin

class MyPlugin : FlutterPlugin{
    override fun onAttachedToEngine(binding: FlutterPlugin.FlutterPluginBinding) {
        var binaryMessenger = binding.binaryMessenger
        binding.platformViewRegistry.registerViewFactory( "plugins.flutter.io/custom_platform_view",
        MyFlutterViewFactory(binaryMessenger))
    }
    companion object{
        @JvmStatic
        fun registerWith(registry: io.flutter.plugin.common.PluginRegistry.Registrar){
            registry.platformViewRegistry().registerViewFactory("plugins.flutter.io/custom_platform_view",
                    MyFlutterViewFactory(registry.messenger()))
        }
    }

    override fun onDetachedFromEngine(binding: FlutterPlugin.FlutterPluginBinding) {
    }

}
  • 最后在MainActivity里面添加插件奏夫,代碼如下
package com.example.flutter_demo

import io.flutter.embedding.android.FlutterActivity
import io.flutter.embedding.engine.FlutterEngine

class MainActivity: FlutterActivity() {
    
    
    override fun configureFlutterEngine(flutterEngine: FlutterEngine) {
        super.configureFlutterEngine(flutterEngine)
        flutterEngine.plugins.add(MyPlugin())
    }
}

到此為止怕篷,android端的代碼完成历筝。再看下flutter端怎么調(diào)用android view

  • 判斷一下平臺(tái)酗昼,然后跟flutter一樣調(diào)用android view,代碼如下
getwidget7(){
  if(defaultTargetPlatform == TargetPlatform.android){
    return AndroidView(viewType: "plugins.flutter.io/custom_platform_view",creationParams: {"ss":333},
    creationParamsCodec: StandardMessageCodec(),);
  }
}

其中viewType和原生里面保持一致梳猪,creationParams是給原生傳遞參數(shù)的麻削。
直接運(yùn)行就可以實(shí)現(xiàn)在flutter里面使用android view。tip:注意使用真機(jī)春弥,我在使用模擬器的時(shí)候跑不起來(lái)呛哟。

調(diào)用原生view可以和調(diào)用原生方法一起用。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末匿沛,一起剝皮案震驚了整個(gè)濱河市扫责,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌逃呼,老刑警劉巖鳖孤,帶你破解...
    沈念sama閱讀 218,204評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異抡笼,居然都是意外死亡苏揣,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)推姻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)平匈,“玉大人,你說(shuō)我怎么就攤上這事藏古≡鎏浚” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,548評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵拧晕,是天一觀的道長(zhǎng)弟跑。 經(jīng)常有香客問(wèn)我,道長(zhǎng)防症,這世上最難降的妖魔是什么孟辑? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,657評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮蔫敲,結(jié)果婚禮上饲嗽,老公的妹妹穿的比我還像新娘。我一直安慰自己奈嘿,他們只是感情好貌虾,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,689評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著裙犹,像睡著了一般尽狠。 火紅的嫁衣襯著肌膚如雪衔憨。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,554評(píng)論 1 305
  • 那天袄膏,我揣著相機(jī)與錄音践图,去河邊找鬼。 笑死沉馆,一個(gè)胖子當(dāng)著我的面吹牛码党,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播斥黑,決...
    沈念sama閱讀 40,302評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼揖盘,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了锌奴?” 一聲冷哼從身側(cè)響起兽狭,我...
    開(kāi)封第一講書(shū)人閱讀 39,216評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎鹿蜀,沒(méi)想到半個(gè)月后箕慧,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,661評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡耻姥,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,851評(píng)論 3 336
  • 正文 我和宋清朗相戀三年销钝,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片琐簇。...
    茶點(diǎn)故事閱讀 39,977評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蒸健,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出婉商,到底是詐尸還是另有隱情似忧,我是刑警寧澤,帶...
    沈念sama閱讀 35,697評(píng)論 5 347
  • 正文 年R本政府宣布丈秩,位于F島的核電站盯捌,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏蘑秽。R本人自食惡果不足惜饺著,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,306評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望肠牲。 院中可真熱鬧幼衰,春花似錦、人聲如沸缀雳。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,898評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至识椰,卻和暖如春绝葡,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背腹鹉。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,019評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工藏畅, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人种蘸。 一個(gè)月前我還...
    沈念sama閱讀 48,138評(píng)論 3 370
  • 正文 我出身青樓墓赴,卻偏偏與公主長(zhǎng)得像竞膳,于是被迫代替她去往敵國(guó)和親航瞭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,927評(píng)論 2 355