2016-12-29 23:40:20 qq_16844001 阅读数 736

这里主要说几个关于cocoapods导入三方库需要注意的问题和我遇到的坑

1、Swift语言使用cocoapods配置Podfile文件时要加上use_framework!这句代码,作用是把三方库打包成静态库,具体为什么我也在研究。。。

2、swift调用oc的三方库

  a、要建立一个桥接文件,然后在target——>build setting中搜索bridg


Objective-C Bridging Header路径设置一下,一定要设置对,如果你的桥接文件不是和project工程文件在同一级项目目录中,要记得把你的文件所在的目录加进路径,一定要确保根据这个路径可以找到你的桥接文件。

  b、在桥接文件中引用你要调用的三方库的文件名,(这里有坑,我在下面会说明),然后你就可以愉快的使用的库了。在使用的文件中直接用,不用再次导入


3、调用oc三方库遇到的坑,这里我用AFNetWorking举例

  a、#import "AFNetWorking.h"之后要设置一个User Header Search Paths,否则在需要用三方库的地方是调不出来的。在target——>Build Setting里找到search Paths,双击User Header Search Paths后面的空白处,设置目录路径为${SRCROOT}   ,后边选择recursive。注意不要 #import <AFNetWorking/AFNetWorking.h>这样导入


  b、引用三方库的时候,需要在方法中或者声明为常量或者变量才能联想出这个库内的文件。只能说swift真的不是一般的严格。

2017-02-27 10:24:52 tongwei117 阅读数 671

本文主要记录了使用Swift打包带界面的framework的步骤
需求:打包一个framework提供其他应用植入。可以实现跳转(push或present)到framework的界面,然后再把拿到的数据返回到主界面。
准备阶段

  1. 使用Swift写好一个界面,运行测试成功后,留着备用(不建议使用xib,建议使用纯代码搭建界面) – 记得在需要外界引用的类用public修饰。
  2. 如果涉及到图片,先新建一个文件夹,把界面需要到的所有图片放到里面。然后修改文件夹后缀名 加上”.bundle”
  3. 将bundle包放在项目中,加载图片时,使用 userBGView.image = UIImage.init(name:”img.bundle/input_bg”) 这样的格式加载图片
    开始打包 framework
    1 新建工程,选择framework
    这里写图片描述
    2 把之前运行好的程序的文件和 Bundle图片包,直接拖拽到项目中
    这里写图片描述
    3 点击 Target – Build Phase – Headers, 把所有需要引用的文件拖拽到public中去,如果没有看到该文件,可以点击 + 号选择(包括OC的.h文件)
    这里写图片描述
    4 在 xxxx(framework项目名).h文件中,导入OC的.h文件(如果不涉及OC文件,这个步骤可以省略)
    这里写图片描述

5 把之前写好的界面里面的所有图片加载方式加上 “xxx(项目名称).framework”前缀(这一步骤很重要,不然图片会加载失败)
之前是: userBGView.image = UIImage.init(named:”img.bundle/input_bg”)
修改成:userBGView.image = UIImage.init(name:”KyyLoinView.framework/img.bundle/input_bg”)
6 选择 Eidit Scheme – Run – Build Configuration
根据需求编译所需的 framework格式,一般都是两种 : debug – 模拟器 或者 release – 真机
这里写图片描述
7 选择完毕后,command + B 编译,然后会看到Products 中的framework变成黑色了,右键点击 show in finder,可以直接拿到framework使用
这里写图片描述
到这里,整个制作 framework的过程就全部完成了

下面,简单介绍一下怎么使用
1 打开你需要导入的framework项目,把之前制作好的framework复制到这个项目的文件中
这里写图片描述
2 在这个项目的Target中,点击General – Embedded Binaries 点击 + 号,然后点击 “Add Other …”,找到你刚才复制framework的目录中,选择framework
然后你会在 Embedded Binaries 和 Linked Framework Library 中看到这个 framework
这里写图片描述
3 点击 Target – Build Phases 中的Copy Bundle Resource,点击 + 号,选择你的framework
这里写图片描述
ok, 到这里,已经加载 framework完毕了,编译试试
然后直接import引用framework , 之后就可以直接使用之前public出来的类了。

遇到坑点

  1. 使用xib
    解决方法:放弃使用xib搭建界面,使用纯代码。

  2. 加载framework的时候无法引用public的类
    解决方法:在制作framework的时候,记得“第3步”把所需要引用的类拖拽到public中去

  3. 图片加载不出来
    解决方法:记得在加载图片时候,加上“xxx.framework/”的前缀。

其他参考资料:

http://www.cnblogs.com/yajunLi/p/5987687.html
2018-04-10 14:20:56 ws_752958369 阅读数 2299

  随着Swift潮流声越来越近大,行业发展趋向于开源,逼着我们去学习更多知识。废话不多说,下面开始介绍如何以正确的姿势导入第三方库文件。

  学习过Objective-C的同学肯定会知道,一般会有三种方式导入第三方库,分别是:cocoasPod管理工具,打包成framwork导入,直接导入原文件。然而,swift是苹果在oc基础上研发的一种新语言且开源,当然也继承之前的优良传统。同样的也有三种方式。下面主要介绍导入源文件方式手动管理方式。

1.首先拖入第三方文件夹到工程目录下自定义文件夹下,如图分别导入了Alamofire,SnapKit,SDWebImage

2.如果导入的库swift编写那没什么,如果是oc编写,那么还需要生成一个oc-swift桥接文件,如上图Header.h(新建一个Header file)。

