iOS已有項(xiàng)目引入Flutter

iOS馋评、Flutter混合開(kāi)發(fā)中,經(jīng)常會(huì)遇到向已有項(xiàng)目中引入Flutter的情況瞳抓。為了模擬這種情況下引入Flutter的場(chǎng)景埃疫,我會(huì)新建一個(gè)iOS工程,然后在新的iOS工程中孩哑,引入Flutter栓霜。

大致步驟如下:
1.新建iOS工程,使用CocoaPods管理工程横蜒;
2.新建Flutter Module胳蛮;
3.iOS接入flutter module;
4.編寫(xiě)測(cè)試代碼丛晌,查看結(jié)果;
當(dāng)然前提是Mac電腦已經(jīng)配置了Flutter環(huán)境變量仅炊,并安裝了Cocoapods管理工具,這里不詳述了茵乱,需要的可自行百度茂洒。

1、新建iOS工程,使用CocoaPods管理工程

新建文件夾FlutterMixDemo督勺,并在目錄下新建Xcode project : ios_app;
啟動(dòng)終端在FlutterMixDemo/ios_app目錄下依次執(zhí)行一下命令:

pod init
pod install
2渠羞、新建Flutter Module

打開(kāi)終端切換到iOS_Flutter_MixBuilder目錄下,執(zhí)行下面命令:

flutter create -t module my_flutter

my_flutter為module的名字智哀,執(zhí)行完命令等待即可次询。

創(chuàng)建完成build一下,命令如下:

flutter build ios

如果執(zhí)行上面的命令出現(xiàn)證書(shū)相關(guān)錯(cuò)誤瓷叫,也可以使用下方的指令在build的時(shí)候選擇不簽名屯吊,命令如下:

flutter build ios --no-codesign
3、iOS接入flutter module

官方給出了三種接入方案摹菠,這三種方案各有優(yōu)缺點(diǎn)盒卸,我們先簡(jiǎn)單看看這三種方案:

使用 CocoaPods 和 Flutter SDK 集成:ios項(xiàng)目中用CocoaPods直接接入管理flutter module。這種方案需要所有開(kāi)發(fā)人員都配置flutter環(huán)境次氨,且安裝CocoaPods蔽介;優(yōu)點(diǎn)是通過(guò)CocoaPods自動(dòng)集成,配置簡(jiǎn)單煮寡。

在 Xcode 中集成 frameworks:將flutter module先build成FrameWork文件虹蓄,然后在ios項(xiàng)目中引入文件。這種方案的優(yōu)點(diǎn)是ios開(kāi)發(fā)人員不需要flutter環(huán)境幸撕,且項(xiàng)目不需要安裝CocoaPods薇组;缺點(diǎn)是每次修改都需要重新build,重新導(dǎo)入坐儿。

通過(guò)CocoaPods打包Framework:與2類(lèi)似律胀,只不過(guò)在build時(shí)加入--cocoapods參數(shù):flutter build ios-framework --cocoapods --xcframework --no-universal --output=some/path/MyApp/Flutter/。打包出來(lái)的是Flutter.podspec 文件挑童,ios項(xiàng)目中通過(guò)CocoaPods管理集成累铅。這個(gè)方案的與2方案差不多跃须,缺點(diǎn)也是每次改動(dòng)需要重新build站叼,優(yōu)點(diǎn)是ios開(kāi)發(fā)人員不需要flutter環(huán)境。

所以要根據(jù)自身的情況來(lái)選擇符合自己的方案菇民。官方推薦第一種方案尽楔,我也嘗試了第一個(gè)方案,并很順利的引入了Flutter第练,如果你想嘗試其它兩種方式阔馋,可以自行百度指引,本文就不多做延伸了娇掏。

使用Cocoapods+Flutter SDK引入

先打開(kāi)上一步創(chuàng)建的iOS項(xiàng)目的podfile文件呕寝,并在開(kāi)頭添加上下面的代碼:

flutter_application_path = '../my_flutter/'

load File.join(flutter_application_path, '.ios', 'Flutter', 'podhelper.rb')

