iOS 縮小打包項(xiàng)目ipa大小的實(shí)現(xiàn)方法
之前項(xiàng)目上線完全由技術(shù)老大搞,這次獨(dú)立開發(fā)自己來,覺得自己的打包項(xiàng)目體積略大,網(wǎng)上搜索了一些比較不錯(cuò)的方法,這里總結(jié)下。
1、配置編譯選項(xiàng) (Levels選項(xiàng)內(nèi))Genetate Debug Symbols 設(shè)置為NO,這個(gè)配置選項(xiàng)應(yīng)該會(huì)讓你減去小半的體積。
2、舍棄架構(gòu)armv7,因?yàn)閍rmv7用于支持4s和3gs,4s是2011年11月正式上線,雖然還有小部分人在使用,但是追求包體大小的完全可以舍棄了。
3、編譯的版本必須是發(fā)布版本,
4、查找內(nèi)部使用到的第三方庫,一方面可以進(jìn)行刪減代碼,用不到的類,直接刪除,還有第三方庫中的圖片資源統(tǒng)統(tǒng)刪除掉,如果能夠自己手寫實(shí)現(xiàn)的,那費(fèi)功夫自己寫吧
單單上面的幾個(gè)操作全部完成的話,項(xiàng)目一般能驚人小了很多。
其他的資源相關(guān):
圖片
壓縮圖片 不重要的圖片可適當(dāng)采用 8bit PNG圖片
1.什么是矢量圖 矢量圖是由計(jì)算機(jī)的算法產(chǎn)生的,可以無限放大或縮小,不會(huì)有任何損失,通常由矢量軟件制作。
2.什么是位圖 位圖是由一個(gè)一個(gè)的小色塊組成,放大后會(huì)看到那些小色塊,同一面積內(nèi)小色塊越多,分辨率就越高。
3.矢量圖的優(yōu)缺點(diǎn) 可以無限放大或縮小,不會(huì)影響圖像素質(zhì),文件體積較小,編輯靈活。缺點(diǎn)是表達(dá)的色彩層次不清,整體觀感效果不如位圖
4.位圖的優(yōu)缺點(diǎn) 不能放太大,減少文件分辨率后會(huì)影響圖片質(zhì)量,圖片戰(zhàn)勝空間較大,優(yōu)點(diǎn)是能很細(xì)膩地表達(dá)圖片的效果,圖片表達(dá)效果非常好
5.什么情況下用位圖,什么情況下用矢量圖 一些對(duì)圖片要求高的用位圖,例如照片。其他的盡量用矢量圖。例如文字、表格、卡通圖片等
去掉無用的圖片
用代碼繪制簡(jiǎn)單的純色圖片 用Sketch和PaintCode快速得到繪制代碼
如果不需要使用透明,可以用jpeg代替PNG。jpeg減少了些效率但更加小。需權(quán)衡性能,大小。
對(duì)32位的圖片,盡肯能的使用高壓縮率,使用PS的“Save For Web”功能,可以有效的減小JPEG和PNG圖片的尺寸。 默認(rèn)情況下,在build時(shí),PNG圖像就被pngcrush壓縮。
音頻
壓縮音頻,盡可能使用AAC或者M(jìn)P3格式,并且使用一個(gè)較低的碼率。通常44.1khz的碼率有點(diǎn)浪費(fèi),降低一定的碼率也不會(huì)丟失多少音質(zhì)
視頻
視頻也可以使用類似于音頻的處理方法,音視頻的壓縮可以很大程度的壓縮,但是要注意壓縮的格式,是不是會(huì)增加編解碼的負(fù)擔(dān),這要權(quán)衡考慮。
Assets
檢查bundle中的無用文件,不要打包到app或者靜態(tài)庫中??梢渣c(diǎn)擊文件,在右側(cè)的file inspector里面的target membership中取消勾選;或者在build phase里面的Copy Bundle Resources中去掉。
確定 dead code(代碼被定義但從未被調(diào)用)被剝離,build setting 里 DEAD_CODE_STRIPPING = YES。 去掉冗余的代碼,即使一點(diǎn)冗余代碼,編譯后體積也是很可觀的。
以上這篇iOS 縮小打包項(xiàng)目ipa大小的實(shí)現(xiàn)方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
iOS用AutoLayout實(shí)現(xiàn)分頁滾動(dòng)功能
這篇文章主要給大家介紹了關(guān)于iOS用AutoLayout實(shí)現(xiàn)分頁滾動(dòng)功能的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)各位iOS開發(fā)者們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06
iOS 水波紋動(dòng)畫的實(shí)現(xiàn)效果
本篇文章主要介紹了iOS 水波紋的實(shí)現(xiàn)的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-01-01
Objective-C 經(jīng)典字典數(shù)組排序 - 省市區(qū)
本文主要介紹Objective-C 字典數(shù)組排序,這里整理相關(guān)資料及實(shí)現(xiàn)示例代碼,有興趣的小伙伴可以參考下2016-09-09
IOS Ble藍(lán)牙開發(fā)實(shí)現(xiàn)方法
這篇文章主要為大家詳細(xì)介紹了IOS Ble藍(lán)牙開發(fā)的實(shí)現(xiàn)方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12
IOS設(shè)置UIView的邊框?yàn)閳A角詳解及實(shí)例
這篇文章主要介紹了IOS設(shè)置UIView的邊框?yàn)閳A角的相關(guān)資料,需要的朋友可以參考下2017-03-03
iOS移動(dòng)端軟鍵盤彈起空白和滾動(dòng)穿透問題解決方案
這篇文章主要為大家介紹了iOS移動(dòng)端軟鍵盤彈起空白和滾動(dòng)穿透問題解決方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
ios實(shí)現(xiàn)tableView頂部彈簧圖片效果
這篇文章主要為大家詳細(xì)介紹了ios實(shí)現(xiàn)tableView頂部彈簧圖片效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08

