iOS項(xiàng)目中集成 Flutter 模塊 2021-06-20

環(huán)境

  • Flutter 2.3.0
  • Dart 2.14.0

準(zhǔn)備

  • 配置好Flutter環(huán)境兴革,具體細(xì)節(jié) 參考Flutter官網(wǎng)
  • 終端命令行創(chuàng)建Flutter Module
flutter create --template module flutter_module
  • Xcode 創(chuàng)建 iOS Project(FlutterDemo)
  • 創(chuàng)建并配置 Podfile 文件
$flutter_path = '../flutter_module/'

target 'FlutterDemo' do
    flutter_application_path = $flutter_path
    load File.join(flutter_application_path, '.ios', 'Flutter', 'podhelper.rb')
    install_all_flutter_pods(flutter_application_path)
end
  • pod install

頁面跳轉(zhuǎn)

AppDelegate.swift

import Flutter

lazy var flutterEngine: FlutterEngine = {
        // "main" 為對(duì)應(yīng)的dart文件
        let engine: FlutterEngine = FlutterEngine(name: "main", project: nil)
        return engine
    }()

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
        // Override point for customization after application launch.
        flutterEngine.run(withEntrypoint: nil)        
        return true
    }

Native跳轉(zhuǎn)Flutter頁面

let appDelegate: AppDelegate = UIApplication.shared.delegate as! AppDelegate
let vc: FlutterViewController = FlutterViewController(engine: appDelegate.flutterEngine, nibName: nil, bundle: nil)
navigationController?.pushViewController(vc, animated: true)

使用CocoaPods引入遠(yuǎn)程倉庫Flutter Module

  • 上面集成是通過指定本地路徑Flutter文件锯梁,才能正確引入
  • 創(chuàng)建Flutter的時(shí)候?qū)⒛夸浀刂穾нM(jìn)了文件內(nèi) 導(dǎo)致如果將Flutter Module地址移動(dòng)地址浙巫,將不能正確runing 主Project
    實(shí)際開發(fā)過程中难菌,往往將Module直接放在遠(yuǎn)程倉庫上侵续,需要的時(shí)候再通過pod install集成到主項(xiàng)目中燎潮, 基于以上兩點(diǎn)喻鳄,上面實(shí)現(xiàn) 無法滿足實(shí)際需求。

解決方案:Flutter Module 生成 Framework

  1. 先打包Framework
flutter build ios-framework --output=./path
  1. 將導(dǎo)出的所有Framework都合并架構(gòu)
/// 查看 framework 支持的架構(gòu)
lipo -info Flutter.framework  
/// 合并架構(gòu)
lipo -create Flutter-1.framework/Flutter Flutter-2.framework/Flutter -output Flutter.framework
  1. 創(chuàng)建私有庫
pod lib create FlutterLib

4.修改podspec文件, 添加依賴flutter module打包生成所有framework

 s.ios.vendored_frameworks = 'ios_frameworks/App.framework',
  'ios_frameworks/Flutter.framework'
  1. 將第2步合并的所有framework移動(dòng)到 第4步指定的目錄中确封,如ios_frameworks目錄下
  2. 在主app下通過引用私有庫 FlutterLib 引入Flutter Module
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末除呵,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子爪喘,更是在濱河造成了極大的恐慌颜曾,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,888評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件秉剑,死亡現(xiàn)場(chǎng)離奇詭異泛豪,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)侦鹏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,677評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門候址,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人种柑,你說我怎么就攤上這事岗仑。” “怎么了聚请?”我有些...
    開封第一講書人閱讀 168,386評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵荠雕,是天一觀的道長(zhǎng)稳其。 經(jīng)常有香客問我,道長(zhǎng)炸卑,這世上最難降的妖魔是什么既鞠? 我笑而不...
    開封第一講書人閱讀 59,726評(píng)論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮盖文,結(jié)果婚禮上嘱蛋,老公的妹妹穿的比我還像新娘。我一直安慰自己五续,他們只是感情好洒敏,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,729評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著疙驾,像睡著了一般凶伙。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上它碎,一...
    開封第一講書人閱讀 52,337評(píng)論 1 310
  • 那天函荣,我揣著相機(jī)與錄音,去河邊找鬼扳肛。 笑死傻挂,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的挖息。 我是一名探鬼主播踊谋,決...
    沈念sama閱讀 40,902評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼旋讹!你這毒婦竟也來了殖蚕?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,807評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤沉迹,失蹤者是張志新(化名)和其女友劉穎睦疫,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鞭呕,經(jīng)...
    沈念sama閱讀 46,349評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蛤育,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,439評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了葫松。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瓦糕。...
    茶點(diǎn)故事閱讀 40,567評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖腋么,靈堂內(nèi)的尸體忽然破棺而出咕娄,到底是詐尸還是另有隱情,我是刑警寧澤珊擂,帶...
    沈念sama閱讀 36,242評(píng)論 5 350
  • 正文 年R本政府宣布圣勒,位于F島的核電站费变,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏圣贸。R本人自食惡果不足惜挚歧,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,933評(píng)論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望吁峻。 院中可真熱鬧滑负,春花似錦、人聲如沸用含。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,420評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽耕餐。三九已至凡傅,卻和暖如春辟狈,著一層夾襖步出監(jiān)牢的瞬間肠缔,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,531評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工哼转, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留明未,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,995評(píng)論 3 377
  • 正文 我出身青樓壹蔓,卻偏偏與公主長(zhǎng)得像趟妥,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子佣蓉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,585評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容