国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

一統(tǒng)天下 flutter - 插件: flutter 使用 ios 原生控件,并做數(shù)據(jù)通信

這篇具有很好參考價值的文章主要介紹了一統(tǒng)天下 flutter - 插件: flutter 使用 ios 原生控件,并做數(shù)據(jù)通信。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

源碼 https://github.com/webabcd/flutter_demo
作者 webabcd

一統(tǒng)天下 flutter - 插件: flutter 使用 ios 原生控件,并做數(shù)據(jù)通信

示例如下:

lib\plugin\plugin2.dart

/*
 * 插件
 * 本例用于演示 flutter 使用 android/ios 原生控件,并做數(shù)據(jù)通信
 *
 * 一、android 插件開發(fā)
 * 1、主 flutter 項目要先在 android 平臺中運行一下
 * 2、在 android 文件夾上,使用右鍵菜單,然后選擇 Flutter -> Open Android module in Android Studio 即可開發(fā)插件
 * 3、參見 /android/app/src/main/kotlin/com/example/flutter_demo/MainActivity.kt
 *
 * 二、ios 插件開發(fā)
 * 1、主 flutter 項目要先在 ios 平臺中運行一下
 * 2、在 android studio 或 visual studio code 中執(zhí)行如下邏輯
 *    cd ios
 *    pod install
 * 3、用 xcode 中打開 /ios/Runner.xcworkspace 即可開發(fā)插件
 * 4、參見 /ios/Runner/AppDelegate.swift
 *
 *
 * 注:插件中實現(xiàn)的功能不支持 flutter 的 hot reload
 */

import 'dart:async';
import 'dart:io';

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

import '../helper.dart';

class Plugin2Demo extends StatefulWidget {
  const Plugin2Demo({Key? key}) : super(key: key);

  @override
  _Plugin2DemoState createState() => _Plugin2DemoState();
}

class _Plugin2DemoState extends State<Plugin2Demo> {

  @override
  Widget build(BuildContext context) {

    return Scaffold(
      appBar: AppBar(
        title: const Text('title'),
      ),
      body: const _MyWidget()
    );
  }
}


class _MyWidget extends StatefulWidget {
  const _MyWidget({Key? key}) : super(key: key);

  @override
  _MyWidgetState createState() => _MyWidgetState();
}

class _MyWidgetState extends State<_MyWidget> {

  /// 用于保存從 android/ios 發(fā)送到 flutter 的數(shù)據(jù)
  String _nativeToFlutterMessage = '';
  /// 用于控制 android/ios 和 flutter 通信的 controller
  final _controller = _MyViewController();

  @override
  void initState() {

    _controller.addListener(() {
      setState(() {
        _nativeToFlutterMessage = _controller.nativeToFlutterMessage;
      });
    });

    super.initState();
  }

  @override
  Widget build(BuildContext context) {
    return Column(
      crossAxisAlignment: CrossAxisAlignment.stretch,
      children: [
        Expanded(
          child: Container(
            color: Colors.red,
            child: _buildNativeView(),
          ),
        ),
        Expanded(
          child: Container(
            color: Colors.green,
            child: _buildFlutterView(),
          ),
        ),
      ],
    );
  }

  /// 嵌入到 flutter 中的 android/ios 的 view
  Widget _buildNativeView() {
    return _MyNativeView(
      controller: _controller,
    );
  }

  Widget _buildFlutterView() {
    return Stack(
      alignment: AlignmentDirectional.bottomCenter,
      children: [
        Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: [
            Text("native to flutter: $_nativeToFlutterMessage"),
            const SizedBox(height: 10),
            ElevatedButton(
              onPressed: () {
                _controller.flutterToNative("${DateTime.now().millisecondsSinceEpoch}");
              },
              child: const Text('發(fā)送數(shù)據(jù)給 Native'),
            ),
          ],
        ),
        const Padding(
          padding: EdgeInsets.only(bottom: 15),
          child: Text(
            'Flutter - View',
            style: TextStyle(
              fontSize: 24,
              fontWeight: FontWeight.bold,
            ),
          ),
        ),
      ],
    );
  }
}


/// 嵌入到 flutter 中的 android/ios 的 view
class _MyNativeView extends StatefulWidget {
  final _MyViewController controller;

  const _MyNativeView({required this.controller, Key? key}) : super(key: key);

  @override
  _MyNativeViewState createState() => _MyNativeViewState();
}

