- 浏览: 84992 次
- 性别:
- 来自: 北京
文章分类
最新评论
导读:本文是来自移动应用开发公司Sourcebits系列文章Mobile App Trends Series(译者:此网站要梯子)中的一篇,文章内容适合初涉此领域的读者,现翻译如下。
在了解了跨平台移动应用设计的利弊和移动应用开发常见错误之后,你想到了一个不错的应用创意,你甚至连应用的名字都想好了,接下来该干什么?
现在,我们要谈谈设计了。你需要考虑移动应用的功能结构、用户流程等问题,而这些并不是那么容易。考虑到进入开发阶段我们会涉及到诸如需求变动、项目管理等棘手的问题,所以在设计阶段,我们需要给自己制定一些原则,并且要切合实际的开展工作。这样我们才能开发出一款好用又有趣的应用。忽略这些潜在的问题而盲目瞎干,你很有可能在此后的开发阶段陷入灾难。
本文试图帮助移动应用设计者在工作中避免一些难缠的麻烦,希望你的应用以及你的设计思路均能因此受益。
错误1. 在弄清用户流程之前匆忙开始界面(草图)设计
在开始界面设计前,我们要先把完整的用户流程详细的走通顺走清楚。哪怕是再简单的应用,为了确保用户流程逻辑正确、界面布局合理,我们需要反复推敲用户流程并绘制类似上面的流程图。另外值得注意的是,最好把关键功能绘制在流程图靠近顶部的地方,而不是被层层分支淹没在底部。
跳过此环节而草率的开始界面设计,最终开发出的应用很可能在使用流程上不够清晰合理,用户上手后不得其解,兴趣索然。
错误2. 低估开发成本
设计师在Photoshop中画出的任何东西,最终都需要通过开发人员的代码在屏幕上表现。原本只需几小时开发的功能,由于设计师的一个看似细微的改动,可能会多耗费几天的开发时间。所以,在设计过程中要避免画蛇添足。
换句话说,如果设计师主导了移动应用功能的取舍,那后果会很严重。举个搜索框的例子,原本相对简单的一个功能,设计师灵光乍现——在用户输入关键词的同时不断给出实时的搜索结果。这个看似细节的改动,很可能让开发人员当场吐血。像这种的功能改动最好经过多方讨论后做出决策,而不是任由设计师自说自话。
错误3. 在低分辨率下设计,使用位图文件
始终坚持为Retina屏幕的高分辨率绘制设计图,然后以此输出低分辨率版本图片。这对于老手来说是常识,我们在这里再啰嗦几句。大家都知道,移动设备的常见屏幕尺寸是越来越五花八门(以iOS平台 为例,迄今需要考虑的就有4种分辨率)。所以,绘制高分辨率版本的图片,甚至是使用矢量图而不是位图,这些有助于设计师效率最大化,以及更好的应对未来的新硬件。
错误4. 触摸区域太小
普通人的食指触摸面积在1.6至2厘米见方,而且在使用移动应用的大多数时间里,他们的手指飞快的掠过屏幕。设计移动应用界面需要时刻提醒自己这一点,用户的触摸并不能像鼠标点击一样精确。看看你的设计是不是在一屏里包含了太多的按钮等功能触发点,按钮是不是足够大,间距是不是足够宽,会不会发生用户点选不到或者误按其它按钮的问题?
错误5. 滥用开场动画
在启动时播放一段精致的动画似乎是个不错的想法,但切忌不要为了动画而动画。Path和Thrillist’s JackThreads使用很酷的开场动画是因为这些应用启动需要一些时间,在程序完成加载之前用户什么也不能做(译者:Path启动貌似没有啥动画,难道是针对老版本说的?)。这种情况下,为用户准备一段简短愉悦的动画以消除等待的焦虑就显得很合时宜了。
由于应用启动时必须首先显示一张静待图片(译者:如iOS应用的Default.png),然后才能切换到动画,所以务必确保这个切换看起来天衣无缝。一些不好的例子在处理这个环节的时候产生了不协调的跳转或者闪屏,这都是需要避免的。(译者:优酷iPad应用的早期版本存在这种切换,处理中有一闪而过的黑屏,现在的版本把动画直接去掉了)
错误6. 让用户不知所措的原地等待
在程序加载、处理数据、或者等待网络反馈时不给用户及时的反馈,会让用户误认为应用挂了,这也是一种不好的用户体验。
举例来说:通过网络加载数据的同时,不要让用户傻傻的盯着一个空白的屏幕等待,显示一个转菊花或者动画特效什么的,让用户明白应用运行正常,只不过是在等待网络数据。如果能显示数据读取的进度条那就更好了,不过事先和开发人员商量一下开发难度(参考本文第二点)。
错误7. 盲目借鉴其它移动平台风格
糟糕的抄袭只会让用户感到疑惑和愤怒。每一个移动平台都有自己的风格,平台厂商也已经依据其平台自身的审美诉求撰写类似苹果的Human Interface Guidelines之类的指导性文档(译者:Android现在也有类似的文档)。在iPhone上开发类似Windows Phone 7的Metro风格应用就很可能让习惯了iOS的用户感到无从下手。
我想说的是,你的应用并不一定要和官方应用一模一样,但也不能看起来另类到像不属于这个平台一样。
错误8. 过分拥挤的界面
在高PPI下设计移动应用界面,你可能不知不觉中就在一个屏幕里放了太多的东西。在27″的iMac屏幕上看设计图,你的设计是那么的赏心悦目。请在移动设备上再多看一眼(哪怕仅仅是把设计图导入手机相册看),可能就不是那么回事了。在一个屏幕内塞太多的元素,会让用户操作起来费力,甚至淹没了最重要的信息。
错误9. 认为所有用户都和你一样的使用应用
无论你的应用界面看起来有多赞,都要做可用性测试。你可以在熟人圈内开展小规模的beta测试,记住让一些资深的设计师也参加。根据他们的反馈,在最终发布前调整界面。你也可以在Craigslist上发布广告,邀请一些学生来试用新产品,记得提供比萨或者一点报酬什么的。
错误10. 忘记使用或者滥用手势操作
记住并不是所有界面元素都必须直观的被用户看到,有时我们可以隐藏一些惊喜。
拿iPhone上面的官方邮件应用 (译者:又是老生常谈的例子),用户可以在收件箱中通过横扫邮件标题激活删除功能,这就免去了用户点击“编辑”、选择邮件、选择删除的麻烦。这里我们发现有个平衡点:老用户可能发觉出用手势完成快速删除,同时保留“编辑”按钮以便不熟悉的用户完成删除、标记等其它操作。所以,善用手势但不能过分倚重手势,一般来说要最好不要用手势操作替代菜单等需要点选操作的界面元素。
总结
如果要用一句话概括文本提到的点点滴滴,那就是:好的设计是经过深思熟虑的。带着审慎的态度全面的考察你的设计,真正的从用户的角度出发想问题。不要试图走走捷径,也不要跳过测试,不要设计出连你自己都拿不出手的东西
在了解了跨平台移动应用设计的利弊和移动应用开发常见错误之后,你想到了一个不错的应用创意,你甚至连应用的名字都想好了,接下来该干什么?
现在,我们要谈谈设计了。你需要考虑移动应用的功能结构、用户流程等问题,而这些并不是那么容易。考虑到进入开发阶段我们会涉及到诸如需求变动、项目管理等棘手的问题,所以在设计阶段,我们需要给自己制定一些原则,并且要切合实际的开展工作。这样我们才能开发出一款好用又有趣的应用。忽略这些潜在的问题而盲目瞎干,你很有可能在此后的开发阶段陷入灾难。
本文试图帮助移动应用设计者在工作中避免一些难缠的麻烦,希望你的应用以及你的设计思路均能因此受益。
错误1. 在弄清用户流程之前匆忙开始界面(草图)设计
在开始界面设计前,我们要先把完整的用户流程详细的走通顺走清楚。哪怕是再简单的应用,为了确保用户流程逻辑正确、界面布局合理,我们需要反复推敲用户流程并绘制类似上面的流程图。另外值得注意的是,最好把关键功能绘制在流程图靠近顶部的地方,而不是被层层分支淹没在底部。
跳过此环节而草率的开始界面设计,最终开发出的应用很可能在使用流程上不够清晰合理,用户上手后不得其解,兴趣索然。
错误2. 低估开发成本
设计师在Photoshop中画出的任何东西,最终都需要通过开发人员的代码在屏幕上表现。原本只需几小时开发的功能,由于设计师的一个看似细微的改动,可能会多耗费几天的开发时间。所以,在设计过程中要避免画蛇添足。
换句话说,如果设计师主导了移动应用功能的取舍,那后果会很严重。举个搜索框的例子,原本相对简单的一个功能,设计师灵光乍现——在用户输入关键词的同时不断给出实时的搜索结果。这个看似细节的改动,很可能让开发人员当场吐血。像这种的功能改动最好经过多方讨论后做出决策,而不是任由设计师自说自话。
错误3. 在低分辨率下设计,使用位图文件
始终坚持为Retina屏幕的高分辨率绘制设计图,然后以此输出低分辨率版本图片。这对于老手来说是常识,我们在这里再啰嗦几句。大家都知道,移动设备的常见屏幕尺寸是越来越五花八门(以iOS平台 为例,迄今需要考虑的就有4种分辨率)。所以,绘制高分辨率版本的图片,甚至是使用矢量图而不是位图,这些有助于设计师效率最大化,以及更好的应对未来的新硬件。
错误4. 触摸区域太小
普通人的食指触摸面积在1.6至2厘米见方,而且在使用移动应用的大多数时间里,他们的手指飞快的掠过屏幕。设计移动应用界面需要时刻提醒自己这一点,用户的触摸并不能像鼠标点击一样精确。看看你的设计是不是在一屏里包含了太多的按钮等功能触发点,按钮是不是足够大,间距是不是足够宽,会不会发生用户点选不到或者误按其它按钮的问题?
错误5. 滥用开场动画
在启动时播放一段精致的动画似乎是个不错的想法,但切忌不要为了动画而动画。Path和Thrillist’s JackThreads使用很酷的开场动画是因为这些应用启动需要一些时间,在程序完成加载之前用户什么也不能做(译者:Path启动貌似没有啥动画,难道是针对老版本说的?)。这种情况下,为用户准备一段简短愉悦的动画以消除等待的焦虑就显得很合时宜了。
由于应用启动时必须首先显示一张静待图片(译者:如iOS应用的Default.png),然后才能切换到动画,所以务必确保这个切换看起来天衣无缝。一些不好的例子在处理这个环节的时候产生了不协调的跳转或者闪屏,这都是需要避免的。(译者:优酷iPad应用的早期版本存在这种切换,处理中有一闪而过的黑屏,现在的版本把动画直接去掉了)
错误6. 让用户不知所措的原地等待
在程序加载、处理数据、或者等待网络反馈时不给用户及时的反馈,会让用户误认为应用挂了,这也是一种不好的用户体验。
举例来说:通过网络加载数据的同时,不要让用户傻傻的盯着一个空白的屏幕等待,显示一个转菊花或者动画特效什么的,让用户明白应用运行正常,只不过是在等待网络数据。如果能显示数据读取的进度条那就更好了,不过事先和开发人员商量一下开发难度(参考本文第二点)。
错误7. 盲目借鉴其它移动平台风格
糟糕的抄袭只会让用户感到疑惑和愤怒。每一个移动平台都有自己的风格,平台厂商也已经依据其平台自身的审美诉求撰写类似苹果的Human Interface Guidelines之类的指导性文档(译者:Android现在也有类似的文档)。在iPhone上开发类似Windows Phone 7的Metro风格应用就很可能让习惯了iOS的用户感到无从下手。
我想说的是,你的应用并不一定要和官方应用一模一样,但也不能看起来另类到像不属于这个平台一样。
错误8. 过分拥挤的界面
在高PPI下设计移动应用界面,你可能不知不觉中就在一个屏幕里放了太多的东西。在27″的iMac屏幕上看设计图,你的设计是那么的赏心悦目。请在移动设备上再多看一眼(哪怕仅仅是把设计图导入手机相册看),可能就不是那么回事了。在一个屏幕内塞太多的元素,会让用户操作起来费力,甚至淹没了最重要的信息。
错误9. 认为所有用户都和你一样的使用应用
无论你的应用界面看起来有多赞,都要做可用性测试。你可以在熟人圈内开展小规模的beta测试,记住让一些资深的设计师也参加。根据他们的反馈,在最终发布前调整界面。你也可以在Craigslist上发布广告,邀请一些学生来试用新产品,记得提供比萨或者一点报酬什么的。
错误10. 忘记使用或者滥用手势操作
记住并不是所有界面元素都必须直观的被用户看到,有时我们可以隐藏一些惊喜。
拿iPhone上面的官方邮件应用 (译者:又是老生常谈的例子),用户可以在收件箱中通过横扫邮件标题激活删除功能,这就免去了用户点击“编辑”、选择邮件、选择删除的麻烦。这里我们发现有个平衡点:老用户可能发觉出用手势完成快速删除,同时保留“编辑”按钮以便不熟悉的用户完成删除、标记等其它操作。所以,善用手势但不能过分倚重手势,一般来说要最好不要用手势操作替代菜单等需要点选操作的界面元素。
总结
如果要用一句话概括文本提到的点点滴滴,那就是:好的设计是经过深思熟虑的。带着审慎的态度全面的考察你的设计,真正的从用户的角度出发想问题。不要试图走走捷径,也不要跳过测试,不要设计出连你自己都拿不出手的东西
发表评论
-
Android SDK下载速度慢无法更新?使用国内镜像站加速
2016-01-29 18:18 733https://blog.kuoruan.com/24.htm ... -
探秘腾讯Android手机游戏平台之不安装游戏APK直接启动法
2014-08-01 12:02 399原文地址:http://blog.zhourunsheng.c ... -
关于ViewPager和Fragment
2014-07-07 14:18 1014原文地址:http://www.cnblogs.com/iho ... -
Android移动操作系统的脆弱性分类研究
2014-03-18 14:46 624下载地址:http://www.paper.edu.cn/re ... -
Android实战技巧:深入解析AsyncTask
2014-03-06 11:21 347原文地址:http://blog.csdn ... -
Ubuntu android真机调试
2014-03-06 11:01 449关闭adb服务,切换到root,重启adb服务,离开root ... -
64位Ubuntu配置android环境报错(...adb": error=2, 没有那个文件或目录)
2014-02-07 13:29 584原文地址:http://blog.csdn.net/jayho ... -
【Android 声音处理】MediaPlayer和SoundPool
2014-01-14 17:08 1894原文地址:http://blog.sina ... -
Android自定义组件之一:View详解
2013-07-15 16:08 761原文地址:http://www.eoeandroid.com/ ... -
Android中error inflating class fragment
2013-06-19 17:21 1094原文地址:http://blog.csdn.net/qp120 ... -
拿来主义Android优秀开源项目
2013-06-05 11:57 915http://dengzhangtao.iteye.com/b ... -
android sqlite db-journal文件产生原因及说明
2013-06-05 11:37 3569原文地址:http://blog.csdn.net/chthq ... -
Android系统自带Camera方向判别
2013-05-22 16:40 696使用了OrientationEventListener, 也就 ... -
android onTouchEvent和setOnTouchListener中onTouch的区别
2013-03-27 10:35 730原文地址:http://blog.csdn ... -
Android源码编译整理总结
2013-01-08 11:37 683原文地址:http://www.cnblogs.com/hoj ... -
安卓图表引擎AChartEngine(一) - 简介
2012-12-20 17:47 984原文地址:http://blog.csdn.net/lk_bl ... -
微技巧:Android手机隐藏指令大全
2012-12-07 11:36 766原文地址:http://news.xinhuanet.com/ ... -
自定义控件(attrs定义属性的使用)
2012-12-04 11:38 1151这里为了演示使用自定义变量,字体大小改用自定义的属性。 首先 ... -
二进制在数学中的妙用
2012-11-14 15:50 804原文地址:http://blog.csdn.net/hackb ... -
国外程序员推荐:每个程序员都应读的书
2012-11-06 10:58 800原文地址:http://blog.jobbole.com/58 ...
相关推荐
移动应用办公系统是一种现代企业管理和协作工具,它利用先进的信息技术,特别是互联网和移动通信技术,将传统的办公流程和任务管理转移到手机和平板等移动设备上。这种系统的主要目的是提高工作效率,增强团队协作,...
首先,"企业移动应用平台demo"通常是为了展示一个完整的企业级移动应用解决方案的样例,它可能包含了用户界面设计、数据处理、后台服务集成等多个方面的内容。这样的demo旨在让开发者能够快速理解平台的功能和使用...
1.移动应用崩溃概况:移动应用崩溃是指应用程序在运行过程中出现强制关闭的现象。 2.app启动时间: app启动时间是指应用程序从启动到用户可以交互的时间。 3.应用交互分析:应用交互分析是指对应用程序交互性能的...
这样设计的目的是为了将不同类别的应用和服务隔离开来,避免一个应用的安全问题影响到其他应用,同时也能提供不同级别的安全保障,如金融应用可能需要更高的安全级别。多安全域技术使得SIM卡能够承载更多类型的服务...
最后,反模式是指在设计中应避免的错误做法,如标新立异可能导致用户困惑,隐喻错位让用户难以理解,愚蠢的对话框和过多的确认框会打断用户流程,图表垃圾是信息可视化中的大忌,而按钮海则使界面显得混乱无序。...
它通过赛程中的激烈比拼,旨在全面提升参赛学生的移动互联网应用软件开发技能,为移动互联网产业输送具备扎实理论基础与实践操作能力的专业技术人才。 赛项规程所包含的三个核心比赛环节——程序排错、系统设计和...
在篡改和逆向工程的章节中,指南讲述了如何对移动应用进行逆向工程,以识别可能的安全漏洞和设计缺陷。身份认证架构章节则着重于如何确保移动应用的安全认证机制有效。 网络通信测试部分,则涉及确保移动应用数据...
书中详细讲解了Android大部分重要API的使用方法,并提供了专家级别的技术,指导如何高效管理开发团队和项目,以节省开发时间并避免开发中的常见错误。此外,本书还向读者展示了如何使用Android的硬件API,以及与数据...
9. **无障碍设计**:移动Web设计应考虑到所有用户,包括视觉、听觉或其他障碍的人群。遵循WCAG(Web Content Accessibility Guidelines)标准,确保内容对辅助技术友好。 10. **测试与迭代**:设计完成后,应在各种...
移动应用开发涉及界面设计、数据处理、网络通信等多个方面。开发者需要了解Android的Activity生命周期、Intent机制、布局管理以及自定义View等核心概念。 **3. 用户界面(UI)设计** UI设计是移动应用的重要组成...
2. **处理不确定性**:移动设备可能面临网络不稳定、电量不足等问题,设计时应考虑这些因素,提供合理的错误信息或状态提示。 3. **利用传感器**:现代移动设备配备了多种传感器,如GPS、陀螺仪等,合理利用这些...
在移动应用开发中,本地缓存机制扮演着至关重要的角色,它能显著提升用户体验,减少对网络的依赖,尤其在离线或者网络不稳定的情况下。本文将深入探讨如何为iOS平台设计一个高效的本地缓存系统。 首先,理解本地...
移动应用开发及安全实验操作手册1提供了五个不同的实验,涵盖了Android应用的基本开发流程以及与安全相关的实践。以下是每个实验的详细说明: 实验1:Android开发环境搭建 在本实验中,学习者需要按照课程指导安装...
这为我们提供了研究移动应用特性的机会,进一步提升跨平台开发的能力。 总之,这个压缩包中的源码资源为Android应用开发的学习提供了丰富的素材,无论是对于初学者还是有一定经验的开发者,都能从中获益。通过阅读...
移动应用加固工具源码是针对Android或iOS平台上应用程序的一种安全技术,目的是提高应用程序的抗逆向工程能力,防止恶意攻击者通过反编译、调试、篡改等方式获取应用的敏感信息或破坏其正常运行。本项目的核心是实现...
### 全国职业院校技能大赛高职组移动互联网应用软件开发...每一道题目都需要考生深入理解题目要求,并结合移动应用开发的相关知识和技术进行解答。通过这些练习,不仅能够提高编程能力,还能够锻炼解决实际问题的能力。
**在移动通讯中的应用** 移动通信中,DSP技术发挥着至关重要的作用,主要体现在以下几个方面: 1. **调制与解调**:移动通信系统中,信号需要经过调制才能在无线信道上传输。常见的调制方式如AM、FM、ASK、FSK、...