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

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

MethodChannelDemo(messenger: controller.binaryMessenger)

最后

简历首选内推方式,速度快,效率高啊!然后可以在拉钩,boss,脉脉,大街上看看。简历上写道熟悉什么技术就一定要去熟悉它,不然被问到不会很尴尬!做过什么项目,即使项目体量不大,但也一定要熟悉实现原理!不是你负责的部分,也可以看看同事是怎么实现的,换你来做你会怎么做?做过什么,会什么是广度问题,取决于项目内容。但做过什么,达到怎样一个境界,这是深度问题,和个人学习能力和解决问题的态度有关了。大公司看深度,小公司看广度。大公司面试你会的,小公司面试他们用到的你会不会,也就是岗位匹配度。

面试过程一定要有礼貌!即使你觉得面试官不尊重你,经常打断你的讲解,或者你觉得他不如你,问的问题缺乏专业水平,你也一定要尊重他,谁叫现在是他选择你,等你拿到offer后就是你选择他了。

另外,描述问题一定要慢!不要一下子讲一大堆,慢显得你沉稳、自信,而且你还有时间反应思路接下来怎么讲更好。现在开发过多依赖ide,所以会有个弊端,当我们在面试讲解很容易不知道某个方法怎么读,这是一个硬伤…所以一定要对常见的关键性的类名、方法名、关键字读准,有些面试官不耐烦会说“你到底说的是哪个?”这时我们会容易乱了阵脚。正确的发音+沉稳的描述+好听的嗓音决对是一个加分项!

最重要的是心态!心态!心态!重要事情说三遍!面试时间很短,在短时间内对方要摸清你的底子还是比较不现实的,所以,有时也是看眼缘,这还是个看脸的时代。

希望大家都能找到合适自己满意的工作!

进阶学习视频

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)


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

[外链图片转存中…(img-aZzPxjdI-1714844840690)]

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题 (含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

[外链图片转存中…(img-Tk5KvJl2-1714844840692)]
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值