Flutter与iOS原生混合开发

简介: Flutter与iOS原生混合开发

一、Flutter工程创建

Flutter有四种工程类型:

  • Flutter Application:Flutter应用
  • Flutter Module :Flutter与原生混合开发
  • Flutter Plugin:Flutter插件
  • Flutter Package:纯Dart组件

原生与混合开发需要创建Flutter Module工程;

1. Android Studio创建方式,Project type选择Module:

2. 命令行创建方式:

flutter create -t module --org com.example 工程名称

二、Xcode工程创建

直接创建Xcode App项目即可(文件夹最好和fluuter module项目文件夹路径保持一致,否则需要修改相对路径)

三、混合开发工程配置

主要是在已有原生iOS工程项目中,集成Flutter功能模块

方式一

利用Cocoapods导入Flutter项目功能模块(开发者必须配置Flutter开发环境

1. 初始化Pods

pod init

2. Podfile中新增如下(注意路径问题)

# Uncomment the next line to define a global platform for your project
platform :ios, '11.0'
flutter_application_path = '../fluttermodule'
load File.join(flutter_application_path, '.ios', 'Flutter', 'podhelper.rb')
target 'NativeOCTest' do
  install_all_flutter_pods(flutter_application_path)
  use_frameworks!
end
post_install do |installer|
  flutter_post_install(installer) if defined?(flutter_post_install)
end

3.开Xcode工程,使用如下代码调起Flutter页面,运行即可;

#import "ViewController.h"
#import <Flutter/Flutter.h>
@interface ViewController ()
@property(strong, nonatomic) FlutterViewController *flutterVC;
@property(strong, nonatomic) FlutterEngine *flutterEngine;
@end
@implementation ViewController
- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
}
- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
    [self test];
}
- (void)test {
    self.flutterVC.modalPresentationStyle = UIModalPresentationFullScreen;
    [self presentViewController:self.flutterVC animated:YES completion:nil];
}
- (FlutterEngine *)flutterEngine {
    if (!_flutterEngine) {
        FlutterEngine *engine = [[FlutterEngine alloc] init];
        if (engine.run) {
            _flutterEngine = engine;
        }
    }
    return _flutterEngine;
}
- (FlutterViewController *)flutterVC {
    if (!_flutterVC) {
        _flutterVC = [[FlutterViewController alloc] initWithEngine:self.flutterEngine nibName:nil bundle:nil];
    }
    return _flutterVC;
}
@end

方式二:

