【三星官方教程】如何为Gear VR开发应用(五):添加功能

2023-10-14 08:40

本文主要是介绍【三星官方教程】如何为Gear VR开发应用(五):添加功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

现在两个场景都已经制作完成,可以在照片查看器中加入一些功能了。这个应用中使用射线系统,从镜头发出射线,与场景中的物件发生碰撞。碰撞会检测到某些标记,从而通知系统运行一些特定的动作。这个应用里的主要功能包括前进,后退功能,以及播放幻灯。

在这期教程中,你将学到:

·建立射线以触发某个按钮

·建立一个用来瞄准按钮的准星

·建立一个对象,用来管理用户的输入,比如点击或触摸

·建立一个对象,当某个按钮被触发后,通知应用循环播放一系列不同的背景

·建立并实施对象的标签

·用脚本控制循环播放的属性,如时长和模式

·将图片载入球面

·在GearVR 上创建并运行完成后的app

 

1)使用替代场景

建议用前几期教程中制作的启动场景和主场景作为本期教程的起点。但如果你想用一个干净的文件来开始本期教程,也可以使用Unity自带的替代场景。

A.返回Unity,关闭Build Settings窗口。

B.Project窗口,找到/Assets/Workshop/Scenes/CatchUpScenes文件夹,打开 3_Main.unity 文件。

C.在菜单中,选择File > Save Scene as…。在Save Scene对话框,将文件名设为Main.unity并保存到/Assets/Workshop/Scenes文件夹。选择覆盖现有的Main.unity文件。

D.Project窗口,找到/Assets/Workshop/Scenes/CatchUpScenes文件夹,打开3_Splash.unity

E.在菜单中,选择File > Save Scene as…。在Save Scene对话框,将文件名设为Splash.unity并保存到/Assets/Workshop/Scenes文件夹。选择覆盖现有的Splash.unity文件。

 

2)为镜头加上射线

A.返回Unity,打开Main.unity文件。

B.Hierarchy窗口,选择OVRCameraRig>TrackingSpace>CenterEyeAnchor

C.选择Create > Create Empty Child


D.Inspector窗口,将空对象的名字改为Raycaster

E.点击Add Component按钮,选择Scripts >Raycaster。这样你就可以向一个目标发出射线。


 

3)为镜头加上准星

A.Hierarchy窗口,选择Create > 2D Object > Sprite

B.New Sprite拖到OVRCameraRig>TrackingSpace>CenterEyeAnchor中。


C.Inspector窗口,将Sprite的名字改为Reticle

D.有些对象会被放在不易找到的地方,而在场景中,很难精确地吧对象放在某个地方。在Transform部分,点击齿轮图标,选择Reset。这样可以把对象放在 (000)


E.Project窗口,打开/Assets/Workshop/Textures文件夹,把Reticle文件拖到Inspector窗口中的Sprite Renderer > Sprite输入框。


F.Transform部分,将PositionZ设为5。准星因位于播放幻灯按钮的正前方。

G.Scales XY,和Z设为0.1


H.点击Add Component按钮并选择Scripts > Reticle。这会使射线的轨迹遵循准星的位置。

I.Reticle部分,将Pressed Color设为绿色。


J.点击Play按钮预览场景。你应该可以看到播放幻灯按钮前面显示了白色的准星。

K.再次点击Play按钮退出预览。

 

4)创建InputManager对象

A.Hierarchy窗口,选择Create > Create Empty

B.Inspector窗口,将空对象的名字改为InputManager。这个对象是用来检测用户输入的。

C.点击Add Component按钮,选择 Scripts > Input Manager。当某个对象被轻触,Is Pressed的属性会在onoff 间切换。


 

5)创建Createthe AppManager

A.Hierarchy窗口,右击InputManager,选择Duplicate

B.Inspector窗口,将InputManager (1)的名字改为AppManager。这个对象用来通知系统对用户的输入采取什么反应。

C.Input Manager部分,选择Script输入框边上的target 按钮。在SelectMonoScript窗口,找到并选择ApplicationManager脚本。


当用户触动某个按钮,场景的背景材质会切换。所有的三个按钮都会打上标签,告诉app每个按钮的功能。例如:如果Button_Advance被触动,背景会切换到下一张材质。

 

6)定义对象标签

A.在菜单中,选择Edit > Project Settings > Tags andLayers

B.Inspector窗口,展开Tags部分。

C.点击Add (+) 按钮增加一个标签。将Tag 0内容设为IncrementButton

D.再增加两个标签,并设为如下内容:

