最近在研究如何制作自己的.framework琅翻,在網(wǎng)上看了好多文章,但是寫的都不是很全柑贞,里面也不包括資源圖片方椎、第三方(如Masonry,AFN)和plist文件钧嘶,所以只能自己動(dòng)手了棠众。下面詳細(xì)介紹一下如何生帶有第三方、圖片有决、plist文件的.framework
一闸拿、制作.framework
1.首先,我們新建工程书幕,選擇Coco Touch Framework
2.使用CocoaPods導(dǎo)入Masonry和SVProgressHUD(這里以Masonry和SVProgressHUD為例),打開WQFramework.xcworkspace乐疆,可以看到我們的第三方已導(dǎo)入成功震鹉,接下來(lái)就要進(jìn)行一些配置了。(以上都是廢話,下面的才是重點(diǎn)G焖隆)
3.我們先創(chuàng)建兩個(gè)類道逗,WQClass :NSObject和WQView : UIView(我這里只是demo拇舀,在實(shí)際中可以把自己想要打包的文件都拉進(jìn)來(lái))变抽,我們?cè)赪QClass和WQView的.h中分別寫一個(gè)初始化方法,并在.m中實(shí)現(xiàn)方法掠抬。這里我們?cè)赪QView中導(dǎo)入我要使用的第三方,并使用他們吼野,我創(chuàng)建了兩個(gè)UIImageView,并給其中一個(gè)附上了圖片两波。并且我拉進(jìn)來(lái)一個(gè)plist文件瞳步,讀取并打印了它(這里是方便我們看一下打包framework時(shí),圖片和plist文件直接使用會(huì)出現(xiàn)什么問(wèn)題)
4.更改參數(shù)配置:
(1)選中?Target?腰奋,選擇?Build Settings?单起,在?Architectures?下增加?armv7s?。
(2)Build Active Architecture Only修改為NO劣坊,否則生成的靜態(tài)庫(kù)就只支持當(dāng)前選擇設(shè)備的架構(gòu)嘀倒。
(3)在搜索欄搜索?Mach-O Type?,將?Mach-O Type修改為?Static Library(靜態(tài)庫(kù))類型。
(4)選中?Target?测蘑,選擇?Build Phases?-?Headers?灌危,可以看出有三個(gè)選項(xiàng),分別是?Public 碳胳、Private 勇蝙、Project?,把需要公開給別人的?.h?文件拖到?Public?中挨约,把不想公開的味混,即為隱藏的?.h?文件拖到?Project?中。
5.完成上述步驟之后诫惭,在默認(rèn)生成的.h文件中翁锡,我的是WQFramework.h,把所有需要暴露的.h文件都用#import 引入贝攒,記住一定要將所有需要暴露的.h文件都引入盗誊,也就是上面Headers-Public中加的所有.h文件时甚,不然編譯后生成的.framework在引用的時(shí)候會(huì)有警告隘弊。
6.打包framework:分為真機(jī)和模擬器,這兩個(gè)生成的framework是不一樣的荒适。這里只進(jìn)行生成真機(jī)framework梨熙,個(gè)人感覺(jué)生成模擬器的.framework并沒(méi)什么卵用。(如果說(shuō)你需要生成一個(gè)既可以真機(jī)使用又可以模擬器使用的刀诬,那就分別生成咽扇,最后在合并在一起)。按照下圖將編譯的?Device?選擇為真機(jī) 陕壹,然后按下?Command + B?開始編譯质欲,編譯成功后右鍵?Products?文件夾下的?.framework?文件,點(diǎn)擊 Show in Finder糠馆。
重點(diǎn):我這時(shí)我編譯會(huì)報(bào)錯(cuò)嘶伟,把Build Active Architecture Only修改為YES,編譯就會(huì)成功又碌,這時(shí)再切換為NO編譯九昧,還是會(huì)成功。經(jīng)過(guò)總結(jié)Build Active Architecture Only為YES或者NO毕匀,導(dǎo)出framework后都正常使用铸鹰,親測(cè)!
7.測(cè)試打包完成的.framework皂岔,把生成的.framework導(dǎo)入測(cè)試項(xiàng)目json中蹋笼,測(cè)試framework中的WQClass類和WQView類。(注意:我們?cè)趂ramework中使用了Masonry和SVP,所以在測(cè)試項(xiàng)目json中剖毯,我們需要使用cocoapods導(dǎo)入這兩個(gè)第三方诞仓,不然會(huì)報(bào)錯(cuò)!)
可以看到速兔,我們制作的.framework成功了墅拭!可是別高興太早,我們?cè)趂ramework中使用的圖片并沒(méi)有顯示涣狗,讀取的plist文件打印也為空谍婉!接下來(lái)我們就需要處理framework中的圖片和plist文件了。
二镀钓、制作bundle
1.新建項(xiàng)目穗熬,選擇macOS ---> Bundle
2.因?yàn)锽undle默認(rèn)是macOS系統(tǒng)的,所以我們要修改他的屬性丁溅。
3.修改Build Setting中COMBINE_HIDPI_IMAGES屬性為NO唤蔗。否則Bundle圖片格式就會(huì)為tiff格式。
4.作為資源包只需要編譯就好窟赏,不需要安裝相關(guān)配置妓柜,設(shè)置Skip Install的值為YES,同時(shí)刪除Installation Directory的鍵值
5.把圖片拉進(jìn)Bundle中,選擇真機(jī)模式棍掐,command + B,右鍵Show in Finder拷况,可以看到我們生成的Bundle文件作煌。
6.把Bundle文件導(dǎo)入到我們的framework中,我們用到圖片的時(shí)候赚瘦,就取Bundle中的圖片來(lái)用粟誓。使用時(shí)注意,具體用法??
7.command + B起意,把新生成的framework重新導(dǎo)入demo中鹰服,并把Bundle也導(dǎo)入demo,運(yùn)行demo杜恰。(注意:如果demo中不導(dǎo)入Bundle获诈,圖片是不會(huì)顯示出來(lái)的)
這時(shí)可以看到,圖片可以顯示出來(lái)了心褐,說(shuō)明我們的Bundle制作成功了舔涎,圖片的問(wèn)題我們解決了,下面要解決plist文件了逗爹。其實(shí)根據(jù)我們Bundle的制作過(guò)程亡嫌,不難想到plist文件的使用原理嚎于。
三、plist文件的使用
1.其實(shí)plist文件的使用原理和圖片一樣挟冠,只不過(guò)圖片需要制作Bundle于购,而plist文件不需要。把plist文件拖進(jìn)framework中知染,重新編譯framework肋僧,把重新編譯的framework和plist文件都拖到demo中,這樣我們就可以打印出plist文件了控淡。
四、xib
如果你要打包的framework中包含xib掺炭,我們?cè)诔跏蓟痻ib時(shí)要這樣寫??辫诅,帶上你framework的名字。然后在我們的·測(cè)試demo中的Copy Bundle Resources中添加這個(gè)framework涧狮。
注意??:
1.?-ObjC:加了這個(gè)參數(shù)后炕矮,鏈接器就會(huì)把靜態(tài)庫(kù)中所有的 Objective-C 類和分類都加載到最后的可執(zhí)行文件中。
2.?-all_load:會(huì)讓鏈接器把所有找到的目標(biāo)文件都加載到可執(zhí)行文件中者冤,但是千萬(wàn)不要隨便使用這個(gè)參數(shù)肤视!假如你使用了不止一個(gè)靜態(tài)庫(kù)文件,然后又使用了這個(gè)參數(shù)譬嚣,那么你很有可能會(huì)遇到 ld: duplicate symbol 錯(cuò)誤钢颂,因?yàn)椴煌膸?kù)文件里面可能會(huì)有相同的目標(biāo)文件钞它,所以建議在遇到 -ObjC 失效的情況下使用 -force_load 參數(shù)拜银。
3.?-force_load:所做的事情跟 -all_load 其實(shí)是一樣的,但是 -force_load 需要指定要進(jìn)行全部加載的庫(kù)文件的路徑遭垛,這樣的話尼桶,你就只是完全加載了一個(gè)庫(kù)文件,不影響其余庫(kù)文件的按需加載锯仪。
出現(xiàn)錯(cuò)誤泵督!
今天在引入一個(gè)靜態(tài)framework庫(kù)時(shí)候,編譯遇到了“Can't map file, errno=22 file 'xxx' for architecture arm64(armv7)”問(wèn)題!
起因是我在主項(xiàng)目中庶喜,build setting-----》other linker flags 中-force_load了該framework庫(kù)
1小腊,找到引用項(xiàng)目的build setting----》build active architecture only ----》設(shè)置成NO
我原本就是no,所以結(jié)果沒(méi)啥用
2久窟,最后嘗試了這一種辦法
將主項(xiàng)目中other linker flages 中的-force_load "XXX.framework"改成“-force_load "XXX.framework/XXX”其中XXX是靜態(tài)庫(kù)名秩冈。
歡迎轉(zhuǎn)載,希望附上原創(chuàng)出處(本篇文章地址)原創(chuàng)不易斥扛,感謝大家支持入问!