利用framework集成到原生工程里面(原生开发工程师无需配置Flutter环境1. 进入到Flutter module项目工程所在文件夹、执行以下命令:

flutter build ios-framework --output=../flutter_export

2. 在Flutter工程目录下会生成如下文件夹以及framework

3. 打开Xcode工程,选中Targets -> General -> Frameworks,Libraries,and Embedded Content,点击+号,然后点击Add Other -> Add Files,选中添加App.xcframework和Flutter.xcframework4. 添加上述调起Flutter的代码即可正常运行;

方式三:

利用Cocoapods集成到原生工程里面(原生开发工程师无需配置Flutter环境

1. 进入到Flutter module项目工程所在文件夹、执行以下命令:

flutter build ios-framework --cocoapods --output=../flutter_export

2. 在Flutter工程目录下会生成如下文件夹以及framework(与方式二的区别是没有了Flutter.xcframework)3. 原生工程中集成Pods环境

platform :ios, '11.0'
target 'NativeOC' do
  use_frameworks!
  pod 'Flutter', :podspec => '../flutter_export/Debug/Flutter.podspec'
end

4. 打开Xcode工程,选中Targets -> General -> Frameworks,Libraries,and Embedded Content,点击+号,然后点击Add Other -> Add Files,选中添加App.xcframework

5. 添加上述调起Flutter代码即可正常运行;

方式四:

利用git自动化构建CI原生开发工程师无需配置Flutter环境

1. 新建git远程代码仓库并把原生代码和Flutter代码上传上去当前文件夹结构:2. 点击Actions

3. 创建Action

自动化脚本相关代码

name: FlutterAction
on: [push]
jobs:
  check:
    name: Test on ${{ matrix.os }}
    runs-on: macos-latest
    steps:
      - uses: actions/checkout@v3
      - uses: subosito/flutter-action@v2
        with:
          flutter-version: '3.7.6'  
          channel: 'stable'
      - run: cd fluttermodule && flutter build ios-framework --cocoapods --output=../NativeOC/Flutter
      - run: |
         git add .
         git commit -m 'build flutter action framework' 
      - name: Push changes
        uses: ad-m/github-push-action@master
        with:
          github_token: ${{ secrets.GITHUB_TOKEN }}

注意仓库的设置,否则会提示没有权限

执行状态

运行成功Actions状态改变git仓库中出现了一个Flutter文件夹

4. 拉取代码,并配置Pod内容,同方式三,注意路径问题

platform :ios, '11.0'
target 'NativeOC' do
  use_frameworks!
  pod 'Flutter', :podspec => 'Flutter/Debug/Flutter.podspec'
end

目录结构

5. 添加上述调起Flutter的代码即可正常运行,后续只需push代码即可同步更新Flutter内容;

相关文章
|
7天前
|
IDE 开发工具 Android开发
安卓与iOS开发对比:平台选择对项目成功的影响
【9月更文挑战第10天】在移动应用开发的世界中,选择正确的平台是至关重要的。本文将深入探讨安卓和iOS这两大主要移动操作系统的开发环境,通过比较它们的市场份额、开发工具、编程语言和用户群体等方面,为开发者提供一个清晰的指南。我们将分析这两个平台的优势和劣势,并讨论如何根据项目需求和目标受众来做出最佳选择。无论你是初学者还是有经验的开发者,这篇文章都将帮助你更好地理解每个平台的特性,并指导你做出明智的决策。
|
5天前
|
JSON Dart Java
flutter开发多端平台应用的探索
flutter开发多端平台应用的探索
20 6
|
5天前
|
JSON Dart Java
flutter开发多端平台应用的探索 下 (跨模块、跨语言通信之平台通道)
flutter开发多端平台应用的探索 下 (跨模块、跨语言通信之平台通道)
|
5天前
|
API Android开发 iOS开发
安卓与iOS开发中的线程管理对比
【9月更文挑战第12天】在移动应用的世界中,安卓和iOS平台各自拥有庞大的用户群体。开发者们在这两个平台上构建应用时,线程管理是他们必须面对的关键挑战之一。本文将深入探讨两大平台在线程管理方面的异同,通过直观的代码示例,揭示它们各自的设计理念和实现方式,帮助读者更好地理解如何在安卓与iOS开发中高效地处理多线程任务。
|
7天前
|
开发框架 Android开发 iOS开发
探索安卓与iOS开发的差异:构建未来应用的指南
在移动应用开发的广阔天地中,安卓与iOS两大平台各占半壁江山。本文将深入浅出地对比这两大操作系统的开发环境、工具和用户体验设计,揭示它们在编程语言、开发工具以及市场定位上的根本差异。我们将从开发者的视角出发,逐步剖析如何根据项目需求和目标受众选择适合的平台,同时探讨跨平台开发框架的利与弊,为那些立志于打造下一个热门应用的开发者提供一份实用的指南。
19 5
|
7天前
|
开发工具 Android开发 iOS开发
安卓与iOS开发:平台选择的艺术与科学
在移动应用开发的广阔天地中,安卓与iOS两大平台如同东西方哲学的碰撞,既有共通之处又各具特色。本文将深入探讨这两个平台的设计理念、开发工具和市场定位,旨在为开发者提供一份简明扼要的指南,帮助他们在这场技术与商业的博弈中找到自己的道路。通过比较分析,我们将揭示每个平台的优势与局限,以及它们如何影响应用的性能、用户体验和市场接受度。无论你是初涉江湖的新手,还是经验丰富的老手,这篇文章都将为你的选择提供新的视角和思考。
18 5
|
8天前
|
安全 Android开发 开发者
探索安卓开发的未来:Kotlin的崛起与Flutter的挑战
在移动开发的广阔天地中,安卓平台始终占据着举足轻重的地位。随着技术的不断进步和开发者需求的多样化,Kotlin和Flutter成为了改变游戏规则的新玩家。本文将深入探讨Kotlin如何以其现代化的特性赢得开发者的青睐,以及Flutter凭借跨平台的能力如何挑战传统的安卓开发模式。通过实际案例分析,我们将揭示这两种技术如何塑造未来的安卓应用开发。
27 6
|
7天前
|
开发工具 Android开发 Swift
探索安卓与iOS开发的差异:从新手到专家的旅程
在数字时代的浪潮中,移动应用开发已成为连接世界的桥梁。本文将深入探讨安卓与iOS这两大主流平台的开发差异,带领读者从零基础出发,逐步了解各自的特点、开发环境、编程语言及市场策略。无论你是梦想成为移动应用开发者的初学者,还是希望扩展技能边界的资深开发者,这篇文章都将为你提供宝贵的见解和实用的建议。
|
8天前
|
人工智能 Android开发 iOS开发
安卓与iOS开发:平台选择的艺术
在移动应用开发的广阔天地里,安卓和iOS两大操作系统各占半壁江山。本文将深入探讨这两个平台的开发环境、工具及市场趋势,帮助开发者在选择适合自己项目的平台时做出更明智的决策。通过比较各自的优势与局限,我们不仅能更好地理解每个系统的核心特性,还能洞察未来技术发展的脉络。无论你是刚入行的新手还是资深开发者,这篇文章都将为你提供有价值的参考和启示。
20 5
|
8天前
|
开发工具 Android开发 iOS开发
安卓与iOS开发:一场操作系统的较量
在数字时代的浪潮中,安卓和iOS这两大操作系统如同海上的两艘巨轮,各自承载着不同的使命与梦想。本文将深入浅出地探讨这两个系统在开发领域的异同,从用户体验、开发工具、市场趋势等多个维度进行比较分析。通过这场技术的较量,我们可以更好地理解每个系统的优势与局限,以及它们如何影响我们的日常生活和工作。