class _MyNativeViewState extends State<_MyNativeView> {

  @override
  Widget build(BuildContext context) {

    /// 判斷是否為 web 環(huán)境要用 kIsWeb
    /// 如果在 web 環(huán)境使用 Platform.xxx 的話會報錯的
    if (kIsWeb) {
      return const MyText("不支持 web 環(huán)境");
    }

    if (Platform.isAndroid) {
      /// 嵌入到 flutter 中的 android 的 view(相關(guān)的插件在 android/app/src/main/kotlin/com/example/flutter_demo/MyFlutterPlugin2.kt)
      return AndroidView(
        viewType: 'com.webabcd.flutter/myview',                           /// 需要嵌入的 view 的標識(這是在插件中定義的)
        onPlatformViewCreated: _onPlatformViewCreated,                    /// 傳給插件的初始參數(shù)
        creationParams: const <String, dynamic>{'k1': 'p1', 'k2': 'p2'},  /// 傳給插件的初始參數(shù)的編碼方式
        creationParamsCodec: const StandardMessageCodec(),                /// 需要嵌入的 view 創(chuàng)建后觸發(fā)的事件
      );
    }

    if (Platform.isIOS) {
      /// 嵌入到 flutter 中的 ios 的 view(相關(guān)的插件在 ios/Runner/MyFlutterPlugin2.swift)
      return UiKitView(
        viewType: 'com.webabcd.flutter/myview',                           /// 需要嵌入的 view 的標識(這是在插件中定義的)
        creationParams: const <String, dynamic>{'k1': 'p1', 'k2': 'p2'},  /// 傳給插件的初始參數(shù)
        creationParamsCodec: const StandardMessageCodec(),                /// 傳給插件的初始參數(shù)的編碼方式
        onPlatformViewCreated: _onPlatformViewCreated,                    /// 需要嵌入的 view 創(chuàng)建后觸發(fā)的事件
      );
    }

    return const MyText("不支持當前環(huán)境");
  }

  /// 對于 android 來說,這個 id 是插件中 PlatformViewFactory 的 create() 中生成的 viewId
  /// 對于 ios 來說,這個 id 是插件中 FlutterPlatformViewFactory 的 create() 中生成的 viewId
  void _onPlatformViewCreated(int id) {
    var methodChannel = MethodChannel('com.webabcd.flutter/channel2_view$id');
    widget.controller.setMethodChannel(methodChannel);
  }
}

/// 用于控制 android/ios 和 flutter 通信的 controller
class _MyViewController extends ChangeNotifier {

  late MethodChannel _methodChannel;

  String nativeToFlutterMessage = "";

  /// 接收從 android/ios 發(fā)送到 flutter 的數(shù)據(jù)
  void setMethodChannel(MethodChannel methodChannel) {
    _methodChannel = methodChannel;
    _methodChannel.setMethodCallHandler((call) async {
      switch (call.method) {
        case 'nativeToFlutter':
          final result = call.arguments as String;
          nativeToFlutterMessage = result;
          notifyListeners();
          break;
      }
    });
  }

  /// 從 flutter 發(fā)送數(shù)據(jù)到 android/ios
  Future<void> flutterToNative(String message) async {
    await _methodChannel.invokeMethod('flutterToNative', message);
  }
}

ios\Runner\AppDelegate.swift

/*
 * 本例用于演示 ios 插件的開發(fā)
 */

import UIKit
import Flutter

@UIApplicationMain
@objc class AppDelegate: FlutterAppDelegate
{
    override func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions:[UIApplication.LaunchOptionsKey: Any]?) -> Bool
    {
        // 用于為某個插件提供服務(wù)
        let registrar1: FlutterPluginRegistrar = self.registrar(forPlugin: "com.webabcd.flutter/plugin1")!
        let registrar2: FlutterPluginRegistrar = self.registrar(forPlugin: "com.webabcd.flutter/plugin2")!
        
        // 注冊自定義插件,用于演示 flutter 與 ios 原生之間的數(shù)據(jù)通信
        MyFlutterPlugin1.register(with: registrar1)
        
        // 注冊自定義插件,用于演示 flutter 使用 ios 原生控件,并做數(shù)據(jù)通信
        MyFlutterPlugin2.register(with: registrar2)
        
        GeneratedPluginRegistrant.register(with: self)
        
        return super.application(application, didFinishLaunchingWithOptions: launchOptions)
    }
}

ios\Runner\MyFlutterPlugin2.swift

