《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案例场景,这个场景中展示了插件中大部分手势的案例,该场景打开后的界面如下图所示。


7cf2d74f08d04df1ff8d490c8a1a6232bd1f61ec

上图中的场景展示了下列手势:
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组件的参数如下图所示。


3aae6b99e4ecad953cbd946291fcaed4c7c32dd8

上图中的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 +鼠标左键滑动控制模型缩放。


910fe87cc05304a04c2ff1688600bbc29759aa33

在实现缩放控制的时候,EasyTouch为我们提供的接口也特别简单。与旋转模型类似,只需要给被旋转的物体加上一个QuickPinch组件,但是不要忘记给物体再添加一个碰撞器组件。
5.拖动模型
拖动模型是指,当鼠标或手指选择屏幕中的某个物体之后,拖动手指,物体会跟随手指进行移动,如果不借助插件,则实现步骤如下。
(1)通过Unity中的Input类获取当前鼠标的位置或触摸点的位置,返回的坐标信息为屏幕坐标。
(2)将获取的屏幕坐标转换为世界坐标,这个步骤可以通过Camera中的ScreenToWorldPoint
方法来实现。
(3)将模型的位置移动到转换后的世界坐标位置。
上述实现过程比较麻烦,因此我们直接采用EasyTouch中的QuickDrag组件实现。我们只需要给被拖动的物体添加QuickDrag组件。如果要实现两个手指拖动,则添加TwoDragMe这个脚本组件就可以了。
本节关于手势控制的内容已经介绍完毕,其实EasyTouch还拥有其他一些手势控制和功能,大家可以参考它的帮助文档。
相关文章
|
6月前
|
设计模式 测试技术 vr&ar
提升你的Android开发技能:从AR/VR沉浸到UI设计和故障排除(三)
提升你的Android开发技能:从AR/VR沉浸到UI设计和故障排除
|
6月前
|
人工智能 机器人 区块链
提升你的Android开发技能:从AR/VR沉浸到UI设计和故障排除(二)
提升你的Android开发技能:从AR/VR沉浸到UI设计和故障排除
|
4天前
|
定位技术 vr&ar Android开发
AR与VR在安卓开发中的应用案例
【4月更文挑战第14天】AR和VR技术在安卓开发中日益普及,改变生活和工作方式。AR应用于导航、教育、零售,如AR导航、解剖学教学工具和虚拟家居预览。VR则创造虚拟环境,用于游戏、旅游和健身,如VR游戏“Beat Saber”、虚拟旅游和VR健身应用。这些技术在医疗、房地产等领域也展现潜力,未来将有更多创新应用出现,开发者应关注并探索其可能性。
|
2月前
|
数据可视化 安全 vr&ar
VR vs AR到底谁更有潜力改变未来?
VR vs AR到底谁更有潜力改变未来?
29 0
|
3月前
|
人工智能 物联网 vr&ar
AR与VR技术的融合:开启全新的现实体验
在当今快速发展的科技领域中,混合现实(AR)和增强现实(VR)技术成为引人注目的热门话题。本文将探讨AR与VR技术的融合应用,以及它们给我们带来的全新现实体验。通过结合虚拟和真实世界的元素,AR与VR技术正逐渐改变着我们对于交互、娱乐、教育和工作的理解。
|
11天前
|
编解码 数据可视化 vr&ar
干货! 2023 VR/AR行业全貌深度剖析!
干货! 2023 VR/AR行业全貌深度剖析!
|
4月前
|
存储 数据处理 vr&ar
实时云渲染技术为何被称为VR和AR领域的加速剂?
实时云渲染技术为何被称为VR和AR领域的加速剂?
|
4月前
|
运维 安全 vr&ar
VR和AR引领的工业元宇宙:数字化革命的引擎
VR和AR引领的工业元宇宙:数字化革命的引擎
|
5月前
|
vr&ar
VR和AR的区别
VR和AR的区别
|
6月前
|
缓存 Java vr&ar
提升你的Android开发技能:从AR/VR沉浸到UI设计和故障排除(一)
提升你的Android开发技能:从AR/VR沉浸到UI设计和故障排除

热门文章

最新文章