App压缩方案 3+1,轻松搞定20M限制

2024-02-08 14:58

本文主要是介绍App压缩方案 3+1,轻松搞定20M限制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转自: http://www.aiw3.com/iphone/0504969.html

 

App压缩方案 3+1,轻松搞定20M限制

 

方案一:
使用高效的png图片压缩软件,先对所有图片进行一次瘦身。

这里推荐一款Mac下的图片压缩软件--ImageOptim。方便试用,只要简单的把要压缩的文件或者文件夹拖到软件里,它就会自动压缩。
注意:1。不用特意去塞选,因为它会自动识别文件格式,非图片格式的它不会进行处理,所以不用担心,尽管拖!~
    2。压缩的时候它会覆盖原文件,所以担心原文件损坏的童鞋,请自己注意备份。不过到目前为止,没有发现它有什么问题
    3。压缩之后的图片可能会出现无法预览的情况,不用担心,照样编译,照样成功!
    4。压缩率的问题还要看具体的图片文件而定,一般情况平均压缩率在50%以上,最高的见过94%的。哈~
    5。最后提醒一点,可以反复对一系列图片进行多次压缩,以寻求最大压缩率,压到不能再压缩的时候会显示“X”,所以请放心使用!


方案二:
对音乐音效进行降噪处理,还有注意使用的音乐格式!

音乐这块我并不在行,所以不便多评,现在市面上音乐处理软件很多,功能也异常强大。处理建议就是,用尽一切方法让他变小,
只要自己听的不难受就好!

注:我们自己项目中音乐文件本来有20M多。后来经过一系列处理后只有800K!!更重要的是,一般人根本没听出差别!
所以音乐压缩非常有必要!!


方案三:
在以上两点都处理过后,如果还没有达到您的要求。(如,处理后大小21M左右,差一点咯!)可以进行最后一步,也是技术性的压缩。
使用Zip压缩技术,对资源文件中的图片及音乐进行压缩。


首先下载一个zip开源类,网上很多。我用的是--ZipFile-OC。好像也叫minizip。这个开源类是专门针对Obj-C写的。封装的比较好,用法很简单。
http://linglong117.blog.163.com/blog/static/277145472009101814159283/)转至云水蝉心的日志。该日志介绍了两种zip方法,我使用的是第二种。
文章末尾有附上ZipFile-OC的下载。具体的就不再重复啦。请看原著。~在此也鸣谢云水蝉心。

下面主要说下如何实现压缩资源。


先来看下,Xcode是如何处理Resources中的文件的,只要在工程中找到编译好的app文件,右键显示包内容,就会发现,Xcode在编译的时候会将 Resources里的文件,一个个从各自的文件夹中取出来复制到app中供程序调用。

而我们要做的就是将这些文件事先取出并压缩成zip。然后删除原有的资源,将压缩后的zip文件放入Resources进行编译。注意,不可有文件夹,所有的图片及音乐都必须在同一个目录下被压缩。

这里我们会遇到一个问题,那就是如何在程序读取这些图片的时候,把他们解压出来呢?
注意一个问题,苹果是不运行开发者在程序中修改app文件的。所以必须找一个可修改的文件夹存放解压出来的文件。那就是Document的文件夹(每个应用都有次文件夹)。

只要在程序读取资源之前(这个位置取决于你程序代码如何写,应该不用我多说吧),解压所需的资源文件到Document目录下,然后修改读取资源的地址即可。

 

为方便新手理解。附上代码。以一个Cocos2d框架的游戏为例。
在以下函数开头加入Zip代码。

- (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
    NSArray *paths =NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask,YES);
    NSString *documentsDirectory = [paths objectAtIndex:0]; //前两句为获取Documents在真机中的地址
    NSString *imagePath = [documentsDirectorystringByAppendingPathComponent:@"/某一个资源名"];
    //获取某一个资源解压之后的地址,特别注意“/”不可少。 该文件地址将作为判断资源是否压缩过的依据,以免重复解压。

    NSData* data = [ NSData dataWithContentsOfFile:imagePath];

    if(data == NULL) //如果标志文件不存在,则表面程序第一次运行,则解压所需资源文件,若存在则跳过。
    {

        NSString *loadImagePath = [[documentsDirectorysubstringToIndex:documentsDirectory.length-9]stringByAppendingPathComponent:@"项目名(Product Name)/ 压缩文件名(*.zip)"];//获取资源中的压缩文件

        ZipArchive *za = [[ZipArchive alloc] init];

        if( [za UnzipOpenFile:loadImagePath] ) //解压
        {
            BOOL ret = [za UnzipFileTo:documentsDirectory overWrite:YES];
            if( NO==ret )
            {
            }
            [za UnzipCloseFile];
        }

        [za release];

    }
