flutter plugin之路:flutter與原生交互傳值OC/java版(二)

  • 系列文章

flutter與原生交互傳值OC/java版(一)
flutter與原生交互傳值OC/java版(二)
四步實現(xiàn)flutter顯示iOS原生組件OC/java版(三)
四步實現(xiàn)flutter顯示安卓原生組件OC/java版(三)
本demo的github地址:https://github.com/iBinbro/flutterstudy

上一篇flutter plugin之路:flutter與原生交互傳值OC/java版(一)說道如何使用flutter調(diào)用原生api傳值(值的傳遞流程這樣:flutter->原生->flutter,flutter調(diào)用原生方法,此時flutter可以傳一個參數(shù)給原生埃碱,然后原生接受flutter的調(diào)用后拍皮,再返回一個值給flutter),這一篇說的是原生如何主動傳值給flutter

實現(xiàn)流程

flutter通過標識監(jiān)聽指定的通道->原生通過這個通道向flutter發(fā)送信息->flutter通過監(jiān)聽這個通道獲取原生發(fā)送的信息

實現(xiàn)目標村怪,原生每1秒調(diào)用一次方法,自增數(shù)值,然后傳到flutter挫剑,再由flutter進行顯示

本demo的github地址:https://github.com/iBinbro/flutterstudy
(補充了安卓java版贯莺,以OC為例作為分析风喇,安卓java同理不做敘述了)

一、flutter端的實現(xiàn)

1.創(chuàng)建TwoCommunicate類(statefulwidget)
2.flutter注冊監(jiān)聽通道
3.聲明兩個方法用于處理接收到的數(shù)據(jù)以及異常錯誤
4.執(zhí)行監(jiān)聽
5.build方法實現(xiàn)布局缕探,將返回的數(shù)據(jù)顯示出來

import 'package:flutter/material.dart';
import 'dart:async';
import 'package:flutter/services.dart';

class TwoCommunicate extends StatefulWidget {
  @override
  _TwoCommunicateState createState() => _TwoCommunicateState();
}

class _TwoCommunicateState extends State<TwoCommunicate> {

  //****************原生主動調(diào)用flutter****************//
  //存放原生傳給flutter的值
  String _nativeToFlutterString = '';

  //注冊監(jiān)聽原生通道
  EventChannel eventChannel = EventChannel('http://www.reibang.com/p/7dbbd3b4ce32');

  //監(jiān)聽到數(shù)據(jù)后用于處理數(shù)據(jù)的方法魂莫,這個函數(shù)是用于處理接收到原生傳進來的數(shù)據(jù)的,可自行定義
  void _receiveFromeNative(Object para){
    print(para);
    setState(() {
      _nativeToFlutterString = para.toString();
    });
  }

  //原生返回錯誤信息
  void _fromNativeError(Object error){
    print(error);
  }

  @override
  void initState() {
    // TODO: implement initState
    //實現(xiàn)通道的監(jiān)聽爹耗,并傳入兩個帶有參數(shù)的函數(shù)用于監(jiān)聽到數(shù)據(jù)后 對數(shù)據(jù)進行處理
    eventChannel.receiveBroadcastStream().listen(_receiveFromeNative, onError: _fromNativeError);
    super.initState();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('text'),
      ),
      body: Container(
        padding: EdgeInsets.all(32.0),
        child: Center(
          child: Column(
            children: <Widget>[
              //顯示原生傳過來的值
              MaterialButton(
                color: Colors.green,
                child: Text(_nativeToFlutterString),
                onPressed: () {
                },
              )
            ],
          ),
        ),
      ),
    );
  }
}

二耙考、原生端iOS OC的實現(xiàn),
先運行下工程,避免打開ios工程缺少文件潭兽,然后在工程目錄進入ios文件夾倦始,打開Runner.xcworkspace,使用xcode進行原生代碼的編寫
#include "AppDelegate.h"
#include "GeneratedPluginRegistrant.h"

//遵循代理方法
@interface AppDelegate()<FlutterStreamHandler>

@end

@implementation AppDelegate{
    /// 用于主動傳值給flutter的橋梁.
    FlutterEventSink _eventSink;
    NSInteger _nativeCount;
}

- (BOOL)application:(UIApplication *)application
    didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    
    __weak __typeof(self) weakself = self;
    
    FlutterViewController *controller = (FlutterViewController *)self.window.rootViewController;
    
    /**********原生主動傳值給flutter-Start**********/
    _nativeCount = 0;
    
    NSLog(@"原生實現(xiàn) 原生傳值給flutter的通道標識");
    FlutterEventChannel *eventChannel = [FlutterEventChannel eventChannelWithName:@"http://www.reibang.com/p/7dbbd3b4ce32" binaryMessenger:controller];
    //設置代理
    [eventChannel setStreamHandler:self];
    
    /**********原生主動傳值給flutter-End**********/
    
    
    
  [GeneratedPluginRegistrant registerWithRegistry:self];
  // Override point for customization after application launch.
  return [super application:application didFinishLaunchingWithOptions:launchOptions];
}