/*
 * 自定義插件,用于演示 flutter 使用 ios 原生控件,并做數(shù)據(jù)通信
 */

import UIKit
import Flutter

// 自定義插件
class MyFlutterPlugin2: NSObject, FlutterPlugin
{
    static func register(with registrar: FlutterPluginRegistrar)
    {
        let binaryMessenger = registrar.messenger() // binaryMessenger 用于后續(xù)通過 FlutterMethodChannel 傳輸二進制數(shù)據(jù)
        
        let factory = MyFlutterPlatformViewFactory(binaryMessenger: binaryMessenger)
        registrar.register(factory, withId: "com.webabcd.flutter/myview") // 指定 view 的標識,在 flutter 中通過此標識使用這個 view
    }
}

// 自定義 FlutterPlatformViewFactory 用于創(chuàng)建一個 FlutterPlatformView
class MyFlutterPlatformViewFactory: NSObject,FlutterPlatformViewFactory {
    
    var binaryMessenger: FlutterBinaryMessenger?
    
    init(binaryMessenger: FlutterBinaryMessenger)
    {
        super.init()
        
        self.binaryMessenger = binaryMessenger
    }
    
    // viewId - 創(chuàng)建的 view 實例的 id(當這個 view 創(chuàng)建成功后,回調(diào) UiKitView 的 onPlatformViewCreated 時,會把這個 viewId 傳遞過去)
    // args - 在 flutter 中通過 UiKitView 的 creationParams 傳遞過來的初始參數(shù)
    func create(withFrame frame: CGRect, viewIdentifier viewId: Int64, arguments args: Any?) -> FlutterPlatformView
    {
        return MyFlutterPlatformView(frame, viewId: viewId, args: args, binaryMessenger: self.binaryMessenger!)
    }
    
    // 初始參數(shù)的編碼方式,要與 UiKitView 的 creationParamsCodec 一致
    func createArgsCodec() -> FlutterMessageCodec & NSObjectProtocol
    {
        return FlutterStandardMessageCodec.sharedInstance()
    }
}

// 自定義 FlutterPlatformView 用于將指定的 ios 中的 view 嵌入到 flutter 中
class MyFlutterPlatformView: NSObject, FlutterPlatformView {
    
    // 需要嵌入到 flutter 中的 ios 的 view
    var _myView: MyView?
    // 用于 flutter 與 ios 之間的通信
    var _methodChannel: FlutterMethodChannel?
    
    init(_ frame: CGRect, viewId: Int64, args :Any?, binaryMessenger: FlutterBinaryMessenger)
    {
        super.init()
        
        _myView = MyView()
        _myView!.frame = frame
        
        // 獲取在 flutter 中通過 UiKitView 的 creationParams 傳遞過來的初始參數(shù)
        if let dict = args as? NSDictionary
        {
            _myView!.showMessage(message: "flutter 創(chuàng)建 UiKitView 時的初始參數(shù) k1:\(dict.value(forKey: "k1") as! String), k2:\(dict.value(forKey: "k2") as! String)")
        }

        // 創(chuàng)建一個 FlutterMethodChannel 并指定其名稱,它用于 flutter 和 ios 插件之間的通信(在 flutter 中通過名稱獲取此 channel 后就可以通信了)
        // binaryMessenger 的意思是這個 FlutterMethodChannel 用于傳輸二進制數(shù)據(jù)
        _methodChannel = FlutterMethodChannel(name: "com.webabcd.flutter/channel2_view\(viewId)", binaryMessenger: binaryMessenger)
        // flutter 調(diào)用 ios 插件中的方法時,會執(zhí)行到這里(更詳細的說明請參見 MyFlutterPlugin1.swift)
        _methodChannel!.setMethodCallHandler { (call:FlutterMethodCall, result:@escaping FlutterResult) in
          
            let method = call.method
            
            if (method == "flutterToNative")
            {
                let message = call.arguments as! String
                self._myView!.showMessage(message: "flutter to ios: \(message)")
                result(true)
            }
        }
        
        _myView!.setIosToFlutterHandler { message in
            // 通過 FlutterMethodChannel 從 ios 發(fā)送數(shù)據(jù)到 flutter
            self._methodChannel!.invokeMethod("nativeToFlutter", arguments: message)
        }
    }
    
    // 返回需要嵌入到 flutter 中的 ios 的 view
    func view() -> UIView {
        return _myView!
    }
}

