LeapMotion v2 中文文档
  • Introduction
  • 语言
    • Introduction
    • C++
      • 文档概述(v2.3)
      • 骨骼追踪模型概述
      • API 综述
      • 设计指南
        • 菜单设计指南
        • 用户导向与教程设计指南
        • 应用展示与营销指南
        • 用户体验设计指南
      • 应用程序开发
        • SDK 库
        • 快速入门
        • 项目设置
        • 系统架构
        • 运行时配置
        • 控制器策略
      • 使用追踪 API
        • 连接到控制器
        • 追踪模型
        • 帧
        • 手
        • 手指
        • 手势
        • 触摸仿真
        • 运动
        • 坐标系统
        • 相机图像
        • 序列化追踪数据
      • API 参考
        • Arm
        • Bone
        • CircleGesture
        • Config
        • Controller
        • Device
        • DeviceList
        • FailedDevice
        • FailedDeviceList
        • Finger
        • FingerList
        • Frame
        • Gesture
        • GestureList
        • Hand
        • HandList
        • Image
        • ImageList
        • InteractionBox
        • KeyTapGesture
        • Listener
        • Matrix
        • Pointable
        • PointableList
        • ScreenTapGesture
        • SwipeGesture
        • Tool
        • ToolList
        • Vector
      • 附录
        • Leap Motion Release Notes
        • 使用 LeapMotion 控制面板
        • 使用可视化诊断工具
        • WebSocket 通信
        • 鸣谢
    • Objective-C
      • 文档概述(v2.3)
      • 骨骼追踪模型概述
      • API 综述
      • 设计指南
        • 菜单设计指南
        • 用户导向与教程设计指南
        • 应用展示与营销指南
        • 用户体验设计指南
      • 应用程序开发
        • SDK 库
        • 快速入门
        • 项目设置
        • 系统架构
        • 运行时配置
      • 使用追踪 API
        • 连接到控制器
        • 追踪模型
        • 帧
        • 手
        • 手指
        • 手势
        • 触摸仿真
        • 运动
        • 坐标系统
        • 相机图像
        • 序列化追踪数据
      • API 参考
        • LeapArm
        • LeapBone
        • LeapCircleGesture
        • LeapConfig
        • LeapController
        • LeapDelegate
        • LeapDevice
        • DeviceList
        • LeapFinger
        • FingerList
        • LeapFrame
        • LeapGesture
        • GestureList
        • LeapHand
        • LeapImage
        • ImageList
        • LeapInteractionBox
        • LeapKeyTapGesture
        • LeapListener Protocol
        • LeapMatrix
        • LeapPointable
        • LeapPointableList
        • LeapPointableOrHandList
        • Category
        • LeapScreenTapGesture
        • LeapSwipeGesture
        • LeapTool
        • LeapVector
      • 附录
        • Leap Motion Release Notes
        • 使用 LeapMotion 控制面板
        • 使用可视化诊断工具
        • WebSocket 通信
        • 鸣谢
    • Python
      • 文档概述(v2.3)
      • 骨骼追踪模型概述
      • API 综述
      • 设计指南
        • 菜单设计指南
        • 用户导向与教程设计指南
        • 应用展示与营销指南
        • 用户体验设计指南
      • 应用程序开发
        • SDK 库
        • 快速入门
        • 项目设置
        • 系统架构
        • 运行时配置
      • 使用追踪 API
        • 连接到控制器
        • 追踪模型
        • 帧
        • 手
        • 手指
        • 手势
        • 触摸仿真
        • 运动
        • 坐标系统
        • 相机图像
        • 序列化追踪数据
      • API 参考
        • Arm
        • Bone
        • CircleGesture
        • Config
        • Controller
        • Device
        • DeviceList
        • Finger
        • FingerList
        • Frame
        • Gesture
        • GestureList
        • Hand
        • HandList
        • Image
        • ImageList
        • InteractionBox
        • KeyTapGesture
        • Listener
        • Matrix
        • Pointable
        • PointableList
        • ScreenTapGesture
        • SwipeGesture
        • Tool
        • ToolList
        • Vector
    • JavaScript
      • 文档概述(v2.3)
      • 骨骼追踪模型概述
      • API 综述
      • 设计指南
        • 菜单设计指南
        • 用户导向与教程设计指南
        • 应用展示与营销指南
        • 用户体验设计指南
      • 应用程序开发
        • SDK 库
        • 快速入门
        • 项目设置
        • 系统架构
        • 运行时配置
      • 使用追踪 API
        • 连接到控制器
        • 追踪模型
        • 帧
        • 手
        • 手指
        • 手势
        • 触摸仿真
        • 运动
        • 坐标系统
        • 相机图像
        • 序列化追踪数据
      • LeapJS 插件
      • API 参考
        • Leap namespace
        • Bone
        • CircleGesture
        • Controller
        • Finger
        • Frame
        • Gesture
        • Hand
        • InteractionBox
        • KeyTapGesture
        • Pointable
        • ScreenTapGesture
        • SwipeGesture
        • Matrix
        • Vector
      • 附录
        • Leap Motion Release Notes
        • 使用 LeapMotion 控制面板
        • 使用可视化诊断工具
        • WebSocket 通信
        • 鸣谢
Powered by GitBook
On this page
  • 菜单交互
  • 菜单设计与布局
  • 近邻高亮
  • 放射状菜单
  • 网格菜单
  • 菜单访问与退出
  • 反馈,反馈,反馈!

Was this helpful?

  1. 语言
  2. Objective-C
  3. 设计指南

菜单设计指南

Previous设计指南Next用户导向与教程设计指南

Last updated 5 years ago

Was this helpful?

