codecamp

1.11 图标和图形(Icons and Graphics)

1.11 图标和图形Icons and Graphics

1.11.1 应用图标The App Icon

每个应用都需要一个漂亮的图标。用户常常会在看到应用图标的时候便建立起对应用的第一印象并以此评判应用的品质、作用以及可靠性。

以下几点是你在设计应用图标时应当记住的。当你确定要开始设计时请参考App Icon来获取更详细的设计规格与指导。译者注App Icon处在iOS Human Interface Guidelines的Icon and Image Design部分翻译将在后续更新中放出烦请各位耐心等候。

  • 应用图标是整个应用品牌的重要组成部分。将图标设计当成一个讲述应用背后的故事以及与用户建立情感连接的机会。
  • 最好的应用图标是独特的整洁的打动人心的让人印象深刻的。
  • 一个好的应用图标应该在不同的背景以及不同的规格下都同样美观。为了丰富大尺寸图标的质感而添加的细节有可能让图标在小尺寸时变得不清晰。

1.11.2 小图标Small Icons

iOS提供了一系列小的icon用以代表各种常见任务与操作它们常用在标签栏Tab Bar、工具栏Toolbars与导航栏Navigation Bar中。用户通常都已经了解这些内置图标的含义了因此可以尽可能的多使用它们。

如果需要自定义动作或者内容你也可以设计自定义图标。设计这些小的线性图标与设计应用图标有很大的区别请参考Bar Button Icons来了解更多内容。译者注Bar Button Icons章节处在iOS Human Interface Guidelines的Icon and Image Design部分翻译将在后续更新中放出烦请各位耐心等候

请注意你有时候也可以用文字来代替工具栏和导航栏的图标。 就像iOS的日历里面工具栏上便是使用”今天”,”日历”和”收件箱”来代替图标进行表意的。

想要决定在工具栏和导航栏中到底是用图标还是文字可以优先考虑一屏中最多会同时出现多少个图标。同一屏幕中图标的数量过多可能会让整个应用看起来难以理解。使用图标还是文字还取决于屏幕方向是横向还是纵向因为水平视图下通常会拥有更多的空间可以承载更多的文字。

1.11.3 图形Graphics

iOS应用大多数图形丰富。无论是你需要展示用户的照片还是需要创建自定义图片以下这些需求都应该遵守

  • 支持**Retina**显示屏。确保你应用中的所有图片资源都提供了高分辨率规格。尤其需要注意的是iPhone 6 Plus需要提供@3x规格的图片而所有其他的高分辨率iOS设备都需要提供@2x规格的图片。
  • 显示照片或图片时请使用原始尺寸并不要将它拉伸到大于**100%**。你不会希望在你的应用中看到拉伸和变形的图片。可以让用户自己来选择他们是否想要缩放图片。

不要使用从苹果系列产品中复制的图形。这些图形均受版权保护而且产品的设计可能会频繁改变。

不要将苹果的应用图标图像或者截图用于你的设计中。所有苹果的设计均受版权保护并且不允许出现在你的UI中除非它们是由系统直接提供的。

1.10 颜色与字体(Color and Typography)
1.12 术语和措辞(Terminology and Wording)
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }