一.建立工程 1.建立flutter_module,建立flutter_module,建立flutter_module,不要建立flutter_Application 工程名字你自己定
如圖
data:image/s3,"s3://crabby-images/7212b/7212b2888f7b0b1ed44819122c70dae8f799d5dd" alt="Flutter 和iOS 混合開發(一)"
data:image/s3,"s3://crabby-images/69e88/69e8884da863fb7b65fc084e32606ca9bcfdd11b" alt="Flutter 和iOS 混合開發(一)"
data:image/s3,"s3://crabby-images/c47be/c47be417952a9bc1dbef71c3420954ece8dd5fc3" alt="Flutter 和iOS 混合開發(一)"
flutter_application_path = '../flutter_module/'
eval(File.read(File.join(flutter_application_path, '.ios', 'Flutter', 'podhelper.rb')),
引入flutter 然後pod install
4.配置xcode的相關東西了,因為flutter 不支援bitcode,所以需要把xcode的enablebitcode 設為NO
5.xcode 預設不會執行flutter檔案的,那麼需要一個執行指令碼 我們需要在xcode建立一個指令碼檔案
data:image/s3,"s3://crabby-images/1889c/1889cf1c169601239cad3812432460e1671161e8" alt="Flutter 和iOS 混合開發(一)"
這個指令碼檔案 flutter 官方已經提供給我們了, 位置在:你下載的flutterSDK 裡(配置Flutter環境時下的) packages->flutter_tools->bin->xcode_backend.sh
data:image/s3,"s3://crabby-images/07f46/07f4610a9113051d763db9284908d9e63a2fbc23" alt="Flutter 和iOS 混合開發(一)"
6.在xcode指令碼處我們填入
data:image/s3,"s3://crabby-images/19532/195328a96d772a9ebbb9eb8eeecefd6a430b4c31" alt="Flutter 和iOS 混合開發(一)"
"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh" embed
注意:因為指令碼執行是有順序的,我們需要拖到第二位,只需拖到第二位
data:image/s3,"s3://crabby-images/5cd0f/5cd0f5d58abed85f896b792641c5b51c2926e5d3" alt="Flutter 和iOS 混合開發(一)"
7.編譯工程,正常不會出錯的
二 混合顯示
在xcode工程引入#import <Flutter/Flutter.h>
//
// ViewController.m
// Native
//
// Created by 孫文策 on 2019/8/8.
// Copyright © 2019 孫文策. All rights reserved.
//
#import "ViewController.h" #import <Flutter/Flutter.h>
@interface ViewController ()
@end
@implementation ViewController
-
(void)viewDidLoad {
-
[super viewDidLoad];
// Do any additional setup after loading the view.
UIButton * button = [UIButton buttonWithType:UIButtonTypeCustom];
[button setTitle:@"顯示flutter" forState:UIControlStateNormal];
button.frame = CGRectMake(50, 100, 100, 20);
button.backgroundColor = [UIColor redColor];
[self.view addSubview:button];
[button addTarget:self action:@selector(testAction:) forControlEvents:UIControlEventTouchUpInside];
}
-
(void)testAction:(UIButton *)sender { FlutterViewController * flutterVc = [[FlutterViewController alloc] init]; [self presentViewController:flutterVc animated:YES completion:^{
}]; }
@end
以上是我的測試程式碼。
點選按鈕,我們就可以顯示flutter 頁面了!
可能有說的不詳細的,因為本來寫好了,結果釋出的時候發現不了,還提示我已經儲存到了草稿,然後意外退出來,之前寫的全沒了,心態崩了。。。 有問題可以聯絡我本人:vx: 353634026 記得備註
我得去恢復恢復心態,明天更新flutter和原生通訊,難受