Thursday, 19 April 2018

CINE1102 2017-18 Animation Studio: Assignment 2

CINE1102 2017-18 Animation Studio: Assignment 2 - Virtual Reality Project

Intro:

For this project we were tasked with creating and delivering

We decided to work as a group for this project to attempt to produce a piece of work that would allow us to focus on our own strengths and build our team skills. Due to this project stemming from my original alternate reality/virtual reality concept I decided to work as the team's gameplay designer as I have experience with Unreal Engine 4 and I wanted to challenge myself by developing a virtual reality game.

2.1 Role -  Gameplay Designer:

A majority of my focus on this project was designing and coding the player character and the interaction mechanics in the project. With no experience with virtual reality development but a lot of experience developing for Unreal Engine 4, this project was the perfect opportunity for me to develop new skills and increasing my familiarity with Unreal Engine 4's blueprint system.

From the beginning I wanted anything interactive in the environment to be as modular as possible, allowing the level designers to easily customise the base interact-able blueprint into new objects with unique actions when interacted with. The benefits of this system meant that not only is it extremely easy to quickly populate the environment with interactive objects, but all of the code for picking them up and interacting with them is already handled by the base. This means no code is actually required in the child blueprint itself for the object to be picked up, and coding what happens when the player pulls the trigger is as simple as coding from the event that is fired in the base blueprint when the player pulls the trigger.

2.2 Interactable Objects:

Interactable objects featured in the project, the first four being various base blueprints and the others being children of those bases, excluding 'Interactable Interface', which is used to allow the player pawn and the bases to interact.
Simply put, by creating the initial, basic 'base' blueprint, we can create 'child' blueprints from it that inherit the code from the parent.
The blueprint for the Base Interactable blueprint.
The base interactable blueprint contains all of the code for what happens when the blueprint actor is grabbed via the controller grip buttons. Since this outcome will be the same for all interactive objects that can be picked up, we put this code in this blueprint and leave object-specific actions to the child blueprints.

The graph for a child blueprint, this specific one being a flashlight prop.
By triggering the 'Action' event that is fired when the player pulls the trigger, specific code can be run. As shown above, code specific to an object can be added into the child blueprint, meaning each child blueprint can have unique code.

By default, interactables are coded to be attached to the hand at the rotation and position they were at relative to the player's hand, this allows for a slightly more realistic approach to holding objects. But for instances where objects should be held in a certain way, I added the ability to force objects to snap to a specific rotation relative to the hand. This would work well with weapons and other objects that should aim ahead of the player's hands at all time and ensure the player doesn't have to spend extra time rotating the object to be in a suitable position.


Using these comprehensive settings in the 'class defaults' section members of the team can easily change how each actor behaves:
  • Snap: Whether the object snaps to the player's hands at a default rotation.
  • Hold Location: Unused.
  • Use Alternate Hold: Determines if the actor uses its default position when snapped or the values specified in the next two variables.
  • Hold Transform: The position the object snaps to, relative to the hand.
  • Hold Angle: The angle the object snaps to, relative to the hand.
2.3 Player Blueprint:

Coding the player character was a very demanding task as it went through many iterations with the final one being almost completely original code. Originally we intended to allow players to choose between teleportation and traditional locomotion however we decided that we would stick with one locomotion method, which was the traditional system.

The movement code for the player.
Due to the default virtual reality pawn using teleportation locomotion, I had to code a traditional movement system using the thumb-sticks of the left controller.

The turning code.
Due to difficulties with testing and playing whilst sat down, I decided to implement the ability to rotate the player using the right hand controller, allowing the player to stand still and play, without the issue of worrying about the headset cord.

Using a 'blueprint interface' we can make blueprint actors communicate. As seen in the above image the player actor detects any children of the blueprint interactable base and triggers the 'Interact event' that is sent to the detected actor. If the player is already holding the object it will instead drop the actor.



2.4 Level Interactables:

Code for detecting the player's hand and setting 'hint' text to visible.
Unlike the interactive objects that can be picked up, level interactables remain stationary and can not be manipulated besides being activated. This is used for lights and other level objects that can be activated.