ios\Runner\MyView.swift

/*
 * 本例的 view 用于顯示在 flutter 中
 */

import Foundation

class MyView : UIView
{
    var textViewBottom = UITextView()
    var textView = UITextView()
    var button = UIButton(type: .custom)
    
    required init?(coder: NSCoder)
    {
        super.init(coder:coder);
    }

    override init(frame: CGRect)
    {
        super.init(frame: frame);
        
        self.textView.font = UIFont.systemFont(ofSize: 14)
        self.textView.textColor = .black
        self.textView.backgroundColor = .clear
        self.textView.textAlignment = .center
        self.textView.isEditable = false
        self.addSubview(self.textView)
        
        self.button.setTitle("發(fā)送數(shù)據(jù)給 flutter", for: .normal)
        self.button.backgroundColor = .blue
        self.button.layer.cornerRadius = 10
        self.button.titleLabel?.font = UIFont.systemFont(ofSize: 14)
        self.button.titleLabel?.textColor = .white
        self.button.addTarget(self, action: #selector(buttonPressed), for: .touchUpInside)
        self.addSubview(self.button)
        
        self.textViewBottom.font = UIFont.boldSystemFont(ofSize: 24)
        self.textViewBottom.textColor = .black
        self.textViewBottom.backgroundColor = .clear
        self.textViewBottom.textAlignment = .center
        self.textViewBottom.isEditable = false
        self.textViewBottom.text = "iOS - View"
        self.addSubview(self.textViewBottom)
    }
    
    override func layoutSubviews()
    {
        super.layoutSubviews()
        
        self.button.frame = CGRect(x: (self.bounds.width - 200) / 2, y: self.bounds.height / 2, width: 200, height: 30)
        self.textView.frame = CGRect(x: 0, y: self.bounds.height / 4, width: self.bounds.width, height: 30)
        self.textViewBottom.frame = CGRect(x: 0, y: self.bounds.height - 60, width: self.bounds.width, height: 40)
    }
    
    // 用于顯示 flutter 發(fā)送到 ios 的數(shù)據(jù)
    func showMessage(message: String)
    {
        self.textView.text = message
    }
    
    @objc func buttonPressed()
    {
        // 用于從 ios 發(fā)送數(shù)據(jù)到 flutter
        self.iosToFlutter("\(Int(Date().timeIntervalSince1970 * 1000))")
    }
    
    private var iosToFlutter:(_ message: String) -> () = { p in }
    func setIosToFlutterHandler(iosToFlutter: @escaping ((_ message: String) -> ()))
    {
        self.iosToFlutter = iosToFlutter
    }
}

源碼 https://github.com/webabcd/flutter_demo
作者 webabcd文章來源地址http://www.zghlxwxcb.cn/news/detail-438681.html

到了這里,關(guān)于一統(tǒng)天下 flutter - 插件: flutter 使用 ios 原生控件,并做數(shù)據(jù)通信的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔相關(guān)法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • flutter實現(xiàn)調(diào)用原生安卓的高德地圖導(dǎo)航功能(插件化)

    flutter實現(xiàn)調(diào)用原生安卓的高德地圖導(dǎo)航功能(插件化)

    查看了高德地圖flutter插件的文檔,都沒有能支持導(dǎo)航的功能,并且flutter的高德插件支持的功能特別少,沒辦法,只能使用安卓原生的導(dǎo)航,flutter去調(diào)用了,具體實現(xiàn)方式如下: 創(chuàng)建 Flutter 插件 使用--template=plugin 聲明創(chuàng)建的是同時包含了 iOS 和 Android 代碼的 plugin; 使用--o

    2024年02月16日
    瀏覽(20)
  • uniapp ios原生插件開發(fā)之module

    在文章《uniapp ios原生插件開發(fā) (framework,cocoapods)》中我們已經(jīng)介紹了Module 類型的插件及其創(chuàng)建過程, 卻沒有深入的介紹Module類型插件開發(fā)過程中所涉及到的技術(shù)點。 本文呢就將重點放在對這些技術(shù)點的使用上進行詳解,算是是對上篇文章的一個補充與擴展。 在文章開始之前

    2024年02月13日
    瀏覽(23)
  • Flutter iOS 集成使用 flutter boost

    Flutter iOS 集成使用 flutter boost