/*省略其余代码*/
    return Yes;
}



大家不用担心这个解压过程会很长,粗略估计20M的压缩文件耗时不到3秒,而且只需程序第一次运行时等待,之后就不会再解压。


剩下要做的就是修改原本的资源路径。这里不知道能否再Xcode中直接修改。


我们采用的是最直接也许最笨的方法,就是直接修改图片及音乐处理的底层类。还是拿cocos2d为例。


在TextureMgr.m类中修改addImage(-(Texture2D*) addImage: (NSString*) path;)方法。只要在前面加上以下三句话。


NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,    NSUserDomainMask, YES);
    NSString *documentsDirectory = [pathsobjectAtIndex:0];

    path = [[documentsDirectorystringByAppendingPathComponent:@"/"] stringByAppendingPathComponent:path];
这三句话的作用就是在一个文件名前面加上Documents文件夹的路径。



注意:1。切勿将icon.png/*.plist/Defalut.png等系统及框架资源放入压缩包。
    2。若已使用前两种方案,则此方案可压缩的效率有限。


最后说一种方案。
那就是苹果自带的zip压缩。这可能很多发布过项目的朋友就会知道,在发布前,要将app文件压缩成zip后方可上传。而这一步至少可以剩下6M的空间。

注:在实际操作的时候发现,如果一个项目压缩成zip之后有20M,那么发布之后,会变成21.2M左右。这多出来的1.2M不知是否是苹果在其中放了什么所致呢?

*以下引用6L的解答~
多出的1.2M主要是苹果进行验证签名用的,进行账号收费绑定的。也就是说,不同账号用Itunes下载的同一个app都是不一样的。
在此表示感谢哈~~学习咯!

最后,附上一个实际测试的数据:
一个未经任何处理的app,大小约为50M+。其中图片资源占18M。音乐资源占27M。有6M左右被OpenFeint占据(网上载的大约12M,最后导进去的资源3M左右,剩下的3M应该在编译文件中)。
经过前两个方案处理后,图片仅剩10M不到,音乐只有区区1M(也许在专业设备下音质会差,但还是那句话,相信我,一般人根本听不出来)。OpenFeint并没有进行处理,依然是6M。最后编译出的app为22.4M.经过Zip压缩后再加上苹果的签名验证(即第四个方案)。最后的大小仅16.5M。

这篇关于App压缩方案 3+1,轻松搞定20M限制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/691376

相关文章

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

go动态限制并发数量的实现示例

《go动态限制并发数量的实现示例》本文主要介绍了Go并发控制方法,通过带缓冲通道和第三方库实现并发数量限制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录带有缓冲大小的通道使用第三方库其他控制并发的方法因为go从语言层面支持并发,所以面试百分百会问到

小白也能轻松上手! 路由器设置优化指南

《小白也能轻松上手!路由器设置优化指南》在日常生活中,我们常常会遇到WiFi网速慢的问题,这主要受到三个方面的影响,首要原因是WiFi产品的配置优化不合理,其次是硬件性能的不足,以及宽带线路本身的质... 在数字化时代,网络已成为生活必需品,追剧、游戏、办公、学习都离不开稳定高速的网络。但很多人面对新路由器

SpringBoot+EasyPOI轻松实现Excel和Word导出PDF

《SpringBoot+EasyPOI轻松实现Excel和Word导出PDF》在企业级开发中,将Excel和Word文档导出为PDF是常见需求,本文将结合​​EasyPOI和​​Aspose系列工具实... 目录一、环境准备与依赖配置1.1 方案选型1.2 依赖配置(商业库方案)二、Excel 导出 PDF

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4

MySQL 迁移至 Doris 最佳实践方案(最新整理)

《MySQL迁移至Doris最佳实践方案(最新整理)》本文将深入剖析三种经过实践验证的MySQL迁移至Doris的最佳方案,涵盖全量迁移、增量同步、混合迁移以及基于CDC(ChangeData... 目录一、China编程JDBC Catalog 联邦查询方案(适合跨库实时查询)1. 方案概述2. 环境要求3.

SpringBoot3.X 整合 MinIO 存储原生方案

《SpringBoot3.X整合MinIO存储原生方案》本文详细介绍了SpringBoot3.X整合MinIO的原生方案,从环境搭建到核心功能实现,涵盖了文件上传、下载、删除等常用操作,并补充了... 目录SpringBoot3.X整合MinIO存储原生方案:从环境搭建到实战开发一、前言:为什么选择MinI

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.