iOS中Main App和Extensions之间通信
来源:互联网 发布:mac 终端查找文件夹 编辑:程序博客网 时间:2024/04/28 21:52
iOS中Main App和Extensions之间通信
本文主要介绍MMWormhole框架的使用, 该框架主要用来实现进程间的通信, 在iOS开发中我们经常需要app和extension之间进行数据通信,例如: app和widget之间的通信, 这时候我们就可以使用MMWormhole来实现.
基本原理
首先需要简单介绍一下app groups的概念,下面是一段简单的描述:
这是iOS8新开放的功能,在OS X上早就可用了。它主要用于同一group下的app共享同一份读写空间,以实现数据共享。
extension和containing app共同读写一份数据是很合理的需求,比如系统的股市应用,widget和app中都需要展示几个公司的股票数据,这就可以通过App Groups实现。
其实MMWormhole也是基于这个实现的, 这种通信模式其实跟android中的content provider的形式很类似, 关于App Groups更深入的了解大家可以查阅相关资料, 这里不详细阐述了.
具体使用
这里是效果图:
具体的使用方法也很简单,大致分为以下几步:
1.初始化, 这里需要使用group id, 也就是前面提到的app group.
self.wormhole = [[MMWormhole alloc] initWithApplicationGroupIdentifier:@"group.com.mutualmobile.wormhole" optionalDirectory:@"wormhole"];
2.消息接受方注册监听
[self.wormhole listenForMessageWithIdentifier:@"messageIdentifier" listener:^(id messageObject) { // Do Something}];
3.消息发送方发送消息
[self.wormhole passMessageObject:@{@"titleString" : title} identifier:@"messageIdentifier"];
基于以上三步,也就基本实现了消息通信, 而且还能够传递数据, 使用也非常方便.具体详细的介绍,大家可以去github官网查看.
总结
其实, MMWormhole采用的是文件固化的方式,将具体的数据写入app group中,然后实现进程间的通信,同时它的底层是基于CFNotificationCenter这种系统级消息机制实现的,来实现进程间的通信服务.
项目地址:https://github.com/mutualmobile/MMWormhole
- iOS中Main App和Extensions之间通信
- iOS中两个APP之间的跳转和通信
- iOS App之间如何通信
- 一、iOS App Extensions
- iOS中Categories和Extensions的区别
- IOS APP唤醒另一个APP(app之间互相通信)
- App Extensions for iOS 8
- IOS 唤醒另一个APP(app之间互相通信)
- IOS 唤醒另一个APP(app之间互相通信)
- IOS 唤醒另一个APP(app之间互相通信
- iOS中Categories和Extensions的简单对比
- 深入App Extensions for iOS 8
- iOS平台下实现不同APP之间的通信
- iOS平台下实现不同APP之间的通信
- iOS平台下实现不同APP之间的通信
- iOS平台下实现不同APP之间的通信
- iOS 两个App之间利用URLSchemes的通信
- iOS app之间常用的五种通信方式
- iiOS 开发基础:UIImageView属性
- android的ui组件布局提示:android.widget.XXX cannot be cast to android.widget.YYY解决
- 栈应用之将中缀表达式转化为后缀表达式(逆波兰表达式)
- STL中sort排序算法原理
- Linux vim 常用快捷键
- iOS中Main App和Extensions之间通信
- sgu131
- struts2学习(一) 环境搭建以及简单的演示程序
- uVA311包裹包含
- 基于CentOS7开发之路 --- 第四章 :CentOS 7 安装 postgresql 9.5.0 数据库
- ubuntu samba服务器配置
- Java常量池详解之一道比较蛋疼的面试题
- 表达式求值-栈和队列的应用
- ios全局返回按钮和全屏侧滑功能