iOS中Today扩展插件与宿主APP的交互

iOS中Today扩展插件与宿主APP的交互

        扩展是iOS8后系统开发给开发者的新开发思路与接口,每个扩展均可以理解为一个简单的小应用程序,只是其不是独立存在的,要寄附于某一个主应用上。介绍iOS8扩展与Today插件的专题见以下博客:网络

iOS8中扩展与Today插件:http://my.oschina.net/u/2340880/blog/485533app

        上述博客中只是简单的介绍扩展的应用场景与建立Today扩展插件的方法,在实际开发中,因为扩展是寄附于某个应用程序之上的,所以其一般须要和宿主APP进行数据交互。建立Today扩展Target后,Xcode模板会自动帮助开发者生成一个ViewController做为主界面,开发者能够向其中添加展现UI或者交互控件,十分强大的是,Today扩展中是支持对UIViewController的切换的。须要注意,扩展与原APP是在不一样的目录结构中的,默认状况下,扩展与原APP的数据并不共享,代码也不能复用。例如原APP中可能有网络请求,数据持久化存储等结构框架,扩展中不能够直接使用,扩展须要提供本身的网络请求框架爱,数据持久化结构框架等。框架

      若是项目是使用Pod进行的管理,则能够经过手动设置,使扩展中可使用继承的Pod库,步骤以下:测试

完成上面两张图中的步骤,便可在扩展中使用Pod库了。ui

        Xcode扩展模板建立的ViewController会自动遵照NSWidgetProviding这个协议,这个协议中的方法和意义以下,开发者能够根据需求选择实现:url

//数据更新时调用的方法 系统会按期更新扩展
- (void)widgetPerformUpdateWithCompletionHandler:(void (^)(NCUpdateResult result))completionHandler;
//设置扩展UI边距 注意 在使用Storyboard时,若要所见即所得 这个方法中须要返回UIEdgeInsetsZero
- (UIEdgeInsets)widgetMarginInsetsForProposedMarginInsets:(UIEdgeInsets)defaultMarginInsets;

注意:Today扩展有其本身的plist配置文件,若须要对扩展进行配置,注意不要与宿主工程的plist文件混淆。spa

        在Today扩展中打开原宿主APP使用openURL的方式,示例以下:.net

[viewController.extensionContext openURL:[NSURL URLWithString:[NSString stringWithFormat:@"MyApp://action=%@",@"action"]] completionHandler:nil];

上面打开原宿主APP的代码中,MyApp是宿主APP配置的url Schemes,配置方式以下图:插件

能够经过为url配置参数的方式来进行Today扩展与原宿主APP的信息交互,当扩展使用openURL的方式打开原宿主APP时,宿主APP会调用AppDelegate中的以下方法:调试

-(BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString *,id> *)options{
//能够拿到url作相应逻辑处理
    UIAlertView * alert = [[UIAlertView alloc]initWithTitle:url.absoluteString message:nil delegate:nil cancelButtonTitle:@"肯定" otherButtonTitles:nil, nil];
    [alert show];
    return YES;
}

        上面介绍的openURL的方式只是进行跳转交互,参数传递,并不能完成数据共享的需求,而且经过openURL的方式传递的数据是单向的。实际上,扩展和原宿主APP共享数据的应用场景十分普遍,例如电商类宿主APP中拉取到一批商品信息,Today扩展中也须要这些信息进行展现,若是数据不共享,一样的数据将在宿主APP内部和扩展都都请求一次,十分浪费,难很难同步。系统还提供了另外一种方式来使宿主APP和Today扩展能够共享一块存储空间,这须要使用App Group技术来实现。开发者在进行App Group相关功能的测试时,必须与AppID进行关联。

        首先,须要开启宿主APP的App Group,示例图以下:

在Today扩展中,选择相同的App Group,以下:

开启了App Group功能后,Xcode会自动生成一套匹配的权限文件,以下:

配置工做完成后,能够经过两种方式共享数据存储空间,示例以下:

//使用数据共享的NSUserDefaults 这个NSUserDefaults是宿主APP与扩展所共享的
    NSUserDefaults * defaults =[NSUserDefaults alloc]initWithSuiteName:@"开发者设置的AppGroup名称"];

    //使用数据共享的文件目录
    NSFileManager * manager = [NSFileManager defaultManager];
    //共享目录
    NSURL * baseURL = [manager containerURLForSecurityApplicationGroupIdentifier:@"开发者设置的AppGroup名称"];
    //找文件
    NSURL * filePath =  [baseURL URLByAppendingPathComponent:@"file"];

注意:还有一点细节须要注意,扩展与原宿主APP素材文件也是互相独立的,要在扩展中使用的素材必须添加进扩展Target。

小提示:使用Xcode调试扩展时,须要运行扩展的Target,开发者有时会发现断点失效,将模拟器上的应用删掉,从新运行扩展便可解决。

 

Demo地址:http://pan.baidu.com/s/1bp0ZcYF

截图:

      

 

专一技术,热爱生活,交流技术,也作朋友。

——珲少 QQ群:203317592

相关文章
相关标签/搜索