如何在swift中使用cocoapods导入的第三方oc库
推荐于2016-01-22
就像Java有Maven一样,Objective-C也有自己的依赖管理工具cocoapods。
但是由于swift才出来不久,目前很多cocoapods管理的第三方库依然是由Objective-C编写的。
为了能够在swift中使用这些类库,需要在Xcode中进行一些配置。
假设你的项目是基于cocoapods的,并且是通过XX.xcworkspace打开的。(Xcode6以上)
为了进行演示,假设导入的第三方库是 MBProgressHUD 。下面讲解如何在swift中使用该类库。
步骤一:创建头文件(该头文件是连接oc到swift的桥梁)
在project navigator中右击项目,选择New File... -> iOS -> Source -> Header File,给文件命名后(头文件命名任意,假设为Bridging-Header.h)保存。
步骤二:打开该文件,清空里面的内容,然后导入你想要的类库并保存。
#import "MBProgressHUD.h"
步骤三:
进入到Build Settings,在搜索框中输入bridg,找到Objective-C Bridging Header,选项,把头文件的路径赋值给该选项。如图所示:
步骤三:
使用引用的代码,比如在viewDidLoad方法里添加显示进度框:
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
// 如同pch一样,使用该类库无需在顶部导入该类库的头文件
MBProgressHUD .showHUDAddedTo(self.view, animated: true)
}
运行效果如下:
--------------------
-----
-----
需要注意的是,假如不是通过cocoapods引入的类库,而是直接拷贝到项目中(Build Settings的Objective-C Bridging Header没有赋值过,Xcode会弹出如下对话框:
选择Yes后,项目的根目录下会自动创建一个名字为XXX-Bridging-Header.h的头文件(XXX为你的模块名(module name)一般就是你的product name),
另外在Build Settings的Objective-C Header File的值也被自动设成头文件的路径。
如图所示:
只要在自动生成的头文件里import你想要的第三方类库后,就可以随意在你的项目源文件里使用它了。