post_install do |installer|
  flutter_post_install(installer)
end

然后在target中添加:

target 'xxx' do
  install_all_flutter_pods(flutter_application_path)
end

修改后的podfile文件如下:

# Uncomment the next line to define a global platform for your project
# platform :ios, '9.0'

flutter_application_path = '../my_flutter/'

load File.join(flutter_application_path, '.ios', 'Flutter', 'podhelper.rb')

post_install do |installer|
  flutter_post_install(installer)
end

target 'ios_app' do

  use_frameworks!

  install_all_flutter_pods(flutter_application_path)

end

最后終端切換到iOS_Flutter_MixBuilder目錄下,執(zhí)行下面命令:

pod install

CocoaPods會(huì)自動(dòng)將flutter module編輯出的產(chǎn)物集成到ios項(xiàng)目中婴梧。如果沒(méi)有問(wèn)題下梢,執(zhí)行?+B 編譯項(xiàng)目就會(huì)成功客蹋。

4、編寫(xiě)測(cè)試代碼孽江,查看結(jié)果

我們?cè)赩iewController原生controller界面讶坯,添加代碼實(shí)現(xiàn)跳轉(zhuǎn)到Flutter界面FlutterViewController,

#import "ViewController.h"
#import <Flutter/Flutter.h>

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    UILabel *label = [[UILabel alloc]init];
    label.textAlignment = NSTextAlignmentCenter;
    label.numberOfLines = 0;
    label.textColor = [UIColor blackColor];
    label.text = @"這是原生界面\n點(diǎn)擊跳轉(zhuǎn)Flutter";
    [self.view addSubview:label];
    
    CGFloat screenWidth = [UIScreen mainScreen].bounds.size.width;
    CGFloat screenHeight = [UIScreen mainScreen].bounds.size.height;
    label.frame = CGRectMake((screenWidth-200)/2, (screenHeight-40)/2, 200, 60);
}

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
    
    [self jumpToFlutterViewController];
}

- (void)jumpToFlutterViewController {
    
    FlutterViewController *vc = [[FlutterViewController alloc]init];
    [self presentViewController:vc animated:YES completion:nil];
}
@end

參考資料:
[稀土掘金]Flutter岗屏、iOS混合開(kāi)發(fā)實(shí)踐
[阿里云開(kāi)發(fā)者社區(qū)]Flutter混合開(kāi)發(fā):在已有iOS項(xiàng)目中引入Flutter(上)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末辆琅,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子这刷,更是在濱河造成了極大的恐慌婉烟,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件暇屋,死亡現(xiàn)場(chǎng)離奇詭異隅很,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)率碾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)叔营,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人所宰,你說(shuō)我怎么就攤上這事绒尊。” “怎么了仔粥?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵婴谱,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我躯泰,道長(zhǎng)谭羔,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任麦向,我火速辦了婚禮瘟裸,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘诵竭。我一直安慰自己话告,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布卵慰。 她就那樣靜靜地躺著沙郭,像睡著了一般。 火紅的嫁衣襯著肌膚如雪裳朋。 梳的紋絲不亂的頭發(fā)上病线,一...
    開(kāi)封第一講書(shū)人閱讀 51,631評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼送挑。 笑死夜矗,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的让虐。 我是一名探鬼主播紊撕,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼赡突!你這毒婦竟也來(lái)了对扶?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤惭缰,失蹤者是張志新(化名)和其女友劉穎浪南,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體漱受,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡络凿,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了昂羡。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片絮记。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖虐先,靈堂內(nèi)的尸體忽然破棺而出怨愤,到底是詐尸還是另有隱情,我是刑警寧澤蛹批,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布撰洗,位于F島的核電站,受9級(jí)特大地震影響腐芍,放射性物質(zhì)發(fā)生泄漏差导。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一猪勇、第九天 我趴在偏房一處隱蔽的房頂上張望设褐。 院中可真熱鬧,春花似錦埠对、人聲如沸络断。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至弱判,卻和暖如春襟沮,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工开伏, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留膀跌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓固灵,卻偏偏與公主長(zhǎng)得像捅伤,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子巫玻,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355