V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
stephenliubp
V2EX  ›  iOS

工程大小优化之图片资源

  •  1
     
  •   stephenliubp · 2017-12-13 17:12:33 +08:00 · 1769 次点击
    这是一个创建于 2578 天前的主题,其中的信息可能已经有所发展或是发生改变。

    工程大小优化之图片资源

    _摘要:_点点 iOS 项目本身功能较多,导致应用体积也比较大。一个 Xcode 工程下图片资源占用了很大的空间,且如果有些 App 需要一键换肤功能,呵呵,不知道得做多少图片。每套图片还需要设置 1x@,2x@,3x@等

    简介

    IconFont 技术起源于 Web 领域的 Web Font 技术。随着时间的推移,网页设计越来越漂亮。但是电脑预装的字体远远无法满足设计者的要求,于是 Web Font 技术诞生了。一个英文字库并不大,通过网络下载字体,完成网页的显示。有了 Web Font 技术,大大提升了设计师的发挥空间。

    网页设计中图标需要适配多个分辨率,每个图标需要占用一次网络请求。于是有人想到了用 Web Font 的方法来解决这两个问题,就是 IconFont 技术。将矢量的图标做成字体,一次网络请求就够了,可以保真缩放。解决这个问题的另一个方式是图片拼合的 Sprite 图。

    Web 领域使用 IconFont 类似的技术已经多年,当我在 15 年接触 BootStrap 的时候 Font Awesome 技术大行其道。最近 IconFont 技术在 iOS 图片资源方面得以应用,最近有点时间自己研究整理了一番,在此记录学习点滴。

    优点

    • 减小体积,字体文件比图片要小
    • 图标保真缩放,解决 2x/3x 乃至将来的 nx 图问题
    • 方便更改颜色大小,图片复用

    缺点

    • 只适用于 纯色 icon
    • 使用 unicode 字符难以理解
    • 需要维护字体库

    网上说了一大堆如何制作 IconFont 的方法,在此不做讨论。

    我们说说怎么用

    1. 首先选取一些有丰富资源的网站,我使用阿里的 IconFont 多年,其他的没去研究,所以此处直接使用阿里的产品。地址:http://www.iconfont.cn/plus
    2. 打开网站在线挑选好合适的图标加入购物车,如图![阿里 IconFont]( https://raw.githubusercontent.com/FantasticLBP/iOSKonwledge-Kit/master/assets/屏幕快照%202017-05-28%20 下午 2.43.33.png "阿里 IconFont")
    3. 选择好之后在购物车查看,然后点击下载代码![下载 IconFont]( https://raw.githubusercontent.com/FantasticLBP/iOSKonwledge-Kit/master/assets/屏幕快照%202017-05-28%20 下午 2.43.48.png "下载 IconFont")
    4. 打开下载好的文件,其机构如下,我们在 iOS 项目开发过程中使用 unicode 的形式使用 IconFont,所以打开 demo_unicode.html ![下载文件目录结构]( https://raw.githubusercontent.com/FantasticLBP/iOSKonwledge-Kit/master/assets/屏幕快照%202017-05-28%20 下午 2.44.09.png "下载文件目录结构") ![unicode 形式使用 IconFont]( https://raw.githubusercontent.com/FantasticLBP/iOSKonwledge-Kit/master/assets/屏幕快照%202017-05-28%20 下午 2.44.22.png "unicode 形式使用 IconFont")
    5. 注意:创建 UIFont 使用的是字体名,而不是文件名;文本值为 8 位的 Unicode 字符,我们可以打开 demo.html 查找每个图标所对应的 HTML 实体 Unicode 码,比如: "店" 对应的 HTML 实体 Unicode 码为:0x3439 转换后为:\U00003439 就是将 0x 替换为 \U 中间用 0 填补满长度为 8 个字符

    Xcode 中使用 IconFont

    初步尝试使用

    1. 首先看看如何简单实用 IconFont
    2. 首先将下载好的文件夹中的iconfont.ttf加入到 Xcode 工程中,确保加入成功在 Build 检查![Xcode 检查引入结果]( https://raw.githubusercontent.com/FantasticLBP/iOSKonwledge-Kit/master/assets/屏幕快照%202017-05-28%20 下午 2.51.36.png "Xcode 检查引入结果")
    3. 怎么用?
    NSMutableAttributedString *attributedStr = [[NSMutableAttributedString alloc] initWithString:@"\U0000e696  \U0000e6ab  \U0000e6ac  \U0000e6ae"];
        [attributedStr addAttribute:NSForegroundColorAttributeName value:[UIColor redColor] range:NSMakeRange(0, 1)];
        [attributedStr addAttribute:NSForegroundColorAttributeName value:[UIColor orangeColor] range:NSMakeRange(3, 1)];
        [attributedStr addAttribute:NSForegroundColorAttributeName value:[UIColor blackColor] range:NSMakeRange(9, 1)];
        self.label.attributedText = attributedStr;
    
    [self.view addSubview:self.label];
    
    pragma mark - getter and setter
    -(UILabel *)label{
           if (!_label) {
               _label = [[UILabel alloc] initWithFrame:CGRectMake(100, 100, BoundWidth-200, 40)];
               _label.font = [UIFont fontWithName:@"iconfont" size:24];
               _label.textColor = [UIColor purpleColor];
           }
           return _label;
       }
    

    做进一步封装,实用更加方便

    利用 IconFont 生成 1 个 UIImage 只需要**LBPIconFontmake(par1, par2, par3)**,par1:iconfont 的 unicode 值; par2:图片大小; par3:图片的颜色值。

    其中,LBPIconFontmake 是一个宏,#define LBPIconFontmake(text,size,color) [[LBPFontInfo alloc] initWithText:text withSize:size andColor:color]。

    self.latestImageView.image = [UIImage iconWithInfo:LBPIconFontmake(@"\U0000e6ac", 60, @"000066") ];
    

    ![封装后的工程目录结构]( https://github.com/FantasticLBP/iOSKonwledge-Kit/raw/master/assets/屏幕快照%202017-05-28%20 下午 2.56.00.png "封装后的工程目录结构")

    1. LBPFontInfo 来封装字体信息
    2. UIColor+picker 根据十六进制字符串来设置颜色
    3. LBPIconFont 向系统中注册 IconFont 字体库,并使用
    4. UIImage+LBPIconFont 封装一个使用 IconFont 的 Image 分类

    效果图

    ![效果图]( https://raw.githubusercontent.com/FantasticLBP/iOSKonwledge-Kit/master/assets/Simulator%20Screen%20Shot%202017 年 5 月 28 日%20 下午 3.19.44.png "效果图")

    Demo 地址

    https://github.com/FantasticLBP/IconFont_Demo

    sherblue
        1
    sherblue  
       2017-12-14 10:18:19 +08:00
    FontAwesomeKit 配合 https://icomoon.io/app/ 制作字体也是美滋滋。
    stephenliubp
        2
    stephenliubp  
    OP
       2017-12-14 13:43:48 +08:00
    稳啊,猜了猜 FontAwesomeKit 的实现估计和我这个原理差不多,然后用 Swift 和 OC 包装了一下
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1833 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 16:26 · PVG 00:26 · LAX 08:26 · JFK 11:26
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.