/**********原生主動傳值給flutter-Start**********/
//flutter開始進行監(jiān)聽山卦,并在此方法傳入 原生主動傳值給flutter的橋梁 event
- (FlutterError *)onListenWithArguments:(id)arguments eventSink:(FlutterEventSink)events{
    NSLog(@"flutter開始進行監(jiān)聽鞋邑,并在此方法傳入 原生主動傳值給flutter的橋梁 event");
    _eventSink = events;
    
    [self repeatAddNativeCount];
    
    return nil;
}

//翻了下官方文檔 Invoked when the last listener is deregistered from the Stream associated to this channel on the Flutter side. 大致意思是stream關(guān)聯(lián)的這個通道監(jiān)聽器取消后調(diào)用,找了下flutter的dart代碼,沒取消監(jiān)聽的方法 后面再說吧 待解
- (FlutterError *)onCancelWithArguments:(id)arguments{
    _eventSink = nil;
    return nil;
}

- (void)repeatAddNativeCount{
    NSLog(@"重復傳值執(zhí)行");
    _nativeCount++;
    //通過橋梁傳值
    if (_eventSink) {
        _eventSink(@(_nativeCount));
    }
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
        [self repeatAddNativeCount];
    });
}

/**********原生主動傳值給flutter-Start**********/

@end

效果圖


image.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市枚碗,隨后出現(xiàn)的幾起案子逾一,更是在濱河造成了極大的恐慌,老刑警劉巖肮雨,帶你破解...
    沈念sama閱讀 216,744評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件遵堵,死亡現(xiàn)場離奇詭異,居然都是意外死亡怨规,警方通過查閱死者的電腦和手機陌宿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來波丰,“玉大人壳坪,你說我怎么就攤上這事⊙教颍” “怎么了弥虐?”我有些...
    開封第一講書人閱讀 163,105評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長媚赖。 經(jīng)常有香客問我霜瘪,道長,這世上最難降的妖魔是什么惧磺? 我笑而不...
    開封第一講書人閱讀 58,242評論 1 292
  • 正文 為了忘掉前任颖对,我火速辦了婚禮,結(jié)果婚禮上磨隘,老公的妹妹穿的比我還像新娘缤底。我一直安慰自己,他們只是感情好番捂,可當我...
    茶點故事閱讀 67,269評論 6 389
  • 文/花漫 我一把揭開白布个唧。 她就那樣靜靜地躺著,像睡著了一般设预。 火紅的嫁衣襯著肌膚如雪徙歼。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,215評論 1 299
  • 那天鳖枕,我揣著相機與錄音魄梯,去河邊找鬼。 笑死宾符,一個胖子當著我的面吹牛酿秸,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播魏烫,決...
    沈念sama閱讀 40,096評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼辣苏,長吁一口氣:“原來是場噩夢啊……” “哼肝箱!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起考润,我...
    開封第一講書人閱讀 38,939評論 0 274
  • 序言:老撾萬榮一對情侶失蹤狭园,失蹤者是張志新(化名)和其女友劉穎读处,沒想到半個月后糊治,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,354評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡罚舱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,573評論 2 333
  • 正文 我和宋清朗相戀三年井辜,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片管闷。...
    茶點故事閱讀 39,745評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡粥脚,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出包个,到底是詐尸還是另有隱情刷允,我是刑警寧澤,帶...
    沈念sama閱讀 35,448評論 5 344
  • 正文 年R本政府宣布碧囊,位于F島的核電站树灶,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏糯而。R本人自食惡果不足惜天通,卻給世界環(huán)境...
    茶點故事閱讀 41,048評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望熄驼。 院中可真熱鬧像寒,春花似錦、人聲如沸瓜贾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,683評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽祭芦。三九已至筷笨,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間实束,已是汗流浹背奥秆。 一陣腳步聲響...
    開封第一講書人閱讀 32,838評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留咸灿,地道東北人构订。 一個月前我還...
    沈念sama閱讀 47,776評論 2 369
  • 正文 我出身青樓,卻偏偏與公主長得像避矢,于是被迫代替她去往敵國和親悼瘾。 傳聞我的和親對象是個殘疾皇子囊榜,可洞房花燭夜當晚...
    茶點故事閱讀 44,652評論 2 354

推薦閱讀更多精彩內(nèi)容