1.   背景

PaintCode是一款面向iOS和Mac应用开发者及设计师的矢量图形可视化开发工具。它可以让设计师把设计好的psd文件直接导入该工具,然后生成用Quartz 2D 产生的object-c代码。直接供程序员使用,而省略了图片资源。

1.1主要功能

  1. 直接生成适用于iOS的Objective-C代码,节省了大量的编程时间。
  2. 生成的代码支持ARC/MRC,iOS5+/6+/7+.
  3. 可以控制图片生成的Frame、颜色等变量来动态生成需要所需要的图片。

1.2 相关资料:

官网:http://www.paintcodeapp.com/

http://blog.csdn.net/lujunelong/article/details/18899913

2.   实验数据

2.1实验一:复杂图片

背景:采用一张较为复杂的图片, 400*400。体积为:37k。

只提供了2X的图片(已压缩);支持armv7 armv7s arm64。

 

paintCode

UIImage

安装包大小

342k

379k

占用内存

3.4M

3.8M

real mem:

12.25M

13.3M

耗时

0.054807(跟踪发现就一个地方耗时)

0.0087

描述:

  1. 安装包大小在paintCode下有明显减小(即使已经支持了arm64,仍然能减小,且图片还没有支持1x和3x的图片效果明显)
  2. real men和占用内存paintCode都有明显减小
  3. 耗时有较大提升。性能差距加大。

2.2 实验二:简单图片

背景:采用一张较为简单的图片, 224*90。体积为:2k。

安装包大小

paintCode(armv7 armv7s arm64)

UIImage(armv7 armv7s arm64)

1份代码or图片

380k

381k

3份代码or图片

396k

385k

安装包大小

paintCode(armv7)

UIImage(armv7)

1份代码or图片

215k

217k

3份代码or图片

216k

221k

描述:

  1. 如果仅仅是打armv7的包,使用paintCode安装包大小有减小。有收益。
  2. 针对简单图片做了3份,使用paintCode在同时支持arm64的情况下,体积收益不一定要大于使用图片。

2.3 实验三:耗时测试

背景: 复杂图片就如实验一,简单图片资源参考图片二

方式

耗时(秒)

简单button的paintCode

0.006329

imageWithContentsOfFile

0.000797

imageNamed(第一次)

0.009291

复杂paintCode

0.061804

描述:

  1. 复杂的paintCode耗时会较长。
  2. 简单button的PaintCode耗时数量级在毫秒级
  3. 一份代码可以支持多个屏幕,针对Iphone6,iphont6+没有体积增加。
  4. 显示效果较好,矢量拉伸。
  5. 有效减小内存使用。
  6. 在复杂大图下,可以有效减少安装包大小。
  7. 如果针对armv7 arm64进行编译,跟直接使用图片比浪费体积。
  8. 生成UIImage耗时比使用直接图片时间长。

3.   风险点&优势

3.1 优势

  1. 一份代码可以支持多个屏幕,针对Iphone6,iphont6+没有体积增加。
  2. 显示效果较好,矢量拉伸。
  3. 有效减小内存使用。
  4. 在复杂大图下,可以有效减少安装包大小。
  5. 如果针对armv7 arm64进行编译,跟直接使用图片比浪费体积。
  6. 生成UIImage耗时比使用直接图片时间长。

3.2 劣势

  1. 如果针对armv7 arm64进行编译,跟直接使用图片比浪费体积。
  2. 生成UIImage耗时比使用直接图片时间长。

4.   进一步优化

为了解决耗时问题, 给paintCode生成的图片做一个缓存,缓存到磁盘。下次使用直接取缓存。提升效率。

备注:

  1. 使用文件名+尺寸+特殊参数组成图片名称存储到磁盘中。
  2. 缓存的图片不要进入icloud。让每个机器分别创建。
  3. 缓存的图片加入一个过期淘汰机制,注意尽量不要让应用中所有图片在同一时间重建。
  4. 进入加入Server开关,可以强制客户端缓存清除。

5.   总结

PaintCode可以对内存大小、安装包大小的控制起到一定作用。但它还是有很多的限制因素。

5.1建议使用PaintCode的场景:

  1. 图片较为复杂、体积较大。
  2. 要为不同屏幕生成多套图片。

比如:首页启动的Loading图片。新手引导。

