原标题:iPhone 有个返回问题
作为一家以体验和设计闻名的公司,苹果到今天都还没有解决侧滑返回不好用的问题,这多多少少有些让人意外。细究之下,往往能发现原因是一个积重难返的历史包袱。
iPhone「没有」返回键为什么不好用,我们还得先回到初代 iPhone 发布前,看看这款重新定义手机的产品,是如何定义交互与按键布局的。
▲圆形 Home 键很长一段时间以来都是 iPhone 的标志性设计我们在之前的文章中提到过 iPhone Home 键的由来,最初乔布斯是想过为 iPhone 加上一颗返回按键的,不过设计师伊姆兰·乔德里(Imran Chaudhri)说服了他。
我的早期构想,是设计一个类似于 Mac 上 Exposé 功能的按键,只要你按下去,就能看到全部的应用程序,然后你再点开其中某一个就能打开它,就像是你在 Exposé 中选择了其中一个窗口。
正面仅保留一颗 Home 不仅是为了简约美观,更是为了降低交互复杂度。乔布斯在发布会上以「永远会带你回到最初的地方」介绍 Home 键,Windows 的开始按键一样,在复杂的功能海中找到一处灯塔,引导着人们使用 iPhone,按下就能回到主界面。
▲在任意界面按下 Home 键都能返回主页唯一的 Home 键不仅方便人们记住它的交互功能,更提供了一种极强的确定性,按下就回到最初的地方。当然,这样做也弱化了退出应用的意义,甚至返回键的存在感也被降低。作为重新定义手机的产品,iPhone 和功能机最大的差别之一就是触控和手势交互成为了最主要的人机交互方式。数字键盘和功能一比一对应的方式虽然方便记忆和使用,但不利于展示内容,换成触控交互后屏幕内容排列更灵活了,比如输入键盘完全可以虚拟化,在需要的时候开启,不需要的时候展示其他内容,即便是多级页面也可以采用虚拟返回按键代替。
一颗 Home 键加上优秀的触控交互,早期 iPhone 的易用性体验并没有出现什么问题。对于单键设计的坚持,也可以在另外一款争议颇多的产品——苹果鼠标中看到。很长一段时间以来,Mac 的官方鼠标配件都不提供右键功能,整个鼠标就是一颗按键。因此很多 Windows 用户切换到 Mac 很不习惯,要使用右键要同时按键苹果鼠标按键和键盘上的 Ctrl 键。
▲图片来自:CNET只是,将按键替换为手势就万事大吉了么。
从按键到手势,不止是替换从 iPhone X 之后,苹果就全面转向了全面屏,原本的 Home 键也被小横条和手势代替。其实对比一下小横条手势和侧滑返回,就能发现 iPhone 的返回手势为什么不好用,手势替换按键并非只是功能的替换,作为最主要的人机交互方式,必须要解决一个问题——可发现性。
▲所有交互按钮都不能遮掩小横条iPhone X 之后的手机,打开后的激活过程必然会包含一项手势教学,正是为了强化记忆,告诉人们滑动小横条就能回到主界面,和 Home 一样回到最开始的地方。手势和按键一样,都是一个手势对应一个功能,减低交互复杂度,上滑是回到主界面,而上滑悬停则是多任务界面。值得一提的是,为了区分这两个手势,iPhone 内部的震动马达发挥作用了,当你悬停时手机会轻微震动,告诉你这是多任务操作手势。左滑和右滑小横条则是快捷切换左右的应用。
▲图片来自:Designing Fluid Interfaces所有的手势配有相应的操作动画,且可撤回,指示用户这代表一个操作。再回过头来看侧滑返回,虽然也有开机教程和可撤回的操作动画,但更多的是靠用户多次操作的肌肉记忆解决手势不易发现的问题。更重要的是和小横条对比,侧滑返回没有专属交互区也没有系统最高交互等级,容易和其他交互方式冲突,文首提到的图片浏览场景就是其中之一,部分应用在多级内容页中也可能会设置虚拟返回按钮而不支持侧滑返回手势,导致一直侧滑也无法返回。
▲Android 侧滑返回会有相应的箭头指示反观 Android 系统就好多了,Google 从一开始就设置了专用的返回按键,侧滑返回作为手势顺其自然地替换了返回按键,且是系统最高级的交互方式,哪怕应用在多级页面没有设置返回交互功能,侧滑也可以强制返回。没有返回键的历史包袱,造成了如今 iPhone 侧滑返回不好用的后果。
大屏改变交互体验iPhone X 发布后,著名用户体验研究机构尼尔森·诺曼集团发布了一篇研究报告,提出了一个观点,更大的屏幕能克服手势操作所带来的交互问题,因为大屏幕能容纳内容与交互元素,在长期使用后,人们会逐渐习惯。
从今天的情况来看,尼尔森报告中所提到的观点已经成为了事实,越来越多应用开始使用各式视觉符号引导用户操作。第三方微博应用 VVebo 就曾因其交互方式对大屏设备友善而广受赞誉,为大屏幕优化的交互主要体现在两方面:
交互按钮下移
更全面的交互符号引导用户操作
屏幕摔碎找丰修
专业维修工程师上门服务
iPhone X系换屏低至308元起
戳图即可下单↓
更多型号手机故障
↓