3.在headerFile中引入第三方库头文件,例如:#import "UIImageView+WebCache.h"

4.配置工程设置,Build Settings -> 搜索 Other Linker Flags 添加 "-Objc"

5.由于导入的头文件HeaderFile没有配置相对路径,编译时可能会报错。Build Setting -> Swift Compiler - Genneral -> Objective-C Bridging Header 在这里添加刚才添加的“头文件”路径,这里建议写相对路径,避免工程在另外一个电脑环境时候报错,找不到路径。用“$SRCROOT”表示当前工程的根目录,这里我直接放在根目录下,所以路径为 $SRCROOT/Header.h.

  到这里,所有的准备工作已经大功告成。开始疯狂的编码吧。

  下面是自动布局框架SnapKit的简单应用,写法类似于OC中masonry(同一个团队研发)。


2017-06-08 15:15:44 boring_cat 阅读数 1273

在iOS8之后 应用要上appstore就开始支持动态库了 所以做动态库是一大趋势。
swift做动态库framework用cocoapods管理的时候 在工程里要用到“use_frameworks!” 这句话
这句的作用是 将cocoapods引用的静态库转为动态库使用
如果不这么做的话 你做成的framework拿去使用的时候 将会出现这样的错误:
dyld: Library not loaded: /Library/Frameworks/xxxx.framework/xxxx

Referenced from: /var/containers/Bundle/Application/B0936ED2-FB82-4487-AE21-A1185AA36EF9/TestXXXXX.app/XXXXX

Reason: image not found

无法加载的情况。
一定要注意!

platform :ios, '8.0'
use_frameworks!

def shared_pods

  pod 'IQKeyboardManagerSwift'
  pod 'CRUtility'
  pod 'Reachability','~> 3.2.0'
  pod 'MBProgressHUD', '~> 1.0.0’
  pod 'SocketRocket', '~> 0.4.2'
  pod 'SBJson', '~> 4.0.2'
  pod 'CocoaLumberjack', :configurations => ['Debug']
#  pod 'WebRTC'
end

target 'ZYRTC' do
  workspace 'ZYRTCWorkspace’
  project 'ZYRTC/ZYRTC.xcodeproj’
  shared_pods
end

target 'ZYRTCApp' do
  workspace 'ZYRTCWorkspace'
  project 'ZYRTCApp/ZYRTCApp.xcodeproj’
  shared_pods
end
2016-02-17 17:24:54 maindek 阅读数 1059

第一步:创建和配置Bridging-Header.h

Swift与OC进行混编,首先要有一个.h文件,这里使用Bridging-Header.h然后设置项目的Build Settings--Swift Compiler--Objective-C Bridging Header内容为DemoApp/Bridging-Header.h,这个与Bridging-Header.h位置有关,从项目的根目录开始在Objective-C Bridging Header选项里面写入Bridging-Header.h相对路径。


第二步:第三方项目依赖

对于第三方项目的依赖,一开始我打算用CocoaPods,但是过程曲折,最后一直报

[objc] view plain copy
 print?在CODE上查看代码片派生到我的代码片
  1. <span style="font-size:14px;">ld: 218 duplicate symbols for architecture i386  
  2. clang: error: linker command failed with exit code 1 (use -v to see invocation)</span>  
我也没有办法了就把第三方项目源码拷贝到自己的项目里面,上图也可以看到我拷贝的事AFNetworking项目,然后在把源码加入到Build Phases--Compile Sources里面

第三步:修改Bridging-Header.h

在Bridging-Header.h中写入#import "AFNetworking.h"

第四步:调用OC

前面的工作做完后我们就可以调用第三方项目的功能了

[objc] view plain copy
 print?在CODE上查看代码片派生到我的代码片
  1. //  
  2. //  ViewController.swift  
  3. //  DemoApp  
  4. //  
  5. //  Created by jiezhang on 14/10/24.  
  6. //  Copyright (c) 2014年 jiezhang. All rights reserved.  
  7. //  
  8.   
  9. import UIKit  
  10.   
  11. class ViewController: UIViewController {  
  12.   
  13.     @IBOutlet weak var weatherInfo: UITextView!  
  14.     override func viewDidLoad() {  
  15.         super.viewDidLoad()  
  16.         updateWeatherInfo()  
  17.     }  
  18.   
  19.     override func didReceiveMemoryWarning() {  
  20.         super.didReceiveMemoryWarning()  
  21.         // Dispose of any resources that can be recreated.  
  22.     }  
  23.   
  24.       
  25.     func updateWeatherInfo() {  
  26.         let manager = AFHTTPRequestOperationManager()  
  27.         let url = "http://api.openweathermap.org/data/2.5/weather"  
  28.         println(url)  
  29.         let params:NSDictionary = ["lat":"37.785834""lon":"-122.406417""cnt":0]  
  30.         println(params)  
  31.         manager.GET(url,  
  32.             parameters: params,  
  33.             success: { (operation: AFHTTPRequestOperation!,  
  34.                 responseObject: AnyObject!) in  
  35.                 self.weatherInfo.text = "JSON: " + responseObject.description!  
  36.             },  
  37.             failure: { (operation: AFHTTPRequestOperation!,  
  38.                 error: NSError!) in  
  39.                 self.weatherInfo.text = "Error: " + error.localizedDescription  
  40.                  
  41.         })  
  42.     }  
  43.   
  44. <p>}</p>  

第五步:运行界面


没有更多推荐了,返回首页