Tag 1: DecremenButton

Tag 2: SlideshowButton

说明:IncrementButtonDecrementButton,和SlideshowButton这三个标签是专门为我们这个教程创建的,在这个app里一定要用到。如果你用其它标签,或名字拼写错误,app里的按钮将无法正常工作。


E.Hierarchy窗口,选择Buttons >Button_Advance

F.Inspector 窗口,将Tag的属性改为IncrementButton


G.下一步,将Button_Slideshow的标签改为SlideshowButton,将Button_Decrement的标签改为DecrementButton

H.保存场景。

 

7)加入TextureCycler脚本

A.Hierarchy窗口,选择AppManager

B.Inspector窗口,找到Application Manager 部分并展开Texture Object 分支。

Texture Object 的属性通知系统切换某个对象的材质。在这里,我们需要Sphere_Inv的材质随着点击按钮而切换。

C.Hierarchy窗口,将Sphere_Inv拖到Element 0


D.Hierarchy窗口,选择Sphere_Inv

E.Inspector窗口,点击Add Component按钮并选择Scripts > Texture Cycler。这一步指定了主场景中的起始材质,以及在slideshow模式下每张图片显示的时长。


 

8)创建TextureLoader对象

A.Hierarchy窗口,选择Create > Create Empty

B.Inspector窗口,将这个空对象的名称改为TextureLoader

这个对象告诉系统将哪些材质载入到AppManager Texture Object (在这里,我们使用wSphere_Inv)

C.点击Add Component按钮并选择Scripts > Texture Loader

D.Texture Loader部分,展开MStartingTextures

App Manager Texture Object中的材质可以切换后,这个脚本会先调用MStarting Textures (缺省的大小为1)MStarting Textures中的材质都用过之后,Texture Loader会载入MLocal Storage Dir Path中的PNGJPG文件。

E.MStarting Textures部分,将Size的数值改为3


F.Project窗口,打开/Assets/Workshop/Textures文件夹。你可以看到一些前缀为 “360” 的图片 (e.g.360_BritishColumbia.jpg)。挑选三张图片,把他们拖到三个Element的输入框里。


G.Texture Loader分支,找到MLocal Storage Dir Path并输入以下路径(必须完全按下面的路径输入)。这会告诉app你本地的360度图片在哪里。这里app会在手机根目录下找到名为 “Workshop”的文件夹。

/mnt/sdcard/Workshop/


说明:你需要在手机上创建Workshop 文件夹。可以打开手机上的My Files应用,点击Device storage > Menu >CreateFolder,创建Workshop文件夹。如果你有360图片想用这个app查看,只要把图片加到这个文件夹里,app会自动到这个文件夹里查看。

H.保存场景。

 

9)创建并运行这个应用

A.在菜单中,选择File > Build Settings…

B.Build Settings窗口,确认Scenes In Build中依次排列着以下两个文件:

Workshop/Scenes/Splash.unity(0)

Workshop/Scenes/Main.unity(1)

C.确认Platform设为AndroidTexture Compression设为ETC2 (GLES 3.0)

D.将手机用USB连接到电脑,并点击Build & Run按钮。

E.Build Android对话框,给APK文件取名并点击Save

F.Unity创建好app后,你会在手机上看到Insert device 对话框。这时可以断开与电脑的连接,将手机插入Gear VR运行你的场景。

这篇关于【三星官方教程】如何为Gear VR开发应用(五):添加功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/209377

相关文章

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Java MQTT实战应用

《JavaMQTT实战应用》本文详解MQTT协议,涵盖其发布/订阅机制、低功耗高效特性、三种服务质量等级(QoS0/1/2),以及客户端、代理、主题的核心概念,最后提供Linux部署教程、Sprin... 目录一、MQTT协议二、MQTT优点三、三种服务质量等级四、客户端、代理、主题1. 客户端(Clien

Golang如何用gorm实现分页的功能

《Golang如何用gorm实现分页的功能》:本文主要介绍Golang如何用gorm实现分页的功能方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景go库下载初始化数据【1】建表【2】插入数据【3】查看数据4、代码示例【1】gorm结构体定义【2】分页结构体

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Java Web实现类似Excel表格锁定功能实战教程

《JavaWeb实现类似Excel表格锁定功能实战教程》本文将详细介绍通过创建特定div元素并利用CSS布局和JavaScript事件监听来实现类似Excel的锁定行和列效果的方法,感兴趣的朋友跟随... 目录1. 模拟Excel表格锁定功能2. 创建3个div元素实现表格锁定2.1 div元素布局设计2.