PaintCode调研的更多相关文章

  1. CMS模板应用调研问卷

    截止目前,已经有数十家网站与我们合作,进行了MIP化改造,在搜索结果页也能看到"闪电标"的出现.除了改造方面的问题,MIP项目组被问到最多的就是:我用了wordpress,我用了织 ...

  2. 记lrd的高二上学期第五次调研考试

    河北某某中学的调研考试其实是很好玩的经历呢.可惜没有太多机会了. 背景: NOIP2016回来之后没有好好学文化课-.自习能翘就翘了,衡中特产学案自助没有好好写(说来我好像从来没被老师查到过,上课写学 ...

  3. 《Kafka Stream》调研:一种轻量级流计算模式

    原文链接:https://yq.aliyun.com/articles/58382 摘要: 流计算,已经有Storm.Spark,Samza,包括最近新起的Flink,Kafka为什么再自己做一套流计 ...

  4. OpenStack调研:OpenStack是什么、版本演变、组件关系(Havana)、同类产品及个人感想

    一点调研资料,比较浅,只是觉得部分内容比较有用,记在这里: 首先,关于云计算,要理解什么是SAAS.PAAS.IAAS,这里不述:关于虚拟化,需要知道什么是Hypervisor,这里也不述: Open ...

  5. Beta版本——用户试用与调研报告

    1 引言 1.1 系统概述 ​ 毕设导师智能分配系统是一个用来简化传统手工匹配繁琐操作的系统.本系统将学生报志愿.系负责人收集整理数据.相关人员进行手工分配.反馈选择结果等繁琐的操作转移到线上.把毕设 ...

  6. 移动Web开发调研

    背景 在移动互联网浪潮下,移动设备普及,对配置需要考虑移动端设备可访问性.Web作为最贴近用户的配置手段,面向从PC端传统页面,向移动端页面的转型. 概念 PC Web: 面向传统PC电脑的浏览器开发 ...

  7. Web自动化测试工具调研

    背景 Web自动化测试越来越被重视, 因为现在Web已经是工程化的状态. 如何通过工具测试, 保证Web开发的质量,提升开发效率,是Web工具的诞生的来由. Web测试分为以下几个方面: 1. 界面测 ...

  8. Postgresql-xl 调研

    Postgresql-xl 调研 来历 这个项目的背后是一家叫做stormDB的公司.整个代买基于postgres-xc.开源版本应该是stormdb的一个分支. In 2010, NTT's Ope ...

  9. 请各位帮帮忙:Android LBS应用——CityExplorer (v1.0) 调研

    Hello哇各位亲!! 请各位帮帮忙:Android LBS应用——CityExplorer(V1.0)调研 嗯,这个事情是这样的,要填一个调查问卷,但是问卷中部分问题是关于这个叫做CityExplo ...

随机推荐

  1. 基础php链接SQL数据库

    要连接到你的数据库必须添加以下几条数据: $conn = @mysql_connect("localhost","root","root") ...

  2. wpf中UserControl的几种绑定方式

    我们经常会抽取一些可重用的控件,某个属性是否需要重用,直接决定了这个属性的绑定方式. 1.完全不可重用的控件 有一些与业务强相关的控件,它们的属性完全来自ViewModel,越是相对复杂的控件,越容易 ...

  3. iMacros 教程

    imacros能记录你在网页中的动作,然后模拟你的动作自动重复执行.进阶应用主要在于两个方面: 1.用JS动态调用,重复执行之. 2.调用CSV文件,这个不错哦. 还可以调用数据库,这个没用过. 安装 ...

  4. Objective-C学习笔记-第三天(1)

    今天开始用oc写iOS程序,遇到的问题有 1.在不同的类使用类的方法或者访问类的属性的时候(公开的方法或者属性),方法或者属性必须在类头文件中声明. 2.对象类型的声明以及定义需要用*,表明这个是一个 ...

  5. C++ Daily 《3》----构造函数可否是虚函数

    C++ 中构造函数可否是虚函数? 绝不要!! 而且,在构造函数中调用虚函数也是不提倡的行为,因为会引发预想不到的结果. 因为,在 derived class 对象构造的过程中,首先调用的是基类的构造函 ...

  6. 福州月赛2057 DFS

    题意:告诉你族谱,然后Q条查询s和t的关系,妈妈输出M,爸爸输出F: 题目地址:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=78233# ...

  7. qsort函数用法【转】

    qsort函数用法 qsort 功 能: 使用快速排序例程进行排序  用 法: void qsort(void *base, int nelem, int width, int (*fcmp)(con ...

  8. 第九课,T语言数组的定义与访问(版本5.0)

    数组的定义与访问 数组是一系列数据的集合,可以存储大量数据,通过数组的下标.key,可以实现对数据的快速访问. 为什么要使用数组呢? 如果您有一个项目列表(例如汽车品牌列表),在单个变量中存储这些品牌 ...

  9. eclipse中运行项目时报Class not found的错误

    环境:Groovy/Grails Tool Suite 3.1.0.RELEASE(BASED ON ECLIPSE JUNO 3.8.1).JDK1.6 运行class的main方法,或启动juni ...

  10. vim编辑器使用相关

    alias 查看vi是否已经绑定vim 一.vim的块选择 v 字符选择 V 行选择 ctrl+v 快选择 y 复制选择的地方(p进行粘贴) d 删除选择的地方 二.vim多文件编辑 :n 编辑下一个 ...