天天品尝iOS7甜点 Day2:Asset Catalog

Asset Catalogs (资产分类),它可以管理物理图像文件和这些文件的上下文信息。

参考:

Asset Catalog - 资产分类

  • 资产分类目录由一些图像的集合、app图标和app启动页构成。
  • 新建工程时,Xcode 会自动创建一个名为 Assets.xcassets 的文件夹。
  • Asset catalogs 是存在在硬盘上面的一个目录,由Xcode进行管理。它以特定的方式进行文件的排列,包含一个json文件存储目录相关联的元数据:

App icons and launch images

Asset catalog(资产分类)默认自动创建,名为Assets.xcassets,包含AppIcon的入口。提供了构建应用的所有需要的图标的尺寸:

LaunchImage 目录需要自己创建:鼠标右击 —— App Icons & Launch Images —— New iOS Launch Image

Custom imagesets - 自定义图像集

和标准的集合一样,你可以使用 asset catalogs 来管理你自己的图片,图片都是包含在ImageSet中的,并且可以使用管理对应的retina和非retina图像。

使用方法:UIImage:imageNamed:

UIImage *image = [UIImage imageNamed:@"Australia"];

💡 加载图片还涉及到缓存问题,参考之前写的文章:

UIImage 使用Tips

Slicing images - 切片图像

Asset catalogs 的另外一个主要的特性就是能够让图像进行切片工作,自从iOS2开始程序就能够使用切片的图像了,但是Xcode中的这个新特性会变得非常的简单。

使用切片变换图像,是创建虚拟的元素基本的技术。例如按钮,需要拉伸这个按钮图片的大小达到一个新的大小,并且要设置边缘不被拉伸,只拉伸中间的部分。

在 Asset catalog 中就可以使用Xcode提供的功能进行切片操作了,开启切片功能,只需要点击Show Slicing按钮,你可以选择水平、竖直或者两者都拉伸的方式,如果你选择之后,图像将会重新加载并且上面会出现拉伸辅助线,你可以通过拖拽辅助线,来实现自己需要拉伸的效果。

使用这些切片图像编程非常的简单,和之前一样创建一个UIImage对象,然后当你调整UIImageView的大小,内部的image就会自动根据切片的图像来变换大小。

UIImage *btnImage = [UIImage imageNamed:@"ButtonSlice"];

// Let's make 2
UIImageView *iv = [[UIImageView alloc] initWithImage:btnImage];
iv.bounds = CGRectMake(0, 0, 150, CGRectGetHeight(iv.bounds));
iv.center = CGPointMake(CGRectGetWidth(self.view.bounds) / 2, 300);
[self.view addSubview:iv];

// And a stretched version
iv = [[UIImageView alloc] initWithImage:btnImage];
iv.bounds = CGRectMake(0, 0, 300, CGRectGetHeight(iv.bounds));
iv.center = CGPointMake(CGRectGetWidth(self.view.bounds) / 2, 350);
[self.view addSubview:iv];

步骤详解:

  1. 点击Show Slicing 按钮?
  1. 选择拉伸模式:

    支持三种模式:水平拉伸、水平和垂直同时拉伸、垂直拉伸。

  2. 设置拉伸句柄:

  3. 代码添加图片:

        UIImage *image = [UIImage imageNamed:@"bird"];
        
        // default
        UIImageView *imageView = [[UIImageView alloc] initWithImage:image];
        imageView.bounds = CGRectMake(0, 0, 50, 37.5);
        imageView.center = CGPointMake(CGRectGetWidth(self.view.bounds) / 2, 300);
        [self.view addSubview:imageView];
        
        // stretch
        UIImageView *stretchImgView = [[UIImageView alloc] initWithImage:image];
        stretchImgView.bounds = CGRectMake(0, 0, 100, 75);
        stretchImgView.center = CGPointMake(CGRectGetWidth(self.view.bounds) / 2, 400);
        [self.view addSubview:stretchImgView];
    
  4. 效果:用【填充部分】去覆盖【可扩展部分】

ImageOptim - 超好用的图像压缩工具

