`
Beyon_javaeye
  • 浏览: 68844 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

Gestures

 
阅读更多
Gestures
  目前Touch Screens技术在不同的应用领域发挥着重要的作用。尤其各种智能移动设备向着更薄、更轻、更强大的方向发展,这对于人机交互提出了更高的要求。凭借触摸屏技术,使用者将从繁琐的按键操作逐渐过渡为利用各种手势快速和准确的实现人机交互,比如轻轻触摸、拖拽、甩或者滑动等一系列的简单手势快速的实现一些常规的命令操作。
  在Android 1.6之前的版本中,需要开发者编写大量的代码才能实现某些更为复杂的Gestures功能。为了让Gestures技术可以被方便的嵌入到第三方软件中,Android 1.6 SDk中嵌入标准的Gestures API库(Package: android.gesture),包括了所有与Gesture技术相关的操作:存储、加载、创建新Gestures和识别等。接下来将通过具体的例子全面的介绍如何将Gestures技术加入到Application中。开始前请先下载实例的源码。

创建一个Gestures Library
  Gestures Builder 在Android 1.6 SDK 中作为系统工具经Emulator启动时被默认加载。开发者可以直接通过Gestures Builder工具创建一批Gestures库,并添加到自己的程序中为用户提供可直接使用的Gestures行为。如果希望用户可以在程序中自定义 Gestures信息,也可以将Gestures Builder作为一个单独的模块整合到程序中,使用的方式与单独操作Gestures Builder工具完全一致。Gestures Builder工具的源码存放在Samples中,建议大家亲自尝试。使用Gestures Builder生成的gestures集合将自动存放在SD Card中。如果使用Emulator调试程序,需要在使用Gestures Builder之前确保当前有可用的虚拟SD Card映射。下边的截图表示当前已经添加三个gestures。

  上边的图示中可以看到每个条目包含两个基本元素,gesture 2D信息和标签,标签在Application中起到索引的作用。在同一个Application中允许包含一个以上带有相同标签的集合,这样可以提高某 些指令被准确识别的几率。利用Gestures Builder添加或者编辑gestures,生成的最终文件存放在SD card中的 gestures目录。可以直接将这个目录下的gestures拷贝到Application的/res/raw中作为默认的gestures资源。

加载Gestures Library
  根据前一节的了解,完全可以掌握利用Gestures Builder创建gestures的方法,并将生成的文件捆绑在自己的应用程序中,作为默认的gestures库。接下来了解如何在 Applicationg程序中加载库中的gestures资源(利用GestureLibraries类可以非常容易处理这个请求):
mLibrary = GestureLibraries.fromRawResource(this, R.raw.spells);
if (!mLibrary.load()) {
    finish();
}

  上边的代码实现了调用gestures前的准备工作。另外除了从本地raw中获取资源以外,也可以直接从SD Card中加载资源,特别针对允许用户自行创建gestures的应用程序,需要在程序中实现基于SD Card的读取和存储方法。由raw中读取的gestures仅具有可读属性,用户无法编辑默认捆绑在Application中的gestures资源。
  下边的图标展示了Gesture Library的层级结构。

Gestures的识别方法
  在应用程序中识别gestures包括绘制和识别两个部分。为了让用户可以直接在Applications表面绘制gestures,需要将下边的标签加入到当前窗口的XML Layout中。
<android.gesture.GestureOverlayView
    android:id="@+id/gestures"
    android:layout_width="fill_parent" 
    android:layout_height="0dip"
    android:layout_weight="1.0" />

  由于GestureOverlayView类并不属于android.widget资源范畴,因此调用时必须提供完整名称(Botton或者其它的 Views只需要提供Short Name就可以直接被系统识别)。Gesture overlay相当于一块简单的绘画板,允许用户绘制各种gestures。Gesture overlay的显示属性可以根据应用程序的整体样式而制定合适的色彩和笔触宽度。利用Listener跟踪Gestures的不同行为,从而相应用户的 细微操作。其中OnGesturePerformedListener是最常用的方法,当用户完成一次Gesture绘制后,系统将自动运行这个 Listener中的代码。至此,完成了Gestures识别功能中的第一个步骤。
GestureOverlayView gestures = (GestureOverlayView) findViewById(R.id.gestures);
gestures.addOnGesturePerformedListener(this);

  接下来通过GestureLibrary对用户绘制的结果进行比对,每次的比对结果将可能包括多个相似的结果。根据数量级(系统中会针对一个 Gesture创建多个实例,目的是达到更加精确的识别目的)的原则,依据降序的排列方法选择最贴近用户意图的结果。下边的代码实现了完整的“筛选”过程。
public void onGesturePerformed(GestureOverlayView overlay, Gesture gesture) {
    ArrayList<prediction> predictions = mLibrary.recognize(gesture);

    // We want at least one prediction
    if (predictions.size() > 0) {
        Prediction prediction = predictions.get(0);
        // We want at least some confidence in the result
        if (prediction.score > 1.0) {
            // Show the spell
            Toast.makeText(this, prediction.name, Toast.LENGTH_SHORT).show();
        }
    }
}

  根据代码的执行过程,recognize()的返回结果是一个prediction集合,包含了所有与gesture相匹配的结果。prediction 的score属性代表了与gesture得相似程度(通常情况下不考虑score小于1的结果)。以上是Gestures应用的两个基本功能的介绍,非常 简单的几行代码就就可以让你的程序支持当前最流行的人性化操作方式。

Gestures Overlay
  接下来介绍另外一个全新的用法。前面是将GestureOverlayView作为一般的View,被直接嵌入在LinearLayout的子集中。然 而,根据这个类名的直观理解是可以作为所有Views元素之上的一个Overlay来使用,更形象的解释是将GestureOverlayView看做一 个盒子,而其它的Views应用元素成为它的子集。这样的方式被普遍应用于游戏操作或者仅限制Application中的某一部分的UI支持 Gestures功能。接下来我们利用GestureListDemo例子来体验这种用法,实现的效果是在一个Contacts列表上创建一个 Gestures Overlay。首先仍然需要利用Gestures Builder初始化一些gestures数据:

  XML layout代码(完全不同于第一个例子的配置方法):
<android.gesture.GestureOverlayView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/gestures"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    
    android:gestureStrokeType="multiple"
    android:eventsInterceptionEnabled="true"
    android:orientation="vertical">

    <ListView
        android:id="@android:id/list"  
        android:layout_width="fill_parent" 
        android:layout_height="fill_parent"  />

</android.gesture.GestureOverlayView>

  当利用Gestures view的Overlay特性时,需要利用更多的属性来设置当前Gesture的状态,在第一个例子中则不需要考虑这些:
  1)gestureStrokeType:设置Stroke的类型。大多数情况下,gestures都是通过一笔完成。然而有一些特别的需求就需要通过多个笔画来实现,例如通过“+”来实现“Add”的行为。
  Single:0
  Multiple:1
  2)eventsInterceptionEnabled: 可以简单理解为当前应用程序在Gesture overlay模式下屏蔽其它Views Events的开关。当它设置为True时,所有基于当前应用程序屏幕的操作都被视作为绘制gestures的行为,从而避免用户与应用程序界面的交互造 成混乱。
  3)orientation:这个属性作为当前Gesture recognizing的参考标准(相当于filter的作用),例如:在这个例子中的Items垂直排列,所有基于Overlay的垂直 (vertical) gesture,都无法被识别为有效的gesture,其与当前的垂直滚动条操作造成混淆。对于水平 (horizontal) gesture可以立即识别为有效的gesture,或者任何以垂直为起始的操作需要至少包含一段水平的绘制轨迹才可以被正常识别。
  Horizontal : 0
  Vertical : 1
public void onGesturePerformed(GestureOverlayView overlay, Gesture gesture) {
    ArrayList<Prediction> predictions = mLibrary.recognize(gesture);
    if (predictions.size() > 0 && predictions.get(0).score > 1.0) {
        String action = predictions.get(0).name;
        if ("action_add".equals(action)) {
            Toast.makeText(this, "Adding a contact", Toast.LENGTH_SHORT).show();
        } else if ("action_delete".equals(action)) {
            Toast.makeText(this, "Removing a contact", Toast.LENGTH_SHORT).show();
        } else if ("action_refresh".equals(action)) {
            Toast.makeText(this, "Reloading contacts", Toast.LENGTH_SHORT).show();
        }
    }
}

  根据上边的设置,目前用户可以基于ListView之上做任何Gesture操作,而不会与当前的Scrolling Events混淆。

  从视觉上可以直接判断当前Gesture是否有效的被当前Application识别。对于无效的Stroke将会以半透明的方式显示。

  相信很快这项技术将作为最基本的应用部署在大部分的应用程序中。让我们开始尝试创建第一个带有Gestures功能的应用程序吧!
  • 大小: 11 KB
  • 大小: 137.7 KB
  • 大小: 15.2 KB
  • 大小: 15.1 KB
  • 大小: 14.3 KB
  • 大小: 14.3 KB
分享到:
评论

相关推荐

    Fingers - Touch Gestures for Unity 2.3.5

    Gestures are restricted to most UI elements by default, but this is easily configured if you want the gestures to pass through additional UI elements. This asset works great with the default Unity UI ...

    CLEAN crxMouse Gestures-4.2.0.zip

    名称:CLEAN crxMouse Gestures ---------------------------------------- 版本:4.2.0 作者:Jeffrey 分类:实用工具 ---------------------------------------- 概述:本版本是基于crxMouse Gestures优化的版本,...

    Unity3d手势触摸插件 Fingers - Touch Gestures for Unity 2.5.6

    ### Unity3D手势触摸插件 Fingers - Touch Gestures for Unity 2.5.6 #### 插件简介 在当今的游戏开发领域,尤其是移动平台游戏的开发中,手势识别和触摸控制已成为不可或缺的一部分。Unity作为一款流行的游戏开发...

    Chrome Gestures 鼠标手势插件说明

    ### Chrome Gestures 鼠标手势插件说明 随着Google Chrome浏览器的推出,凭借其卓越的网页加载速度和高效的JavaScript处理能力,迅速赢得了广大用户的喜爱。然而,除了这些基础性能之外,Chrome还支持一系列强大的...

    mousegestures_x86

    在本例中,"mousegestures_x86" 提供了一个适用于Windows 7操作系统,并且支持IE浏览器的鼠标手势功能。 【支持WIN7】表示这个软件版本已经针对Windows 7进行了优化和兼容性测试,用户可以在Windows 7环境下顺利地...

    Fingers - Touch Gestures for Unity 2.9.3

    "Fingers - Touch Gestures for Unity 2.9.3" 是一个专为Unity游戏引擎设计的插件,它使得开发者能够轻松地在他们的项目中集成触摸手势功能。这个插件的版本号是2.9.3,意味着它可能已经经过多次更新和优化,以提供...

    MR.Gestures_v1.3.3_Downloadly.ir.rar

    《MR.Gestures_v1.3.3_Downloadly.ir.rar》是一款基于Delphi开发的手势控制软件的应用程序,主要用于提升用户的电脑操作体验。通过手势识别技术,它允许用户通过特定的手势在电脑上执行各种命令,从而实现更加便捷、...

    手势识别数据集-Gestures.rar

    这个"手势识别数据集-Gestures.rar"压缩包文件显然是一个专门用于训练和测试手势识别算法的数据集,涵盖了数字0到9的手势。 数据集在机器学习和人工智能领域扮演着至关重要的角色,它们为模型提供了学习的基础。在...

    谷歌鼠标crxMouse-Chrome-Gestures_v3.0.0.crx.7z

    【谷歌鼠标crxMouse-Chrome-Gestures_v3.0.0.crx.7z】是一款专为谷歌浏览器(Chrome)设计的扩展程序,旨在增强用户的浏览体验,通过鼠标手势来执行一系列快捷操作。这款扩展的最新版本为v3.0.0,采用7z压缩格式,...

    触摸手势 Fingers - Touch Gestures 2.2.3 for Unity

    《触摸手势:Fingers - Touch Gestures 2.2.3 for Unity》 在现代的交互式应用和游戏中,触摸手势已经成为用户界面不可或缺的一部分。Unity作为一款强大的游戏开发引擎,为开发者提供了丰富的工具来实现这一功能。...

    Mr._Gestures_for_Xamarin_2.1.0_Downloadly.ir.rar

    "Mr._Gestures_for_Xamarin_2.1.0_Downloadly.ir.rar" 这个标题表明我们正在处理一个名为 "Mr. Gestures for Xamarin" 的软件包,版本号为 2.1.0,格式为 RAR 压缩文件,下载来源可能是 Downloadly.ir 网站。这个...

    鼠标手势IE用MouseGestures_x860

    MouseGestures 最常用的IE鼠标手势

    smartUp-Gestures.chrome手势操作.zip

    Chrome手势操作插件,全名"smartUp-Gestures_v5.0.868.727.chrome手势操作",是一种专为谷歌浏览器(Chrome)设计的扩展工具,旨在提高用户浏览网页的效率和体验。这款插件通过自定义的手势动作,使用户能够快速执行...

    Android应用源码Gestures源码-IT计算机-毕业设计.zip

    在Android应用开发中,手势(Gestures)是用户与应用程序交互的重要方式,它使得用户可以通过触摸屏幕的各种动作来执行不同的操作。这份"Android应用源码Gestures源码"是一个专门为毕业设计学习准备的示例项目,它...

    MouseGestures

    【MouseGestures】是一种高效且实用的浏览增强技术,主要应用于网络浏览器,尤其是针对Internet Explorer(IE)设计。这项技术允许用户通过特定的鼠标动作来执行常见的浏览器操作,例如前进、后退、刷新页面、打开新...

    Fingers - Touch Gestures for Unity 2.9.3.unitypackage.zip

    《Unity3D中的触摸手势:Fingers - Touch Gestures 2.9.3》 Unity3D是一款广泛应用于游戏开发、虚拟现实(VR)、增强现实(AR)等领域的跨平台游戏引擎。随着触控设备的普及,触摸交互在游戏和应用中变得越来越重要。...

    Fingers - Touch Gestures for Unity 2.9.3.unitypackage 亲测unity2020可用!

    《Unity中的手势触摸技术:Fingers - Touch Gestures for Unity 2.9.3》 在Unity游戏开发中,触控交互已经成为移动平台和部分桌面平台应用不可或缺的一部分。"Fingers - Touch Gestures for Unity"是一款专为Unity...

    GesturesBuilder

    `GesturesBuilder`是一个专为Android平台设计的示例项目,它演示了如何实现并应用手势识别功能。在这个项目中,用户可以看到一个列表,该列表展示了可以被程序识别的各种手势。此外,通过工具栏中的“添加”按钮,...

    Gestures Demo.zip

    Gestures Demo介绍: 识别屏幕上的触摸动作。可以识别滑动屏幕的手势是水平划动还是竖直划动,从而产生不同的响应。Gif效果图中,如果手指是水平划屏,产生的划痕比竖直划屏产生的划痕要深。   测试环境: ...

    Fingers - Touch Gestures for Unity

    New Input System Compatible Fingers works on all Unity platforms. If you've used native mobile Android or iOS gestures, you will be right at home with Fingers.

Global site tag (gtag.js) - Google Analytics