为iOS7重新设计你的App
在 WWDC 上看到 iOS 7 系统的发布后,我们重新审视了自己的应用 Grocery List,并且意识到:iOS 7 对于开发者来说是一个全新的开始,就像七年前 iPhone 首次发布一样。现在仅仅简单地改变设计是不够的,我们不得不重新思考并重构整个 app,从而让它适合 iOS 7 全新的环境。我们也的确是这么做的。
根据用户的反馈和我们自己的使用情况,我们意识到,虽然不能改变 app 基本的操作,但是应该对软件的操作流程进行一些优化。比如在旧版本中,添加产品的数量和单位是一个多步骤的操作过程,需要在多个 controller 之间进行导航。在 Grocery List 2 中,用户不用离开当前屏幕就能在恰当的位置设置数值。
在实现这个目标的过程中,遇到了一些我们觉得值得分享的问题。我们将会从动画和手势开始讲起,然 后是界面、色彩以及字体等问题。接下来,为了吸引用户打开 app,我们将不得不思考如何针对 iOS 7 重新设计 app 的图标。最后,我们将分享在我们看来,苹果这次更新的意义何在。
动画
现在随着更新换代,移动设备的性能正变得越来越强大。与此同时,由于可以实时计算物品的物理属 性,动画效果也变得愈加真实。在 iOS 7 中,我们不需要在界面中使用阴影和渐变这些效果了,而是应该更关注用户的感觉、手势以及交互的影响。凭借 iOS 7,你可以创建一个新世界而不是模仿旧有的世界。
新 SDK 可以让你简单地创建并使用自定义的动画效果。在 iOS 7 之前,开发者需要做大量额外的工作才能改变 view controller 之间的转场效果。iOS 7 可以让你简单地添加自己的动画,以帮助用户在不同屏幕之间切换的同时还不会丢失关注焦点。
在 Grocery List 中,我们在显示一个 modal view controller 时使用了轻度定制的转场动画。但是大部分的动画和转场效果都是使用系统默认的。我们本可以使用新的 API 来给 Grocery List 2 添 加更多自定义的动画,但其实苹果提供的默认转场动画对于大多数情况来说已经是个不错的解决方案了,这也是为什么我们 app 中的不同 view controller 之间的转场效果和苹果官方的 app 是一样的。正如前边提到的那样,我们 app 的部分操作流程已经明显地发生了改变。所以,我们将会使用自定义动画从而更好地保持用户的关注焦点。
大多数用户对于 iOS 7 上默认的动画的感觉,是既新鲜又自然,你不需要做很多工作就可以使用这些动画来取悦用户。但是在合适的地方添加一些自定义动画将会提高整个 app 的用户体验。只是请小心不要使用过度。
手势
在拥有了数年的触屏设备的经验后,苹果发现大量使用手势对于用户来说正变得愈加自然。所以在 iOS 7 中,对手势的广泛使用比以前有了更多的可能性。比如在 table view cell 上滑动来显示隐藏的菜单,或者从左向右滑动来返回先前的 view controller,这些手势操作我们已经非常熟悉了,以至于如果一款应用不支持这些手势的话,我们马上就会非常想念它们。在合适的地方,这些直接的手 势操作可以帮助用户更高效地完成任务而不会失去关注焦点。
在 Grocery List 中,我们并没有使用任何自定义手势,但是为了在下个版本中改进用户的操作流程,我们支持在 cell 上进行左右两个方向的滑动来分别展示产品的不同选项。你可以简单地从屏幕的右边缘向左滑动来快速访问菜单以进行列表或者模版的相关设置,而不用在导航栏一层层地返回。
按钮和链接对于用户来说是可见的,也是可识别的,但手势不是。如果你打算用手势来实现某个功能, 很好!但是如果 app 中那些依赖手势的功能没有一个等效的可见的控件,那要为用户提供一个好的方法来发现这些手势。一个好的用户界面通常应当是不言自明的。如果你需要一个类似 使用说明一样的界面或者视频来描述 app 中的基本功能,那这里面很可能就有问题了。
界面
在正式发布前,大家对于 iOS 7 最大的争论莫过于扁平化和拟物化(skeuomorphic) 这两种设计风格间的区别。iOS 7 完全摒弃了设计上对真实世界的依赖,但最大程度地保留了为大众所熟知的交互模式。新的纤细的工具栏图标可以帮助内容脱颖而出,但是别忘了,这样做的后果是 这些图标本身变地不容易识别而且语义不明。尤其是当图标的下方没有说明其行为的文字标签时,情况更是如此。
我们发现争论的重点并不完全在于是设计上是应该再造还是移除所有实物的外观,而是说哪种设计可以 更好地突显内容。如果在导航栏中增加细微的阴影可以突出内容的话,那也没必要一定不使用阴影。最重要的事情还是在需要的时候增加对比度,并且以一种方便用 户使用的方式来展示你的内容。
Grocery List 在设计上非常依赖于真实世界的物品。比如以黑板为 背景,类似纸张上的单元格,所有框架都是有光泽的木质效果。这种设计看起来很好看,但是在这个狭小的空间内如何放置用户交互的控件也会是个不小的挑战,增 加新功能时也同样要考虑这个问题。在 iOS 7 这种更轻量的设计中,我们不必像之前那样关注如何更逼真地拟物化,而是可以把关注点放在如何提升交互,以便用户达成自己的目标。Grocery List 2 一定会使用这个新的设计语言,同时也会保持自己的风格。
在 iOS 7 的设备上使用几周后,明显感觉到现在的交互变得比之前版本更方便。新的动画、手势以及减少对拟物化元素的使用让用户更好地关注内容。
颜色
iOS 6 和 iOS 7 的主要区别之一是色彩整体给人的感觉。外观的颜色从暗色转变为更鲜亮的色彩。iOS 7 使用了更为生机勃勃和高饱和度的颜色,以支持频繁使用的半透明设计和背景模糊设计。
考虑到 Grocery List 对拟物化设计的依赖,所以不可能过分调整用色。颜色是由我们想要模仿的材质所决定的。尽管我们喜欢 iOS 7 中更加友好的外观,像大多数内置的 app 一样大体上是白色,但是 Grocery List 2 这个 app 的外观将主要由符合「采购(Grocery)」这一主题的配色方案来决定。我们不希望我们的 app 看起来就仅仅是另外一个 iOS 7 风格的 app,而是希望创造独一无二的外观。
色彩可以影响用户对 app 的感觉。不要让你的 app 像内置的应用一样满是白色。相反要创造你自己独一无二的个性颜色。得益于 iOS 7 全新的设计风格刚和对拟物化使用的节制,你可以用各种出挑的色彩来表达你的 app 希望传递给用户的讯息。
字体
从 iOS 7 中对文本系统框架的重构这一点上就可以看出来,苹果认识到了字体的重要性。Lable 和 text field 现在直接使用 core text 提供的所有排版相关的功能,这里面就包括字体。连字(Ligature),文字装饰符(swoosh)等功能在新的框架下都可以简单地来实现。通过获取 text style 中的字体对象,你的 app 可以根据用户选择的字体大小来展示内容。想了解更详细的内容,可以看看这篇非常棒的关于 iOS 7 中的字体的文章。
由于「实际」按钮的缺失以及文本周围描边的减少,文字本身获得了更多关注。由于在之前 iOS 7 的 beta 版本中大量使用 Helvetica Neue 的纤细体而受到排版专家的批评,苹果最终又换回了可读性更强的标准体。
在 Grocery List 中,我们使用 slab-serif 字体以配合拟物化风格。当 app 运行在 iOS 7 的设备上时,我们发现这个字体不是一个最佳选择。所以我们决定使用定制的 sans-serif 字体,这款字体可以更好地契合 app 整体的外观。
内容是 app 的基础,提升文字的可读性非常重要,而可读性的关键在于字体。虽然苹果默认的 Helvetica Neue 字体适合大部分情景,但自定义字体也是值得考虑的——尤其是当你的 app 需要呈现大量文本的时候。
App icon
苹果并不仅仅改变了 icon 的大小和轮廓,还改变了视觉氛围。App icon 不再使用光泽效果,并且大多数内置程序的 icon 是和网格对齐的。另外,icon 变得更简单了,移除了仿现实主义的效果,并且大多数只是在多彩的背景上展示简单的概念图标。这是从照相写实主义(photorealistic)风格的插图到阐述 icon 的本义——图示(Iconographic)的一次转变。
从一个有着黑板背景和木质纹理的拟物化的 app icon,转变为一个更加简洁的多彩的有着清晰符号的 icon,Grocery List 并不是真的完全适合新的主屏幕。下个版本中,我们把 icon 简化为一个购物篮符号,并选择一个背景色,这个背景色同样可以用作 app 的主色。这样的多种方法组合使用可以让 icon 更时尚和流行。
在 iOS 7 中,icon 会自动会缩放到新的尺寸,导致图像变模糊。由于 iOS 7 中使用了弧度超级大的圆角来遮盖你的 icon,阴影和高光效果看起来会非常奇怪。如果你不打算让你的 app 适配 iOS 7 的风格,那么至少更新一下你的 icon 的尺寸。
结论
虽然 iOS 7 给人整体的感觉是既新鲜又精致,但是很多概念都是保留下来的,比如从第一个版本就一直存在的导航功能,在列表和表格中查看数据,接收推送通知等等,用户对 这类操作已经非常熟悉了,所以颜色和字体的更改以及移除拟物化设计元素等一系列的改变并没有打断用户所熟知的这一套操作流程。
在这个层面上,苹果并没有强迫你改变 app,但是我们建议你应该总是不断地尝试与时俱进,并始终把一点牢记于心:用户至上。
原文 Re-Designing an App for iOS 7
为iOS7重新设计你的App的更多相关文章
- TableViewCell Swipe to Delete and More Button(like mail app in iOS7 or later)
在iOS7系统的Mail App中TableViewCell的一个功能让我们做TableView的比较羡慕,就是滑动cell,右边出现了两个按钮,如下: 网上在github上有很多大牛用custom ...
- [iOS翻译]《iOS7 by Tutorials》系列:iOS7的设计精髓(上)
简介: 本文翻译自<iOS7 by Tutorials>一书的第一章“Designing for iOS 7”,主要从程序员角度介绍了iOS7的新设计理念,堪称神作!本文翻译仅作学习交流之 ...
- iOS7 人机界面设计指南
iOS7 人机界面设计指南 苹果在WWDC 2013大会上发布了iOS 7,新系统一改5年来的拟物路线,在乔纳森•艾维的主导下,加入了更多的“扁平化”和“极简”现代设计元素. iOS7系统界面 ...
- 【转】《iOS7 by Tutorials》系列:iOS7的设计精髓(上)
简介: 本文翻译自<iOS7 by Tutorials>一书的第一章“Designing for iOS 7”,主要从程序员角度介绍了iOS7的新设计理念,堪称神作!本文翻译仅作学习交流之 ...
- 关于iOS7的一切相关的资料
http://www.cocoachina.com/special/ios7/ PreviousNext 作为的用户,您可能需要了解 WWDC大会以及iOS 7的新界面 CocoaChina WWDC ...
- 解决在iOS8环境下,当用户关闭定位服务总开关时,无法将APP定位子选项加入定位权限列表的问题
关键点:- (void)locationManager:(CLLocationManager *)manager didChangeAuthorizationStatus:(CLAuthorizati ...
- APP适配IOS8,iPhone6和Plus截图简要说明
本文转载至 http://blog.csdn.net/yongyinmg/article/details/41422873 原文:http://www.zcool.com.cn/article/ZMT ...
- 关于iOS和OS X废弃的API你需要知道的一切
如你所知,已废弃(Deprecated)的API指的是那些已经过时的并且在将来某个时间最终会被移除掉的方法或类.通常,苹果在引入一个更优秀的API后就会把原来的API给废弃掉.因为,新引入的API通常 ...
- [译]关于iOS和OS X废弃的API你需要知道的一切
原文: Everything You Need to Know about iOS and OS X Deprecated APIs 如你所知,已废弃(Deprecated)的API指的是那些已经过时 ...
随机推荐
- FreeBSD 路由详解
在同一个局域网上的计算机是直接连通的,但是不同的网络上的计算机并没有直接相连,只能通过一台特殊的专用计算机 -路由器来完成连通.路由器连接有多个网络界面,每一个网络界面连接到一个相应的网络上,具有一个 ...
- 有一种风格,叫做 Low Poly 3D
原作:Simon阿文 杂交编辑者:RhinoC 个人更推崇使用第二款神器 ImageTriangulator :http://www.conceptfarm.ca/2013/port ...
- 隐藏自定义的tabbar之后,push到B视图,B视图的键盘工具条无法响应点击事件
我的情况如下: 在TabbarViewController中隐藏了系统的tabbar,然后自定义tabbar,A B C D 4个视图都有UINavigationController,A视图 使用的是 ...
- HTML页面中常见的一些小方法
在<Head>标签中加 <meta http-equiv="pragma " content="no-cache"> <met ...
- MongoDB - The mongo Shell, Write Scripts for the mongo Shell
You can write scripts for the mongo shell in JavaScript that manipulate data in MongoDB or perform a ...
- 破解软件系列-PE文件深入浅出之Section Table节表
我们已经学了许多关于 DOS header 和 PE header 的知识.接下来就该轮到 section table(节表)了.节表其实就是紧挨着 PE header 的一结构数组.该数组成员的数目 ...
- CSS之Document方法的使用
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- cocos2dx-lua 批量打包及修改
coco2dx目前大部分开发者肯定是用lua解决问题,问题来了,每次改一下lua配置可能你每次都得运行 cocos luacompile -p android 针对不同的平台,可能会有某些配置会略有不 ...
- 使用strtotime和mktime时参数为0时返回1999-11-30的时间戳问题
先看例子 代码如下 复制代码 <?php $time = date('Y-m-d',strtotime('00-00-00 00:00:00')); echo $time; //输出 1999- ...
- OpenFiler安装与基本配置
一. 安装篇 1. 插入安装盘 2. 选择键盘输出 3. 对硬盘进行分区 4. 删除所有数据并重新分区 5. 配置IP地址等信息 ...