    在 Flutter項目中集成完 flutter boost,并且已經(jīng)使用了 flutter boost進行了路由管理,這時如果需要和iOS混合開發(fā),這時就要到 原生端進行集成。 注意:之前建的項目必須是 Flutter module 項目,并且原生項目和flutter module項目在同一個文件夾下面 下面是原生端集成 flutter boost的步驟

    2024年02月13日
    瀏覽(52)
  • flutter使用Chanel與原生通信

    在Flutter中,Platform Channel允許Flutter與原生平臺(如Android和iOS)之間進行雙向通信,以便在Flutter應(yīng)用程序和原生代碼之間傳遞消息和調(diào)用功能。 以下是使用Platform Channel與原生通信的一般步驟: 1. 在Flutter端創(chuàng)建一個MethodChannel對象,用于發(fā)送消息給原生平臺。通常在Flutter Wid

    2024年02月11日
    瀏覽(21)
  • flutter和android互相調(diào)用、android原生項目與flutter module之間的交互、如何在flutter module中使用原生的方法

    bridge.dart MainActivity.kt MainActivity中 Flutter中 android項目依賴flutter module的方式網(wǎng)上有很多,這里就不做講解。主要說一下這種情況下android如何與flutter module之間進行方法的調(diào)用 踩坑:期初我是想讓flutter module調(diào)用它內(nèi)部中的.android文件夾下的原生代碼。.android文件夾下有Flutter、

    2023年04月08日
    瀏覽(20)
  • Flutter iOS 集成使用 fluter boost

    Flutter iOS 集成使用 fluter boost

    在 Flutter項目中集成完 flutter boost,并且已經(jīng)使用了 flutter boost進行了路由管理,這時如果需要和iOS混合開發(fā),這時就要到 原生端進行集成。 注意:之前建的項目必須是 Flutter module 項目,并且原生項目和flutter module項目在同一個文件夾下面 下面是原生端集成 flutter boost的步驟

    2024年02月14日
    瀏覽(27)
  • flutter開發(fā)實戰(zhàn)-webview插件flutter_inappwebview使用

    flutter開發(fā)實戰(zhàn)-webview插件flutter_inappwebview使用

    flutter開發(fā)實戰(zhàn)-webview插件flutter_inappwebview使用 在開發(fā)過程中,經(jīng)常遇到需要使用WebView,Webview需要調(diào)用原生的插件來實現(xiàn)。常見的flutter的webview插件是webview_flutter,flutter_inappwebview。之前整理了一下webview_flutter,查看https://blog.csdn.net/gloryFlow/article/details/131683122 這里我們使用fl

    2024年02月07日
    瀏覽(25)
  • 如何在 macOS 上同時使用 Flutter2 和 Flutter3 進行 ios 開發(fā)

    如何在 macOS 上同時使用 Flutter2 和 Flutter3 進行 ios 開發(fā)

    貓哥主打系統(tǒng)環(huán)境是: macos flutter 3.7.12 ruby 3.2.2 cocoapods 1.12.1 xcode 14.3.1 這套配置運行最新的項目沒問題,但是最近需要維護 flutter 2.10.5 這種老項目,雖然用了 fvm 進行 flutter 版本切換,但是 flutter 2.10.5 用的 ruby 2 ,我當前是 ruby 3 所以運行 pod install 的時候就報錯了。 這個錯誤

    2024年02月12日
    瀏覽(28)
  • uniapp使用原生小程序插件

    uniapp使用原生小程序插件

    ? ? ? ? 本文主要講述在uniapp上使用原生插件步驟 1、在使用插件之前,先登錄微信公眾平臺,在微信公眾平臺,點擊左下角設(shè)置==》第三方設(shè)置==》添加插件==》輸入插件名字==》點擊確定提交申請==》申請通過后可以使用該插件 第一步 ? ?2.搜索你需要的插件點擊添加 ? ?

    2024年02月08日
    瀏覽(17)
  • flutter開發(fā) - 七牛云上傳sdk插件qiniu_flutter_sdk使用

    flutter開發(fā) - 七牛云上傳sdk插件qiniu_flutter_sdk使用

    flutter七牛云上傳sdk插件qiniu_flutter_sdk使用 最近在拆分代碼,將上傳組件設(shè)置成插件,下面記錄下實現(xiàn)過程。 一、創(chuàng)建flutter_plugin上傳插件 這里Android Studio使用創(chuàng)建plugin 填寫一下信息 Project name Project location Description Project type Organization Android Language iOS Language Platforms 二、代碼實

    2024年02月10日
    瀏覽(26)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包