专栏名称: Android_开发者
目录
相关文章推荐
51好读  ›  专栏  ›  Android_开发者

Android UI 及 API 优化指南|Android 开发者 FAQ Vol.10

Android_开发者  · 掘金  · android  · 2018-01-03 04:10

正文

作为应用的设计者,有些开发者在开发过程中容易忽略一些用户体验方面的问题,从而导致了自己的应用用户体验欠佳。本期 Android 开发者 FAQ 我们整理了一些开发者们在后台留言的关于 UI 和 API 在用户体验方面的问题,为大家带来了 UI 及 API 的优化指南。

Q:用户说我的应用在处理信息时提示不明确,老是会误以为程序失去响应了,有什么好的方法改进吗?

A:系统应该在合理时间内给予适当反馈,让用户随时了解系统状态。

在 UI 方面,如果用户进行操作后需要等待一段时间,那么此时,系统就应当告知用户操作完成进度。与加载图标相比,我们更建议开发者采用进度条,并在上面显示上传或者下载百分比。这样用户就可以知道自己在等什么,还要等多久。

△ 告知用户操作完成进度

而在 API 方面,API 应该提供查询当前进度的方法。例如:开发者可以通过 AnimatedVectorDrawable 类来查看动画究竟是否在运行状态: boolean isAnimationRunning = avd.isRunning();

API 可以借助某种回调机制提供反馈:当对象状态发生变更时,通知 API 用户 —— 有点类似于动画开始和结束时的推送通知。AnimatedVectorDrawable 对象就允许通过注册 AnimationCallback 函数,达到上述目的。

Q:“撤回” 的操作在变得越来越流行,这类功能有什么意义呢?如何在我的应用内加入类似的功能?

A:给予用户撤回操作的权利,会让您的应用变得更加友好易用。

在 UI 方面,有时用户进行的操作可能会产生歧义,例如删除和归档邮件,此时系统应当弹出信息确认操作,并提供撤回选项。

△ 允许用户撤回某些操作

而 API 应允许用户 “放弃” 和 “重置” 操作,方便 API 返回正常状态。比如,Retrofit 中的 Call#cancel 可以取消已经发送的网络调用请求或者确保该调用永远不会被执行(前提是在使用 Call#cancel 前,执行尚未发生)。而通过 NotificationManager API,开发者既可以创建又能够取消消息通知。

Q:有用户反馈说我的应用和其他的产品 “不一样”,进行某些按钮和手势操作后没有进行他们预想的功能,我该去哪里了解其他开发者都是怎么设置这些内容的呢?

A:好的应用,不应该让用户对不同的措辞、情况和操作究竟指的是不是一件事而感到烦恼。

在使用您的 App 之前,用户已经接触过许多别的 App,因此他们会期望常见的交互元素在各个 App 之间保持一致性。一旦脱离常规,就容易产生错误。

因此开发者须要和平台保持一致性,并且采用用户熟知的 UI 控件,确保用户能够快速识别并使用它们。此外,开发者自己的 App 也须要保持一致性:多屏操作 App 时,采用相同的用词和图标表示同种操作。例如,保持编辑图标统一,让用户可以在 App 内编辑多种元素。

△ 对话框应和平台统一

至于 API,所有设计应当保持统一,如方法命名应一致;方法内容相同,名字也务必相同;方法中参数排序也要保持一致,等等。

Q:我觉得进行很多操作都额外弹出提示可能会让部分用户感到厌烦,那么究竟怎样的设计才能在不打扰用户和可靠之间找到平衡?

A:从一开始就预防用户在使用中 “犯错” 的发生,是开发者应当遵循的一个原则。

很多情况下,用户无法一直专注于手头的任务,因此开发者应该正确引导,以防用户无意识犯下无法补救的错误。譬如,在进行破坏性行为(比如删除)前先获取用户同意,或者设定良好的默认值。

比如说,Google Photos 添加了确认对话框,避免用户不小心删除相册。而收件箱的闹钟功能(让邮件打个盹儿),则可以一键设定在某段时间后让邮件重新出现在眼前。

△ 在破坏性行为前,Google Photo 会要求用户先进行确认。收件箱一键设定时间,让邮件打个盹儿。

API 应该正确引导用户使用 API,在需要的地方使用默认值。API 应该操作简单容易上手。开发者可以通过提供默认值,帮助用户使用 API。比如说,当创建 Room 数据库时,其中一个默认值可以保证在数据库版本升级过程中,数据量保持不变。这意味着基于 Room 开发的 App 可用性大大增强,因为数据没丢而且数据库版本也是透明的。

而 Room 中的另一个方法 fallbackToDestructiveMigration 则可以更改此行为:在未提供数据迁移的情况下,数据库版本变更后,该方法能够破坏并重建数据库。







请到「今天看啥」查看全文