Swift项目引入第三方库的方法

以下,将创建一个Swift项目,然后引入3个库:

  • Snappy简化autolayout代码的库
  • AlamofireHTTP网络库,AFNetworking作者写的
  • SDWebImage图片加载,objc项目,通过头文件bridge方式供swift使用

其中,前两个是Swift的库,SDWebImage是Objc的库。

源代码见:https://github.com/MarshalW/SwiftWith3rdLibDemo

项目跑起来是这个样子:

做下面步骤之前,需要让自己的项目是git项目。

使用Snappy库

Snappy库,用于简化AutoLayout布局的代码。

和Objc项目不同,Swift项目没有类似CocoaPods的库依赖工具,而是使用git的submodule引入库。目前来看更方便使用。

1. 创建submodule

在当前项目的目录下执行:

1
git submodule add https://github.com/Masonry/Snappy.git

执行完会看到多了个Snappy目录。

这样的项目,如果git共享给其他人,他们除了clone项目以外,还需要:

1
git submodule update --init --recursive
2. 将Snappy.xcodeproj加入到Xcode项目中

如下图所示,直接将文件拖拽过去即可:

3. 将Snappy.framework设置到项目中

Xcode打开项目的General,点击+

然后,选择Snappy.framework,加上它。

4. 编写代码测试

如果能正常import,Xcode不报错,就应该没有问题了:

1
import Snappy

写了个简单的代码运行也没有问题:


override func viewDidAppear(animated: Bool) {
println("super view: \(imageView.superview)")

let padding = UIEdgeInsetsMake(100,100,0)

imageView.snp_makeConstraints { make in //autolayout
make.edges.equalTo(self.imageView.superview!).with.insets(padding)
return
}
}

使用SDWebImage库

SDWebImage库是Objc编写的。引入的方式和Swift有所不同(从第3步开始)。

1. 创建submodule

这一步还是省不了的:

1
git submodule add https://github.com/rs/SDWebImage.git
2. 将SDWebImage.xcodeproj加入到Xcode项目中

3. 设置Target Dependencies

在这里:

加入:

看起来是这样:

4. Link Binaray With Libraries

找到这里:

加入ImageIO.framework(iOS自带的),以及libSDWebImage.a

5. 设置Other Linker Flags

在这里设置-ObjC

设置完了的样子:

6. 创建Bridge头文件

就是创建一个普通的头文件,一般命名为项目名-Bridge-Header.h

7. 设置Bridge头文件

找到这里:

双击箭头标示的地方,会弹出文本框,将头文件加进去即可。

我开始的时候是参照stackoverflow的回答,将头文件直接拖拽进去,发现用的是绝对路径。可以在拖拽后修改一下:

引入第三方库的常见问题

目前主要碰到的问题是各个Swift第三方库Deployment Target版本不一致。比如Alamofire是8.0,而Snappy是7.0,需要让它们的版本是一致的。

会有类似这样的报错:

1
ld: embedded dylibs/frameworks are only supported on iOS 8.0 and later ...

