Flutter开发之——IOS通信MethodChannel(1)

import Flutter

import UIKit

public class MethodChannelDemo {

init(messenger: FlutterBinaryMessenger) {

let channel = FlutterMethodChannel(name: “com.example.flutterios.MethodChannel”, binaryMessenger: messenger)

channel.setMethodCallHandler { (call:FlutterMethodCall, result:@escaping FlutterResult) in

if (call.method == “sendData”) {

if let dict = call.arguments as? Dictionary<String, Any> {

let name:String = dict[“name”] as? String ?? “”

let age:Int = dict[“age”] as? Int ?? -1

result([“name”:“hello,(name)”,“age”:age])

}

}

}

}

}

2.3 在AppDelegate设置MethodChannelDemo

import UIKit

import Flutter

@UIApplicationMain

@objc class AppDelegate: FlutterAppDelegate {

override func application(

_ application: UIApplication,

didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?

) -> Bool {

GeneratedPluginRegistrant.register(with: self)

let controller : FlutterViewController = window?.rootViewController as! FlutterViewController

MethodChannelDemo(messenger: controller.binaryMessenger)

GeneratedPluginRegistrant.register(with: self)

return super.application(application, didFinishLaunchingWithOptions: launchOptions)

}

}

2.4 效果图

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

三 iOS 端向Flutter主动发送数据-定时器


3.1 创建Flutter端MethodChannel

import ‘package:flutter/foundation.dart’;

import ‘package:flutter/material.dart’;

import ‘package:flutter/services.dart’;

void main() {

runApp(MethodChannelDemo());

}

class MethodChannelDemo extends StatefulWidget {

@override

_MethodChannelDemoState createState() => _MethodChannelDemoState();

}

class _MethodChannelDemoState extends State {

var channel = MethodChannel(‘com.example.flutterios.MethodChannel’);

var _data;

var _nativeData;

@override

void initState() {

channel.setMethodCallHandler((call)async{

setState(() {

_nativeData = call.arguments[‘count’];

});

});

}

@override

Widget build(BuildContext context) {

return MaterialApp(

home: Scaffold(

appBar: AppBar(title: Text(“IOS-MethodChannelDemo”)),

body: Column(

children: [

SizedBox(height: 50,),

RaisedButton(

child: Text(‘发送数据到原生’),

onPressed: () async {

var result = await channel

.invokeMethod(‘sendData’, {‘name’: ‘张三’, ‘age’: 18});

var name = result[‘name’];

var age = result[‘age’];

setState(() {

_data = ‘ n a m e , name, name,age’;

});

},

),

Text(‘原生返回数据:$_data’),

Text(‘原生主动发送数据:$_nativeData’)

],

),

),

);

}

}

3.2 创建IOS端MethodChannelDemo

import Flutter

import UIKit

public class MethodChannelDemo {

var count = 0

var channel:FlutterMethodChannel

init(messenger: FlutterBinaryMessenger) {

channel = FlutterMethodChannel(name: “com.example.flutterios.MethodChannel”, binaryMessenger: messenger)

channel.setMethodCallHandler { (call:FlutterMethodCall, result:@escaping FlutterResult) in

if (call.method == “sendData”) {

if let dict = call.arguments as? Dictionary<String, Any> {

let name:String = dict[“name”] as? String ?? “”

let age:Int = dict[“age”] as? Int ?? -1

result([“name”:“hello,(name)”,“age”:age])

}

}

}

startTimer()

}

func startTimer() {

var timer = Timer.scheduledTimer(timeInterval:1, target: self, selector:#selector(self.tickDown),userInfo:nil,repeats: true)

}

@objc func tickDown(){

count += 1

var args = [“count”:count]

channel.invokeMethod(“timer”, arguments:args)

}

}

3.3 在合适的地方调用MethodChannel

import UIKit

import Flutter

@UIApplicationMain

@objc class AppDelegate: FlutterAppDelegate {

override func application(

_ application: UIApplication,

didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?

) -> Bool {

GeneratedPluginRegistrant.register(with: self)

let controller : FlutterViewController = window?.rootViewController as! FlutterViewController

最后

对于程序员来说,要学习的知识内容、技术有太多太多,要想不被环境淘汰就只有不断提升自己,从来都是我们去适应环境,而不是环境来适应我们!

最后,我再重复一次,如果你想成为一个优秀的 Android 开发人员,请集中精力,对基础和重要的事情做深度研究

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。

以下是今天给大家分享的一些独家干货:

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
习效果低效漫长且无助**。整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。

以下是今天给大家分享的一些独家干货:

[外链图片转存中…(img-oK4opSoJ-1714871751519)]

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

  • 9
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
FlutterMethodChannel是一种在Flutter和原生平台(如iOS)之间进行通信的机制。它允许Flutter应用程序调用原生平台上的方法,并且还可以让原生平台调用Flutter的方法。 在iOS上使用MethodChannel,首先需要在原生平台(Objective-C或Swift)的代码中创建一个MethodChannel实例。这个实例需要一个唯一的通道名称,以便Flutter可以识别它。然后,可以使用该MethodChannel实例来注册方法,并指定一个方法名称和一个回调函数来处理该方法被调用时的逻辑。 在Flutter应用程序中,可以使用MethodChannel的实例来调用原生平台上注册的方法。可以指定方法名称和传递参数(如果需要)。MethodChannel会将这个方法调用发送到原生平台,并等待原生平台返回结果。一旦结果返回,可以在Flutter端处理它。 使用MethodChannel时需要注意一些事项。首先,MethodChannel只能传递符合平台限制的数据类型,如字符串、数字、布尔值等。如果需要传递复杂的数据结构,可以将数据转换为平台能够识别的格式(如JSON),然后再进行传递。其次,MethodChannel是一种异步通信机制,所以在处理方法调用时需要考虑异步操作和结果处理的情况。 总的来说,FlutterMethodChannel是一种强大而灵活的机制,可以实现Flutter应用程序与原生平台之间的双向通信。它为开发人员提供了在FlutteriOS之间传递方法调用和数据的能力,可以实现更高级的功能和交互体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值