ImageOptim 是一个免费的图像压缩工具。iOS 工程默认使用 pngcrush 命令来压缩数据,不过其压缩比率不是很高。而使用 ImageOptim 可以达到最大的图片压缩效果。

实现原理:使用各种开源的图像压缩工具,然后取压缩效果最好的那一个。

使用方法也非常简单:在 Finder 中打开图片所在的文件夹,将图片拖拽进 ImageOptim 界面中即可。

其他图像压缩工具:

附录:

摘自官方人机交互指南:iOS Human Interface Guidelines

图片大小和分辨率(Image Size and Resolution)

设备 比例系数
iPhone 7 Plus and iPhone 6s Plus @3x
其余高分辨率的 iOS 设备 @2x
App Icon
设备或状况 图标大小
iPhone 180px × 180px (60pt × 60pt @3x)
120px × 120px (60pt × 60pt @2x)
iPad Pro 167px × 167px (83.5pt × 83.5pt @2x)
iPad, iPad mini 152px × 152px (76pt × 76pt @2x)
App Store 1024px × 1024px
Spotlight, Settings, and Notification Icons
Spotlight
设备 Spotlight 图标大小
iPhone 120px × 120px (40pt × 40pt @3x)
80px × 80px (40pt × 40pt @2x)
iPad Pro, iPad, iPad mini 80px × 80px (40pt × 40pt @2x)

Settings
设备 Settings 图标大小
iPhone 87px × 87px (29pt × 29pt @3x)
58px × 58px (29pt × 29pt @2x)
iPad Pro, iPad, iPad mini 58px × 58px (29pt × 29pt @2x)

Notification
设备 Notification 图标大小
iPhone 60px × 60px (20pt × 20pt @3x)
40px × 40px (20pt × 20pt @2x)
iPad Pro, iPad, iPad mini 40px × 40px (20pt × 20pt @2x)
自定义图标大小
导航栏和工具栏图标尺寸 标签栏图标尺寸
推荐 75px × 75px (25pt × 25pt @3x) 75px × 75px (25pt × 25pt @3x)
50px × 50px (25pt × 25pt @2x) 50px × 50px (25pt × 25pt @2x)
最大 83px × 83px (27.67pt × 27.67pt @3x) 144px × 96px (48pt × 32pt @3x)
56px × 56px (28pt × 28pt @2x) 96px × 64px (48pt × 32pt @2x)

启动画面(Launch Screen)

静态启动画面图片
设备 Portrait size Landscape size
iPhone 7 Plus, iPhone 6s Plus 1242px × 2208px 2208px × 1242px
iPhone 7, iPhone 6s 750px × 1334px 1334px × 750px
iPhone SE 640px × 1136px 1136px × 640px
12.9-inch iPad Pro 2048px × 2732px 2732px × 2048px
9.7-inch iPad Pro, iPad Air 2, iPad mini 4, iPad mini 2 1536px × 2048px 2048px × 1536px
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容

  • 许多UIView的子类,如一个UIButton或一个UILabel,它们知道怎么绘制自己。迟早,你也将想要做一些自...
    shenzhenboy阅读 1,633评论 2 8
  • 有多少现在都会变成曾经,又有多少曾经变成了曾经的曾经 是否有个让你会思念我的夜晚,时间过滤掉了伤痛的记忆,留...
    sun_小璐阅读 264评论 0 0
  • 昨天介绍了客户购买产品的行为都是出于自愿,那么今天这个话题是想帮助你理解当前人们所说的逼单的真实意思。其实人们口头...
    毛正奇阅读 339评论 0 0
  • 钱钟书先生在《围城》里说过这么一句话,婚姻是爱情的坟墓。 婚姻是爱情的必然走向,也是爱情的延续、升华和稳固,是两个...
    敬先生阅读 596评论 4 2
  • 你的一句“好丽友,一辈子!”勾起了我很多的回忆…校园寝室里上下铺时的打闹嬉戏,一同练歌,抢琴房,一同参加唱歌比赛,...
    飞扬的音符阅读 742评论 0 1