A fan blueprint that is a child of the base level interactive blueprint. The wireframe collision box is used to detect the player's hands and allow for the activation of the object.

Upon receiving the activation input, the fan model will begin playing a timeline animation.
Code for grabbing.
Due to being set up in this way, it is incredibly simple for team members to quickly create child blueprints that can inherit the parent code and all that is required of the team member is to code using already established coding.


Level interactable blueprints feature one class variable: 'Touch to Interact'. By enabling this the blueprint will instead activate when the player's hand touches the detection collision box in the blueprint. This can be used the simulate the feeling of the player physically pressing a button, instead of having them pressing the trigger button to activate a button.

3.1 Character Rigging and Animation

During this project I was also the sole animator and character rigger of the team, responsible for rigging and then animating characters for animated hologram sequences featured in the game. This project was my first time rigging and animating characters sculpted in ZBrush, as such it was quite challenging adjusting my rigging techniques to the topology found in sculpted character meshes.

A routine I ensured I followed was the structuring of character skeletons and naming conventions used for their joints. This allows us to theoretically reuse animations across the cast of characters using animation re-targeting if need be.

The mother.
The father.
The rat.
The mother character has blend shapes for talking, allowing easy animation of dialogue without having to use alternative animation methods such as face joints. Blend shapes can be easily controlled in Unreal Engine 4 and this was a large deciding factor in using them instead of face joints.


In addition to the facial blend shapes for emotion and lip-syncing, I included blend shapes for hologram distortion effects, to make the holograms in the game more visually interesting. Thanks to Unreal Engine 4's animation editor the motions for characters can be animated in Maya and the blend shapes can be controlled and added to the animation in Unreal Engine itself.

The original 'talking' animation for the mother, viewed in Autodesk Maya.
The final version viewed in Unreal Engine after using the software's animation editing tools to animate the distortion flexes.

Thanks to this method of animation distortion effects, it allows the animator to have more control over the effect than if we were to use shader effects to achieve a similar result. It also allows us to purposefully distort the first and last frames of the animation to create a seamless loop transition.



I was also responsible for the rigging and animation of the hands that would represent the controllers of the player, instead of the default Oculus Touch model that is used in the final version of the game. We intended for the hand to play context-sensitive animations, such as forming a pointing gesture when their hand is in the vicinity of a interactive object or closing when holding an object.

4 Evaluation:

Our initial ideas for the game did not pan out how we had hoped do to many issues involving time management and problems with our production pipeline. Pinpointing specific reasons for the state of the game can be simplified to poor time management as a majority of our work was left till near the end of development for multiple reasons. With uncertainty with what we could realistically achieve in the time we could work on the project, and uncertainty with next to no limitations for what we could create, a lot of time was spent figuring out what we would actually create. Due to none of us having experience developing for virtual reality and having limited access to a virtual reality headset testing or prototyping ideas for ourselves was extremely difficult.

Another issue with our project was a lack of communication and a lack of experience developing for video games among some team members. As the gameplay designer I should have ensured that our team members were producing assets as efficiently as possible, however I was so focused on the virtual reality side of development that I failed to provide the team with guidelines for how our assets would be produced and implemented. Due to this, many assets have inconsistent quality and certain models are imported as separate scenes, meaning objects like books on bookshelves were exported far away from the scene origin. This inconsistency is due to differing approaches to the video game modeling pipeline due to inexperience with video game development that could have been corrected by enforcing a strict approach to how we handled assets.

This project was a valuable learning experience as I now know what I can do to improve my ability to work with teams and help my team members by establishing guidelines for our development pipeline. It has also taught me that I can should always experiment with ideas, even if there's a chance it may not make it into the final game, as I made discover or develop something that could make a huge improvement.

If I were given another chance to develop this project I would have prioritised ensuring our team understood the virtual reality development pipeline and I would have focused on ensuring all of my gameplay related coding is finished sooner to ensure the team have as much time as possible to become familiar with it. While the modular interactable blueprint system I coded was useful, we didn't manage our time properly and as such we did not make many objects using it and all it was used for in the end was to replace level blueprint code with actor blueprints. We did not realise the project we set out to create but I definitely learned a lot about Unreal Engine 4 and virtual reality. 

No comments:

Post a Comment