《AR与VR开发实战》——3.3 手势控制

本节书摘来自华章出版社《AR与VR开发实战》一书中的第3章,第3.3节,作者 张克发 赵兴 谢有龙,更多章节内容可以访问“华章计算机”公众号查看。

3.3 手势控制

目前市场上流行的AR产品以儿童教育类产品居多,这些产品中大多会有手势交互的功能,本节就将讲解如何在AR产品中加入手势交互的功能。设想以下场景,在识别一个动物的卡片后,会出现该动物的3D立体影像,在识别丢失后,动物模型会停留在屏幕中心,并可以通过手势控制其旋转和缩放。
我们需要实现模型脱卡的功能,这个功能的实现已经在上一节做了详细讲解,本节不再赘述。
关于手势控制,最原始的方式是通过Unity 3D自带的Input类进行处理,但是为了快速实现我们想要达到的效果,可以借助一些插件来实现。用于手势处理的插件有Finger Gesture、LeanTouch和EasyTouch等,本节主要通过EasyTouch这个插件来讲解手势控制功能(本节使用的插件版本为EasyTouch 5)。
接下来,我们就逐步讲解EasyTouch的使用方法。
1.查看EasyTouch案例场景
正确导入EasyTouch插件之后,在Project视图中找到QuickGesture案例场景,这个场景中展示了插件中大部分手势的案例,该场景打开后的界面如下图所示。

上图中的场景展示了下列手势:
Touch:触摸手势。
Tap:点击手势。
Long tap:长按手势。
Drag:拖动手势。
Enter Over Exit:滑过手势。
Double tap:双击手势。
Swipe:滑动手势。
Twist:扭转手势。
Pinch:两个或多个手指挤压,常用于缩放。
2.EasyTouch初始化
EasyTouch初始化的方式非常简单,只需在场景中创建一个空的GameObject,将其命名为EasyTouch,然后在Inspector面板上点击AddComponent添加EasyTouch.cs脚本文件即可。
3.旋转模型
初始化模型的工作完成之后,接下来演示旋转模型的实现方式。查看之前案例场景中Horizontal Swipe下的物体,你会发现当鼠标在该物体上左右滑动时,就可以让物体发生水平方向的旋转,我们查看被旋转物体上的组件信息,发现该物体拥有一个名为QuickSwipe的组件。
因此,只要给需要旋转的物体添加QuickSwipe组件,即可让物体根据手势滑动的方向进行旋转。Quick Swipe组件的参数如下图所示。

上图中的Swipe direction选项表示判断手势滑动的方向,例如Horizontal表示水平方向,Vertical表示竖直方向。Action中的选项表示当手势触发之后,所影响的物体会发生哪些类型的动作,可以选择的动作有Rotate(旋转)、Translate(移动)和Scale (缩放),在此我们选择Rotate选项即可。Affected axes表示被影响的坐标轴,如果是水平方向渲染,则选择Y轴。Sensibility表示灵敏度,可以根据灵敏度调整旋转的速度,Inverse axis表示反向。
4.缩放模型
在手机App中,一般是通过两个手指在触摸屏幕上的距离远近变化来控制模型的大小,因此我们采用EasyTouch中的另外一种Pinch事件。在上述案例场景中我们可以看到这个事件,但是在Unity编辑器中无法通过鼠标模拟多点触控,EasyTouch的解决方案是:首先用Ctrl+鼠标左键确定第一个手指的位置,然后通过Alt+鼠标左键来控制第二个手指的位置与第一个手指的位置之间的距离。
(1)Ctrl +鼠标左键确定第一个手指的位置。
(2)Alt +鼠标左键滑动控制模型缩放。

在实现缩放控制的时候,EasyTouch为我们提供的接口也特别简单。与旋转模型类似,只需要给被旋转的物体加上一个QuickPinch组件,但是不要忘记给物体再添加一个碰撞器组件。
5.拖动模型
拖动模型是指,当鼠标或手指选择屏幕中的某个物体之后,拖动手指,物体会跟随手指进行移动,如果不借助插件,则实现步骤如下。
(1)通过Unity中的Input类获取当前鼠标的位置或触摸点的位置,返回的坐标信息为屏幕坐标。
(2)将获取的屏幕坐标转换为世界坐标,这个步骤可以通过Camera中的ScreenToWorldPoint
方法来实现。
(3)将模型的位置移动到转换后的世界坐标位置。
上述实现过程比较麻烦,因此我们直接采用EasyTouch中的QuickDrag组件实现。我们只需要给被拖动的物体添加QuickDrag组件。如果要实现两个手指拖动,则添加TwoDragMe这个脚本组件就可以了。
本节关于手势控制的内容已经介绍完毕,其实EasyTouch还拥有其他一些手势控制和功能,大家可以参考它的帮助文档。

时间: 2024-07-28 20:56:35

《AR与VR开发实战》——3.3 手势控制的相关文章

《AR与VR开发实战》——2.7 3D物体识别

本节书摘来自华章出版社<AR与VR开发实战>一书中的第2章,第2.7节,作者 张克发 赵兴 谢有龙,更多章节内容可以访问"华章计算机"公众号查看. 2.7 3D物体识别 2.5节和2.6节讲解了柱体识别和立方体识别,这两节的内容都只是针对简单几何体进行识别,在本节中,我们将介绍不规则三维物体的识别步骤和方法.1.下载并导入插件登录官网,点击Downloads下的Tools,下载Vuforia Object Scanner (Vuforia物体扫描器).Vuforia Obj

