FlutterBoostPlugin.h 4.27 KB
Newer Older
Jidong Chen's avatar
init  
Jidong Chen committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
/*
 * The MIT License (MIT)
 * 
 * Copyright (c) 2019 Alibaba Group
 * 
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 * 
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 * 
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
#import <Flutter/Flutter.h>

26
#import "FLBPlatform.h"
Jidong Chen's avatar
Jidong Chen committed
27
#import "FLBTypes.h"
Jidong Chen's avatar
init  
Jidong Chen committed
28

29
@interface FlutterBoostPlugin : NSObject<FlutterPlugin>
Jidong Chen's avatar
Jidong Chen committed
30
#pragma mark - Initializer
Jidong Chen's avatar
init  
Jidong Chen committed
31 32
+ (instancetype)sharedInstance;

余玠's avatar
余玠 committed
33 34 35 36 37 38
/**
 * 初始化FlutterBoost混合栈环境。应在程序使用混合栈之前调用。如在AppDelegate中
 *
 * @param platform 平台层实现FLBPlatform的对象
 * @param callback 启动之后回调
 */
39
- (void)startFlutterWithPlatform:(id<FLBPlatform>)platform
余玠's avatar
余玠 committed
40
                         onStart:(void (^)(FlutterEngine *engine))callback;
Jidong Chen's avatar
init  
Jidong Chen committed
41 42 43

#pragma mark - Some properties.
- (BOOL)isRunning;
Jidong Chen's avatar
Jidong Chen committed
44

Jidong Chen's avatar
init  
Jidong Chen committed
45 46
- (FlutterViewController *)currentViewController;

Jidong Chen's avatar
Jidong Chen committed
47
#pragma mark - broadcast event to/from flutter
余玠's avatar
余玠 committed
48 49 50 51 52 53 54

/**
 * Native层往Dart层发送事件,事件名称通过eventName指定
 *
 * @param eventName 事件名称
 * @param arguments 参数
 */
Jidong Chen's avatar
Jidong Chen committed
55
- (void)sendEvent:(NSString *)eventName
Jidong Chen's avatar
Jidong Chen committed
56
        arguments:(NSDictionary *)arguments;
Jidong Chen's avatar
Jidong Chen committed
57

余玠's avatar
余玠 committed
58 59 60 61 62 63
/**
 * 添加监听Dart层调用Native层的事件
 *
 * @param name 事件名称
 * @param listner 事件监听器
 */
Jidong Chen's avatar
Jidong Chen committed
64 65
- (FLBVoidCallback)addEventListener:(FLBEventListener)listner
                            forName:(NSString *)name;
66 67

#pragma mark - open/close Page
余玠's avatar
余玠 committed
68 69 70 71 72 73 74 75 76

/**
 * 关闭页面,混合栈推荐使用的用于操作页面的接口
 *
 * @param uniqueId 关闭的页面唯一ID符
 * @param resultData 页面要返回的结果(给上一个页面),会作为页面返回函数的回调参数
 * @param exts 额外参数
 * @param completion 关闭页面的即时回调,页面一旦关闭即回调
 */
77
+ (void)close:(NSString *)uniqueId
余玠's avatar
余玠 committed
78
       result:(NSDictionary *)resultData
79 80 81
         exts:(NSDictionary *)exts
   completion:(void (^)(BOOL))completion;

余玠's avatar
余玠 committed
82
/**
余玠's avatar
余玠 committed
83
 * 打开新页面(默认以push方式),混合栈推荐使用的用于操作页面的接口;通过urlParams可以设置为以present方式打开页面:urlParams:@{@"present":@(YES)}
余玠's avatar
余玠 committed
84 85 86 87 88 89 90
 *
 * @param url 打开的页面资源定位符
 * @param urlParams 传人页面的参数; 若有特殊逻辑,可以通过这个参数设置回调的id
 * @param exts 额外参数
 * @param resultCallback 当页面结束返回时执行的回调,通过这个回调可以取得页面的返回数据,如close函数传入的resultData
 * @param completion 打开页面的即时回调,页面一旦打开即回调
 */
91 92 93
+ (void)open:(NSString *)url
   urlParams:(NSDictionary *)urlParams
        exts:(NSDictionary *)exts
余玠's avatar
余玠 committed
94
       onPageFinished:(void (^)(NSDictionary *))resultCallback
95
  completion:(void (^)(BOOL))completion;
余玠's avatar
余玠 committed
96 97 98 99 100 101 102 103 104 105 106 107 108 109 110

/**
 * Present方式打开新页面,混合栈推荐使用的用于操作页面的接口
 *
 * @param url 打开的页面资源定位符
 * @param urlParams 传人页面的参数; 若有特殊逻辑,可以通过这个参数设置回调的id
 * @param exts 额外参数
 * @param resultCallback 当页面结束返回时执行的回调,通过这个回调可以取得页面的返回数据,如close函数传入的resultData
 * @param completion 打开页面的即时回调,页面一旦打开即回调
 */
+ (void)present:(NSString *)url
   urlParams:(NSDictionary *)urlParams
        exts:(NSDictionary *)exts
onPageFinished:(void (^)(NSDictionary *))resultCallback
  completion:(void (^)(BOOL))completion;
Jidong Chen's avatar
init  
Jidong Chen committed
111
@end