Swift项目引入第三方库的方法的更多相关文章

  1. ios – CFNetwork内部错误:URLConnectionLoader.cpp:289

    当我在一段时间后打开我的应用程序时,我收到了日志:440:CFNetworkinternalerror(0xc01a:/buildroot/Library/Caches/com.apple.xbs/Sources/CFNetwork/CFNetwork-758.4.3/Loading/URLConnectionLoader.cpp:289)它从未出现在过去.我的项目使用网络库AFNetworkin

  2. ios – 如何获取缓存图像SDWebImage的数据

    我正在使用SDWebImage库来缓存我的UICollectionView中的Web图像:但我想将缓存的图像本地保存在文件中,而不是再次下载它们有没有办法获取缓存图像的数据解决方法SDWebImage默认自动缓存下载的图像.您可以使用SDImageCache从缓存中检索图像.当前应用会话有一个内存缓存,它会更快,并且有磁盘缓存.用法示例:还要确保在文件中导入SDWebImage.(如果您使用的是Swift/Carthage,它将导入WebImage

  3. 【原创IOS开发】swift使用SDWebImages

    oc使用SDWebImage网上很多代码了已经。。下载地址:https://github.com/rs/SDWebImage2、swift调用的时候,需要在“xxxx-Bridging-Header”加入:#include"UIImageView+Webcache.h"建立桥接。,placeholderImage:UIImage)其中icon.png为未加载时的默认图片。imageArr为存放图片url的一个数组。

  4. 在Swift中,使用SDWebImage做缓存后获取缩略图的大小

    0//不等于1,执行下一个循环ifcount![0],options:[],progress:nil,completed:{->Voidin//图片缓存完成,但是图片不一定有imageifimage!=nil{//将image转成二进制数据letdata=UIImagePNGRepresentationdataLenth+=data!.length}//dispath_group_leave要放到闭包的最后,才能够正确的测试出。dispatch_group_leave})}//调度组回到主队列dispat

  5. Swift:用UICollectionView整一个瀑布流

    除了以上说到的内容之外,collectionview还有一个专门处理布局的UICollectionViewLayout。苹果给了一个基础的布局UICollectionViewFlowLayout,可以实现一个基本的流式布局。直接干掉,拖一个UICollectionViewController进去并设置为默认的Controller。之后在interfacebuilder中把collectionview的类设置为HomeCollectionViewController。接下来再次回到collectionvie

  6. 小胖说swift01--------如何在Swift开发中使用CocoaPods导入的第三方库

    今天在用Swift写项目时,需要用CocoaPods引入SDWebImage这个三方库,于是开始在Vim命令中创建podfile,在创建之前需要cd到当前项目的目录中,Podfile创建步骤如下:1、创建Podfile:touchPodfile2、编辑Podfile文件:vimPodfile按i进入编辑状态,编辑完成后按Esc退出编辑状态,然后输入:wq返回,Podfile文件的内容如下需要注意的一点是:swift和OC中有一点不同,在swift中配置Podfile文件时要加上use_framework!

  7. Swift项目引入第三方库的方法

    Swift项目引入第三方库的方法以下,将创建一个Swift项目,然后引入3个库:Snappy简化autolayout代码的库AlamofireHTTP网络库,AFNetworking作者写的SDWebImage图片加载,objc项目,通过头文件bridge方式供swift使用其中,前两个是Swift的库,SDWebImage是Objc的库。和Objc项目不同,Swift项目没有类似CocoaPods的库依赖工具,而是使用git的submodule引入库。可以在拖拽后修改一下:引入第三方库的常见问题目前主要

  8. 源码解析ios开发SDWebImage方法

    这篇文章主要为大家介绍了源码解析ios开发SDWebImage方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  9. php – Snappy&wkhtmltopdf:页脚编号

    我想在Snappy和Wkhtmltopdf生成的每个页面的页脚中都有页码,但我没有找到任何关于它的线索.我可以设置页脚文本,但如何设置页码?…文档here表示某些标签被替换为例如页码.

  10. iOS中的图像预加载

    谢谢解决方法使用sd_setimageWithURL在当前卡上下载映像,并在完成处理程序中开始下载预取队列.通过这种方式,当前图像始终具有最高优先级并且不会滞后.如果已下载当前图像,SDWebImage将识别此并从缓存中获取它.可以通过减少预取图像的数量来解决滞后和高内存消耗的另一个问题.20是相当高的,5应该足够了,但这取决于图像大小,网络速度等…等等.直到你发现它落后的观点.

随机推荐

  1. Swift UITextField,UITextView,UISegmentedControl,UISwitch

    下面我们通过一个demo来简单的实现下这些控件的功能.首先,我们拖将这几个控件拖到storyboard,并关联上相应的属性和动作.如图:关联上属性和动作后,看看实现的代码:

  2. swift UISlider,UIStepper

    我们用两个label来显示slider和stepper的值.再用张图片来显示改变stepper值的效果.首先,这三个控件需要全局变量声明如下然后,我们对所有的控件做个简单的布局:最后,当slider的值改变时,我们用一个label来显示值的变化,同样,用另一个label来显示stepper值的变化,并改变图片的大小:实现效果如下:

  3. preferredFontForTextStyle字体设置之更改

    即:

  4. Swift没有异常处理,遇到功能性错误怎么办?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 字典实战和UIKit初探

    ios中数组和字典的应用Applicationschedule类别子项类别名称优先级数据包contactsentertainment接触UIKit学习用Swift调用CocoaTouchimportUIKitletcolors=[]varbackView=UIView(frame:CGRectMake(0.0,0.0,320.0,CGFloat(colors.count*50)))backView

  6. swift语言IOS8开发战记21 Core Data2

    上一话中我们简单地介绍了一些coredata的基本知识,这一话我们通过编程来实现coredata的使用。还记得我们在coredata中定义的那个Model么,上面这段代码会加载这个Model。定义完方法之后,我们对coredata的准备都已经完成了。最后强调一点,coredata并不是数据库,它只是一个框架,协助我们进行数据库操作,它并不关心我们把数据存到哪里。

  7. swift语言IOS8开发战记22 Core Data3

    上一话我们定义了与coredata有关的变量和方法,做足了准备工作,这一话我们来试试能不能成功。首先打开上一话中生成的Info类,在其中引用头文件的地方添加一个@objc,不然后面会报错,我也不知道为什么。

  8. swift实战小程序1天气预报

    在有一定swift基础的情况下,让我们来做一些小程序练练手,今天来试试做一个简单地天气预报。然后在btnpressed方法中依旧增加loadWeather方法.在loadWeather方法中加上信息的显示语句:运行一下看看效果,如图:虽然显示出来了,但是我们的text是可编辑状态的,在storyboard中勾选Editable,再次运行:大功告成,而且现在每次单击按钮,就会重新请求天气情况,大家也来试试吧。

  9. 【iOS学习01】swift ? and !  的学习

    如果不初始化就会报错。

  10. swift语言IOS8开发战记23 Core Data4

    接着我们需要把我们的Rest类变成一个被coredata管理的类,点开Rest类,作如下修改:关键字@NSManaged的作用是与实体中对应的属性通信,BinaryData对应的类型是NSData,CoreData没有布尔属性,只能用0和1来区分。进行如下操作,输入类名:建立好之后因为我们之前写的代码有些地方并不适用于coredata,所以编译器会报错,现在来一一解决。

返回
顶部