《AR与VR开发实战》——2.11 帧标记识别

本节书摘来自华章出版社<AR与VR开发实战>一书中的第2章,第2.11节,作者 张克发 赵兴 谢有龙,更多章节内容可以访问"华章计算机"公众号查看. 2.11 帧标记识别 在使用Vuforia进行开发时,我们总是强调识别图的识别度星级越高,越容易识别.那么假如在商业项目中,客户要使用的识别图的识别星级为0,该怎么办呢?这就是FrameMarker大展拳脚的时候了.本节我们将为大家介绍一个名叫FrameMaker的神奇功能.1.插件下载访问https://developer.

《AR与VR开发实战》——3.2 模型脱卡功能的实现

本节书摘来自华章出版社<AR与VR开发实战>一书中的第3章,第3.2节,作者 张克发 赵兴 谢有龙,更多章节内容可以访问"华章计算机"公众号查看. 3.2 模型脱卡功能的实现 在常见的AR项目中,识别到图像后会将3D物体叠加到识别目标之上并具有追踪效果,但是当识别目标丢失后,我们希望能够将3D模型停留在屏幕中心,并能够和用户进行交互,比如点击模型伴随动画切换.播放语音讲解等一系列功能.这个功能就是我们本节将要为大家介绍的脱卡功能.脱卡实现的原理是,将3D物体从识别目标下移出

《AR与VR开发实战》——第1章AR技术简介

本节书摘来自华章出版社<AR与VR开发实战>一书中的第1章,第1.1节,作者 张克发 赵兴 谢有龙,更多章节内容可以访问"华章计算机"公众号查看. 第1章 AR技术简介 增强现实(Augmented Reality,AR)是一种实时计算摄影机影像的位置及角度并加上相应图像的技术,这种技术的目标是在屏幕上把虚拟世界套在现实世界中并进行互动.这种技术于20世纪90年代提出,随着随身电子产品运算能力的提升,其用途将会越来越广.目前对于增强现实有两种通用的定义.一种定义是北卡大学罗

《AR与VR开发实战》——2.5 柱形识别

本节书摘来自华章出版社<AR与VR开发实战>一书中的第2章,第2.5节,作者 张克发 赵兴 谢有龙,更多章节内容可以访问"华章计算机"公众号查看. 2.5 柱形识别 Vuforia SDK提供了带有图像的柱形物体识别功能,柱形识别只针对柱形物体,配合包裹在柱体表面的图像来进行识别,比如识别饮料瓶.本节将介绍柱形识别的实现步骤和方法. Vuforia官方案例包登录Vuforia官网,进入Downloads页面,点击Samples选项,然后下载如下插件并解压. 在解压完成后找到

《AR与VR开发实战》——第3章 AR内容交互 3.1 动态加载AR模型

本节书摘来自华章出版社<AR与VR开发实战>一书中的第章,第3.1节,作者 张克发 赵兴 谢有龙,更多章节内容可以访问"华章计算机"公众号查看. 3.1 动态加载AR模型 在第2章中我们实现了通过Vufoira默认方式识别并显示三维模型.默认的加载模型是通过将3D物体直接放置在场景中并作为识别目标的子物体来实现的,这种实现方式的问题是,当场景中有很多识别目标后,需要一次性加载的模型内容会占用很大的内存.因此,在实际项目案例中需要动态加载识别目标对应的模型,在识别丢失之后删除

《AR与VR开发实战》——2.8 云识别

本节书摘来自华章出版社<AR与VR开发实战>一书中的第2章,第2.8节,作者 张克发 赵兴 谢有龙,更多章节内容可以访问"华章计算机"公众号查看. 2.8 云识别 在开发项目的过程中,当我们需要将识别图放置在服务器后台而不是App内部的时候,需要使用Vuforia的云识别功能,在本节中,我们将介绍Vuforia云识别的实现步骤和方法.1.创建License Key登录Vuforia开发者官网,点击Develop,在License Manager下面创建一个License K

《AR与VR开发实战》——2.3 创建AR视频

本节书摘来自华章出版社<AR与VR开发实战>一书中的第2章,第2.3节,作者 张克发 赵兴 谢有龙,更多章节内容可以访问"华章计算机"公众号查看. 2.3 创建AR视频 本节将介绍AR视频的创建,AR视频即识别某张图像并播放与所识别图像对应的视频文件,一般用于企业宣传册.广告.书籍等相关领域.我们将会继续使用Unity和Vuforia SDK来开发AR视频应用,关于Vuforia SDK的相关配置可参阅前面的章节.Unity默认支持的视频格式分别有.mov..mpg..mp

《AR与VR开发实战》——2.4 文字识别

本节书摘来自华章出版社<AR与VR开发实战>一书中的第2章,第2.4节,作者 张克发 赵兴 谢有龙,更多章节内容可以访问"华章计算机"公众号查看. 2.4 文字识别 本节介绍如何使用Vuforia和Unity实现文字识别功能.Vuforia对文字识别有一定的要求,首先,Vuforia能够识别的文字大多为英文,不能识别数字和中文.其次,默认能够识别的英文单词必须是官方词库中的单词(10万个),当然,还可以自定义添加英文单词.接下来我们通过Vuforia官方自带的案例来看一下文