栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Flutter开发之——IOSView,安卓开发自学教程

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Flutter开发之——IOSView,安卓开发自学教程

import Foundation

import Flutter

class MyFlutterViewFactory: NSObject,FlutterPlatformViewFactory {

var messenger:FlutterBinaryMessenger

init(messenger:FlutterBinaryMessenger) {

self.messenger = messenger

super.init()

}

func create(withframe frame: CGRect, viewIdentifier viewId: Int64, arguments args: Any?) -> FlutterPlatformView {

return MyFlutterView(frame,viewID: viewId,args: args,messenger: messenger)

}

func createArgsCodec() -> FlutterMessageCodec & NSObjectProtocol {

return FlutterStandardMessageCodec.sharedInstance()

}

}

3.4 在 AppDelegate 中注册

import UIKit

import Flutter

@UIApplicationMain

@objc class AppDelegate: FlutterAppDelegate {

override func application(

_ application: UIApplication,

didFinishLaunchingW

《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》

开源分享完整内容戳这里

ithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?

) -> Bool {

GeneratedPluginRegistrant.register(with: self)

let registrar:FlutterPluginRegistrar = self.registrar(forPlugin: “plugins.flutter.io/custom_platform_view_plugin”)!

let factory = MyFlutterViewFactory(messenger: registrar.messenger())

registrar.register(factory, withId: “plugins.flutter.io/custom_platform_view”)

return super.application(application, didFinishLaunchingWithOptions: launchOptions)

}

}

说明:

  • plugins.flutter.io/custom_platform_view ,这个字符串在 Flutter 中需要与其保持一致
3.5 编辑Flutter页面

在Intellij页面中编辑main.dart

import ‘package:flutter/foundation.dart’;

import ‘package:flutter/material.dart’;

void main() {

runApp(PlatformViewDemo());

}

class PlatformViewDemo extends StatelessWidget {

@override

Widget build(BuildContext context) {

Widget? platformView() {

if (defaultTargetPlatform == TargetPlatform.android) {

return AndroidView(

viewType: ‘plugins.flutter.io/custom_platform_view’,

);

} else if (defaultTargetPlatform == TargetPlatform.iOS) {

return UiKitView(

viewType: ‘plugins.flutter.io/custom_platform_view’,

);

}

}

return MaterialApp(

home: Scaffold(

appBar: AppBar(

title: Text(“Platform”),

),

body: Center(

child: platformView(),

),

),

);

}

}

3.6 效果图

四 Flutter中嵌入IOS自定义View时设置初始化参数


4.1 Flutter 端修改如下

UiKitView(

viewType: ‘plugins.flutter.io/custom_platform_view’,

creationParams: {‘text’: ‘Flutter传给IOSTextView的参数’},

creationParamsCodec: StandardMessageCodec(),

)

  • creationParams :传递的参数,插件可以将此参数传递给 AndroidView 的构造函数。

  • creationParamsCodec :将 creationParams 编码后再发送给平台侧,它应该与传递给构造函数的编解码器匹配。值的范围

  • StandardMessageCodec

  • JSONMessageCodec

  • StringCodec

  • BinaryCodec

4.2 IOS自定义View接受参数

import Foundation

import Flutter

class MyFlutterView: NSObject,FlutterPlatformView {

let label = UILabel()

init(_ frame: CGRect,viewID: Int64,args :Any?,messenger :FlutterBinaryMessenger) {

super.init()

if(args is NSDictionary){

let dict = args as! NSDictionary

label.text = dict.value(forKey: “text”) as! String

}

}

func view() -> UIView {

return label

}

}

4.3 效果图

五 Flutter 向 iOS View 发送消息


5.1 Flutter 端,创建 MethodChannel 用于通信(Intellij端修改)

import ‘package:flutter/foundation.dart’;

import ‘package:flutter/material.dart’;

import ‘package:flutter/services.dart’;

void main() {

runApp(PlatformViewDemo());

}

class PlatformViewDemo extends StatefulWidget {

@override

_PlatformViewDemoState createState() => _PlatformViewDemoState();

}

class _PlatformViewDemoState extends State {

static const platform =

const MethodChannel(‘com.example.flutterios.MyFlutterView’);

@override

Widget build(BuildContext context) {

Widget? platformView() {

if (defaultTargetPlatform == TargetPlatform.android) {

return AndroidView(

viewType: ‘plugins.flutter.io/custom_platform_view’,

creationParams: {‘text’: ‘Flutter传给AndroidTextView的参数’},

creationParamsCodec: StandardMessageCodec(),

);

} else if (defaultTargetPlatform == TargetPlatform.iOS) {

return UiKitView(

viewType: ‘plugins.flutter.io/custom_platform_view’,

creationParams: {‘text’: ‘Flutter传给IOSTextView的参数’},

creationParamsCodec: StandardMessageCodec(),

);

}

}

return MaterialApp(

home: Scaffold(

appBar: AppBar(),

body: Column(children: [

RaisedButton(

child: Text(‘传递参数给原生View’),

onPressed: () {

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

},

),

Expanded(child: Center(child: platformView())),

]),

),

);

}

}

说明:

  • com.example.flutterios.MyFlutterView:是IOS端端自定义View路径,与IOS端MethodChannel端保持一致
5.2 IOS原生View 中也创建一个 MethodChannel 用于通信(Xcode)

body: Column(children: [

RaisedButton(

child: Text(‘传递参数给原生View’),

onPressed: () {

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

},

),

Expanded(child: Center(child: platformView())),

]),

),

);

}

}

说明:

  • com.example.flutterios.MyFlutterView:是IOS端端自定义View路径,与IOS端MethodChannel端保持一致
5.2 IOS原生View 中也创建一个 MethodChannel 用于通信(Xcode)
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/572864.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号