无论从菜单的易用性上还是只是整个程序的使用体验来说,向用户提供更直观的控制方式确保最终用户简单地进行控制,这对于开发完善的程序来说是极其重要的。更需要注意的是,很多时候这些人是第一次与你的软件进行互动,如果连在菜单上的简单交互体验都觉得非常混乱和费力,他们很可能就会开始不喜欢你的软件,甚至不会再使用你的软件了。所以菜单设计方面显然需要花更多的心思来做得更好!

尽管到目前为止很多已有的最佳实践可以应用到 LeapMotion 的开发上,但是这仍然没有让我们认为现在已经可以把桌面和移动菜单的交互转移到三维上,使用 LeapMotion 来进行所有的交互。所以当你在设计实现你的程序菜单时如果遇到交互问题,可以参考我们在开发者社区中建立的一些指南来增强您的应用程序的体验。

菜单交互

使用菜单这个行为会在我们的应用程序中经常被重复,因为这是可能是所有功能连结的中介。因此菜单的交互需要让用户感觉更加自然和可靠,不需要让大多数用户为了操作去学习复杂的手势。为了避免用户使用菜单时出现沮丧情绪,宁可用最基础可靠的方法也不要用太过新颖独特的创意。

菜单设计与布局

无论如何,你必须让你的菜单保持可用性、易读性和简单性的交互来适应你的作品。在不同的按钮中间必须留有空隙方便用户选择而不会很容易就错误点击到另一个。

在这个示例菜单中你可以看到工作中的最佳实践应该是什么样子的。

  1. 应该保持按钮足够大,易于辨认而且有一个高亮/被点击的状态

  2. 高亮的按钮可以使用对比(反向)颜色使得按钮中的文字更加清晰易读

  3. 退出按钮在菜单界面中应该特别容易被找到

  4. 如果菜单使用了手势,那么这个手势必须非常简单,推荐是在区域中设置简单的敲击。

近邻高亮

另一种可以简化你的菜单设计的方法是你对菜单提供一种基于亲近而选择高亮的主题。这样做可以让离指针最近的菜单选项高亮,而不用必须将指针保持在选项上。在下面这个例子中,五个选项都被用外框线标明如何选择并使他们工作,当前用户的指针在左上角,所以左上角的选项亮了,这时候只需要执行点击手势 Play 按钮就会被触发,这种预测行为的办法可以降低用户的学习成本和挫败感。

把菜单布局和亲近高亮原则结合起来就能做出易于使用的菜单,但是通常来说这并不能做出好看并且易于让 LeapMotion 程序来使用的菜单。以下这些例子使用放射状或者网格状的菜单,希望能加深您对菜单交互这个课题的理解。这些例子使用点击(z轴)来作为激活交互方案。除此之外他们也包括了当每一个选项被选中时清晰的高亮反馈,当你在不同选项之间选择的时候会伴随着音效的提醒。最后用光标的变化来表示手指在z轴上的变化,让用户知道自己正在点击这个选项。

放射状菜单

以下这些放射状菜单展现了如何快速把一堆选项用排列成戒指或者派这样的形状。当你需要选择这种菜单中的某一项的时候,你只需要将指标选择这块区域的某一点就能选中这一项,其实就是通过扩大选项面积来减少选中难度。而菜单最中央的区域你可以用来做为一个最重要的区域,也可以仅仅作为非选择区域。

网格菜单

和放射状菜单相似,使用列/排布局的栅格菜单也能让用户轻松选中对应的选项。

菜单访问与退出

有鉴于此,应该用简单易用的方式来设置访问菜单及退出应用程序的方法。

  • 对于很多游戏和应用来说,当用户把手从检测范围内离开的时候,应该显示一个类似『Continue, Main Menu, Quit』的对话框

  • 在菜单上,『返回』按钮,『设置』按钮应该做得很显眼

  • 『Exit』 或者 『Quit』 之类的离开按钮同样应该做得显眼

  • 离开按钮应该是彻底关闭程序,而不应该是返回菜单或者其他什么功能

  • Mac上的 Command-Q 或者 Windows上的 Alt-F4 也要能起到退出的功能

  • 同时要保持你的菜单对于鼠标来说也是可以访问的

第一人称射击游戏中,当用户从检测范围移开手的时候,应该像上图一样把所有运动和游戏参数暂停。

反馈,反馈,反馈!

无论你选择什么方式来让用户使用你的产品,你都要保证在用户操作的过程中有足够的提示和反馈来返回给用户,让用户知道自己的操作没有错误,从而不会在操作过程中因为过高的学习成本而产生沮丧情绪。用户在操作过程中必须立刻知道哪个元素是可以被交互的 —— 类似 『点击按钮来选择一篇文章』 这种简单的提示应该在菜单设计中加入。

一旦用户开始和菜单中的选项交互,流畅自然的视觉反馈和听觉反馈就应该贯穿着整个过程,比如鼠标在按钮上方时时应该马上高亮,滑块的滑动应当更加流畅等等。你对用户进行了更多的引导,他们就更容易完成各项操作。

Frog Dissection 在按钮被选择时使用变大和变亮的方式来告诉用户按钮正在被选中。

Sky Muffins 这个应用在你指向选择按钮的时候使用 『填充』 的方式来告诉用户按钮正在被选中。

你可以在找到在线示例。

你可以在找到在线示例。

像文章前面建议的那样,这两个应用用了 Leap Motion Touch Zone 方面的 API 来处理点击按钮的相关反馈。关于这个API更多的内容,请查看和这篇博文,而这篇文章主要告诉我们如何从一个开发者的角度来更好地使用这个API。

这里
这里
触摸仿真
LeapMotion 的点击识别 API
5 Cell Radial Menu with Center Target
6 Cell Symmetrical Radial Menu
7 Cell Radial Menu with Center Target
4 Cell Symmetrical Radial Menu with 2 Columns