Flutter开发进阶:Channel

2022-03-07  本文已影响0人  __Null

1.初始化路由传值

//ios
let vc = FlutterViewController()
vc.setInitialRoute("openCompany")//设置为one
self.navigatonController?.present(vc, animated:true)

//flutter
void main() => runApp(MyApp(pageIndex:window.defaultRouteName));

class MyApp extends StatelessWidget {
  final String pageIndex;//接收到openCompany
  const MyApp({Key? key, required this.pageIndex}) : super(key:key);
  
  Widget build(BuildContext context){
    //根据pageIndex去加载页面
    return ...
  }
}

2.MethodChannel通信

//ios
let engine = FlutterEngine(name: "app")
var flutter : FlutterViewController? = nil

override func viewDidLoad(){
  engine.run()
  
  self.flutter = FlutterViewController(engine: self.engine, nibName: nil, bundle: nil)
}

override func touchesEnded(_ touches: Set<UITouch>, with event: UIEvent?) {
  if let __flutter = self.flutter {
    let channel = FlutterMethodChannel(name: "explorer", binaryMessenger: __flutter.binaryMessenger)
    self.present(__flutter, animated: true, completion: nil)

    channel.setMethodCallHandler { method, result in
       if(method.method == "exit"){
           NX.print(method.method)
       }
    }
    channel.invokeMethod("openCompany", arguments:nil);
  }
}

//flutter
void main() => runApp(MyApp());

class MyApp extends StatefullWidget {
  const MyApp({Key? key});
  MyAppState createState() => MyAppState()
}

class MyAppState extends State<MyApp> {
  const channel = MethodChannel("explorer");
  String pageIndex;//接收到openCompany
  
  void initState(){
    channel.setMethodCallHandler((call){
      pageIndex = call.method;//openCompany
      setState({});
    });
  }
  
  Widget build(BuildContext context){
    //根据pageIndex去加载页面
    
    //响应事件
    {
       channel.invokeMapMethod("exit", {});
    }
    
    return ...
  }
}

3.Channel

1.FlutterMethodChannel

传递方法的,方法调用(案例如上)

2.FlutterBasicMessageChannel

持续通信,收到消息后还可以恢复

//ios
let channel = FlutterBasicMessageChannel(name: "explorer", binaryMessenger: __flutter.binaryMessenger)
channel.setMessageHandler { value, reply in
  //收到来自flutter的消息
}
channel.sendMessage("----")//发送给flutter的消息



//flutter
BasicMessageChannel channel = BasicMessageChannel("explor", StandardmessageCodec());
channel.setMessageHandler((message){
      //来自App的消息
}); 
channel.send("-----")//发给App的消息

3.EventChannel

数据流

4.Flutter引擎源码

https://blog.csdn.net/dongzhong1990/article/details/105678124

源码主要分为两部分:

Flutter官方源码下载路径:

engine: https://github.com/flutter/engine

flutter framework: https://github.com/flutter/flutter

1.channel通信原理

1.1.MethodChannel通信

let channel = FlutterMethodChannel(name:"explorer", binaryMessenger: self.flutterViewController.binaryMessenger)

初始化方法:将如下三个信息保存起来

channel.setMethodCallHandler { method, result in
  if(method.method == "exit"){                
  }
}

设置消息回调:判断handler是否为空,来进行历史数据的清空和重新赋值。

channel.invokeMethod("openDetail", arguments: nil, result: {})

2.解码器

三种channel有2种解码器,解码器实际上是一种数据转换协议,iOS、Android、dart三端通用。

2.1.FlutterMessageCodec

@protocol FlutterMessageCodec
+ (instancetype)sharedInstance;
- (NSData * _Nullable)encode:(id _Nullable)message;
- (id _Nullable)decode:(NSData * _Nullable)message;
@end

2.2FlutterMethodCodec

服务Methodchannel、EventChannel

@protocol FlutterMethodCodec
+ (instancetype)sharedInstance;
- (NSData *)encodeMethodCall:(FlutterMethodCall *)methodCall;
- (NSData *)decodeMethodCall:(NSData *)methodCall;
- (NSData *)encodeSuccessEnvelope:(id _Nullable)result;
- (NSData *)encodeErrorEnvelope:(FlutterError *)error;
- (id _Nullanle)decodeEnvelope:(NSData *)envelope;
@end

2.3 FlutterStandardReaderWriter

- (nullable id)readValue {
  //
  [self readValueOfType:[self readByte]]
}

- (nullable id)readValueOfType:(UInt8)type{
  
}
- (void)writeValue:(id)value {
  //判断类型
  //写入标志位(数据类型)+数据本身
  [- writeByte:]
  [- writeBytes:- length:-]
}
上一篇 下一篇

猜你喜欢

热点阅读