標籤:
之前項目上線完全由技術老大搞,這次獨立開發自己來,覺得自己的打包項目體積略大,網上搜尋了一些比較不錯的方法,這裡總結下
1、配置編譯選項 (Levels選項內)Genetate Debug Symbols 設定為NO,這個配置選項應該會讓你減去小半的體積。
2、捨棄架構armv7,因為armv7用於支援4s和3gs,4s是2011年11月正式上線,雖然還有小部分人在使用,但是追求包體大小的完全可以捨棄了。
3、編譯的版本必須是發布版本,
4、尋找內部使用到的第三方庫,一方面可以進行刪減代碼,用不到的類,直接刪除,還有第三方庫中的圖片資源統統刪除掉,如果能夠自己手寫實現的,那費功夫自己寫吧
單單上面的幾個操作全部完成的話,項目一般能驚人小了很多。
其他的資源相關:
圖片
壓縮圖片 不重要的圖片可適當採用 8bit PNG圖片
1.什麼是向量圖 向量圖是由電腦的演算法產生的,可以無限放大或縮小,不會有任何損失,通常由向量軟體製作。
2.什麼是位元影像 位元影像是由一個一個的小色塊組成,放大後會看到那些小色塊,同一面積內小色塊越多,解析度就越高。
3.向量圖的優缺點 可以無限放大或縮小,不會影響映像素質,檔案體積較小,編輯靈活。缺點是表達的色彩層次不清,整體觀感效果不如位元影像
4.位元影像的優缺點 不能放太大,減少檔案解析度後會影響圖片品質,圖片戰勝空間較大,優點是能很細膩地表達圖片的效果,圖片表達效果非常好
5.什麼情況下用位元影像,什麼情況下用向量圖 一些對圖片要求高的用位元影像,例如照片。其他的盡量用向量圖。例如文字、表格、卡通圖片等
去掉無用的圖片
用代碼繪製簡單的純色圖片 用Sketch和PaintCode快速得到繪製代碼
如果不需要使用透明,可以用jpeg代替PNG。jpeg減少了些效率但更加小。需權衡效能,大小。
對32位的圖片,盡肯能的使用高壓縮率,使用PS的“Save For Web”功能,可以有效減小JPEG和PNG圖片的尺寸。 預設情況下,在build時,PNG映像就被pngcrush壓縮。
音頻
壓縮音頻,儘可能使用AAC或者MP3格式,並且使用一個較低的碼率。通常44.1khz的碼率有點浪費,降低一定的碼率也不會丟失多少音質
視頻
視頻也可以使用類似於音訊處理方法,音視頻的壓縮可以很大程度的壓縮,但是要注意壓縮的格式,是不是會增加編解碼的負擔,這要權衡考慮。
Assets
檢查bundle中的無用檔案,不要打包到app或者靜態庫中。可以點擊檔案,在右側的file inspector裡面的target membership中取消勾選;或者在build phase裡面的Copy Bundle Resources中去掉。
確定 dead code(代碼被定義但從未被調用)被剝離,build setting 裡 DEAD_CODE_STRIPPING = YES。 去掉冗餘的代碼,即使一點冗餘代碼,編譯後體積也是很可觀的。
轉自:http://blog.5ibc.net/p/88743.html
iOS 如何縮小打包項目ipa大小