Labels

Wednesday, 7 May 2014

Main and Pause Menu's

Originally the menus for the game were going to be made using Unity's in built GUI system. However this proved to be more difficult than expect and so instead I chose to use planes and raycasting to create our menus. Both the main and pause menus are scripted fairly similar however the pause menu alters the time scale of the game as it has to pause the rest of the game environment where as the main menu does not. Each plane is given a specific name that is read when clicked on by the player. If the name corresponds with one in the script then the code for that action is executed. Below are some screenshots of the menus and their code.

Main Menu




Pause Menu



SFX

I compiled the Sound Effects library over the course of the games creation. Once an appropriate sound is located it is imported into the audio editing software. 

There needed to be no delay before the sound and there could be no silence at the end so the sound clip is just sound. After editing the sounds to the correct length, pitch, volume and file type, they could be exported to unity and coded onto the objects creating the sounds.

in some cases we needed to determine the length of animations in order to line up the clip so it sounds like what it looks like its doing.

For sounds that are often repeated like footsteps, i exported a variation of six different steps that are coded to play along side an animation at random so the same one cant be played twice in a row adding to a more believable world.

It was difficult figuring out where to draw the line between real life sounds and synthetic sounds as the game is a strange combination of both but I believe good results have been achieved. 

After inserting the audio files the most important thing will now be getting the volume levels consistent and correct so all sounds are heard, play and sound as expected

Bug Spray Pose and Mecanim Layers

To implement the bug spray pose into our characters animations it had to be blended in using a animation layer mask. The animation layer mask has allowed me to set it so that when the bug spray is used only the top half of the characters animation will change. This meant that we could keep the pose separate from all the other animations but still use them in conjunction with each other. Little scripting had to be done for this as it was simply adding another element to the animation controller script I had previously finished. Below is a screen shot shower the mecanim animation layers, the animation mask and the final pose in game.


Main Menu UI and Particle effects



While Elliot was set with the sounds and enemies i was given the task of UI elements and particle effects. We needed a main menu/pause menu and various fire/wind/snow particle effects.

I tried to keep with the triangulation theme we have with our game and the three red/blue/green monochromatic colours to emulate the old 'arcade' effect, i reasonably happy with the results although it was hard to determine exactly how it would look in unity until the particle emitters were set up properly by Luke. 

Above in order of appearance:

Particle Effects
- Wind Swirl, forest level and fan puzzle
- Thin Wind, Also for fan puzzle
- Fire, used for the lava effects and torches.
- Firefly (Two variations), for more of a forest ambience
- Longer wing swirl, also for forest level winds and puzzles
- Snow, used for the Ice level snow. 

Menu UI
- Main menu, with the options (Start, Level Select and Quit) 
- Level select leads to the forest, ice, fire selection
- Pause menu will use Resume and Quit. 

Extras
- Custom mouse cursor (with glitched effect)
- Un-used pixel art snowflake (Didn't use because we came up with the idea of doing more 'triangulated' theme with the assets and particle effects)


Implementing Audio

Once we had a library of sounds the next thing to do was to begin implementing them into the game. For most of the elements that required sound it was simple to implement. This was due to only having to add a few lines of code to existing switches to get the sounds to also play when an event was triggered. However for the background ambient sounds and game music the scripting was slightly for complex as it required each audio clip to fade out or in depending on the level that you are in. Below is a screenshot of the audio sources for the music and ambient sounds.


The code for the music and ambient sound was however still fairly simple. Each audio clip has their volume interpolated to a set target which occurs when the player enters specific trigger points. Below is a screenshot of the script for the sound transitions.



Bug Spray

The Bug Spray is an item used by the Playable character and is required when removing glitches from enemies, based on a general kitchen cleaning product, the sillouette is easily recognisable, I imported a reference onto an image plane and modeled the basic shape around that in the side views. 
the model is a simple mesh with triangulation and block colours. Given to Jez in order to be incorperated into a character pose when the bug spray is in use.

Throughout the creation process, i used mental ray to render images just to see how the shape and colour would look as a final outcome.



Reference



Tuesday, 6 May 2014

Enemy Visual Bugs

As an extension to the pre-existing enemy bugs it was decided that extra specific bugs would be added to the enemies. Each of these would affect a different aspect of enemy, we decided that these elements would be: scale, speed and the colour. For the scale bug the enemies would simply be twice their original size. The speed bug is used to alter the enemies speed, this can be used to make it really fast or stop completely. As the enemies speed changes its animation will also seem out of sync with the enemies movement speed which adds to the visual effect of the bug. The colour bugs simply causes the enemies material to flicker a bright pink colour, similar to the typical missing material colour. Below are screenshots of these bugs working in the game.


The speed bug was achieved by simply altering the speed variable on the enemy AI script attached to the enemy. The scale bug was also fairly simple and was achieved by just altering the enemies localScale property. The colour bug however was slightly more complex due to the flickering effect. This was achieved by creating a random number between 1 and 0 and if it was greater than 0.7 the enemies material colour is set to the new pink colour. As this occurs every frame this results in a constant random flicker. Below is a screenshot of the code for these bugs.



Parallax Backgrounds

Originally we were going to have the backgrounds to our game as parallaxing 3D models, however due to their large size they would not lightmap correctly. Instead we decided to render the background in a modelling program as a flat image with and alpha channel and use. We still wanted to keep the parallax effect however so that was still implemented as planned. Below are screenshots of the backgrounds in game.




To achieve the parallax effect I used the cameras x position as a reference and for every 1 unit the camera moves the background move 0.2 units in the opposite direction. Also as part of the background scripting at each level transition I have also scripted the cameras background colour to change to match each level. The snippet of code below shows exactly how this was achieved.



Wednesday, 30 April 2014

Level Backgrounds

When we came up with the backgrounds, we originally wanted to paint them but we wasn't sure how we were going to match the length of each level without tiling. Our next idea was to model the background elements so we could still keep the triangulated look. Due to the large sizes of the meshs, we came across a problem with lightmapping, the light maps would stretch across the background meshes giving blurred shadows. To counter this we tried splitting the meshes into smaller pieces (a technique we had to use on some of the larger terrain pieces) but once again the pieces were still too large and could not be made smaller without adding more geometry, which is something we wanted to avoid because of the nature of the triangulated effect.

We solved our problem by rendering each background element separately as a layered psd using mentalray. I was then able to take these renders into Photoshop, these can then be saved off with an alpha channel and applied to 3d planes within Unity. Taking these into Photoshop instead of using the 3D models allowed me to have much more control over colours and giving slight false depth.


I had to match the shadow direction and colour the pieces accordingly to match the unity lighting as close as possible. This allowed me to take each piece into Photoshop and fade them based on the false distance.
The effect i used was to place a blue overlay over the each piece, the closer elements were set to 25% opacity while the far element were set to 50%.

I think this effect worked nicely but not 100% sure it translated as well in game, i think the far background could of been a little more faded. As i thought the colour difference wasn't as noticable in game as it was in Photoshop. Also in some parts of the Forest level, the platforms assets colour look too similar to the background so sometimes blends in. Mostly minor fixes so should hopefully be sorted before the grad show. 

You can see an example of this below:

Monday, 28 April 2014

Particle Effects

Once the game had been built and the lighting had been set up and baked correctly, I moved on to start creating the particle systems for out in game particle effects. Particle effects have mainly been used to improve the aesthetics of the environment. However they have also been used to signify interactivity, character deaths, and many other elements. Each particle system uses different properties to define how it is emitted, and it is the emission of the particle systems that has the biggest impact on the way they look. Below are some screenshots of the particle systems and some explanation of how they have been made.


The above screenshot shows three commonly used particles from the game. The fire particles are emitted with a large start size which is shrunk over time as it moves upwards to achieve the flame shape. The colours also change over time to make the centre of the flame seem brighter. The glow that can be seen on the roof of the cave was created by using the render mode of the particle to distort it and create the ray shapes that can be seen. The sparkle on the torch is used to signify that an object is interactive, it is a fairly basic particle system that just slowly emits a few particles over time that shrink to simulate a cartoon styled sparkle.


In the above screen shot you can see the flowing lava particle as well as the surface lava particle. The flowing lava particles are all emitted in the same direction with gravity multiplier applied to give the effect that they are falling. The surface lava effect has been created by interpolating the start size of particles so that as they are emitted over a large area it creates a wave type effect. The ash particles can also be seen, they have a random velocity multiplier applied over time so that they flutter in random directions. They also have a negative gravity multiplier applied to get them to rise smoothly.


The fire trails and explosion effects that can be seen above are simply modified versions of the fire particle. The trails have had their size, speed and lifetime altered and the explosions are the trails with a fixed position.


The snow effects uses two particle systems. The first is falling snow that has a gravity and velocity multiplier that causes them to fall down at a random direction that can change to give the appearance that they are being blown around. The second particle system is the same as the first one but with the gravity multiplier removed to give the appearance that more snow is being blown around.


The dust particle above is exactly the same as the snow particle system but with the texture and colours changed. The firefly particle system is also the same as the dust and snow system but has a much small emitter so that they stay more closely grouped. 


The wind particle uses two separate systems. The first is used to create the gust effect that is emitted in waves. The second is the wind direction effect, this has been made by using vertically stretched particles and applying a rotation multiplier to emulate the spiralling of a fan.  

Friday, 25 April 2014

Finished Enemy AI and Player Bug Spray

Once movement of the enemies had been scripted the next stage wage was to incorporate the glitched property of the enemies. When the enemies are bugged they cannot be killed by jumping on top of them and instead they must first be sprayed with bug spray to remove the bug to allow the player to destroy them. The enemies also swap textures when they are bugged to an alternate set to visually show the "bug". The code for this for both enemy types is nearly identical so the screen shots below represent the code for both enemies.

Below is a screenshot of what the enemies look like when bugged.



Once the enemy "bugs" had been added the next thing to do was to add the players bug spray as it is required to remove the bugs from the enemies. The bug spray was fairly simple to create and consists of a particle system to depict the spray and a mesh collider to detect whether or not an enemy is colliding with the spray. Below is a screenshot of the player and spray in game as well as a snippet of code that shows how the spray works.




Thursday, 24 April 2014

Standard Enemy Rig and Export

 
Rather than creating three seperate meshes and rigs for each standard enemy, I rigged one mesh using human IK and positioned the bones correctly on one half of the body then just mirrored the bones for the opposite side. By default human IK appears in the 'T' pose but i modelled the enemys arms slightly lower in an attempt to avoid extreme deformation of the mesh so had to reposition the arm bones. I used smooth bind to link the bones to the mesh then bound each seperate set of accessories for each theme to the same rig so in unity it was possible to hide a particular asset allowing us to swap out textures for particular enemies.
 

  We came across a problem on the first export. The rig didnt have enough bones for unity to understand it as a human IK rig so no animation could be applied. After re-rigging there was yet another problem, the default bone settings in maya applied a scale compensation which damaged the mesh upon import but after unticking the box and re-exporting everything ran smoothly. The mesh doesnt look 100% what we had in mind when animated by unity but some tweeking in maya may lead to a better outcome.

Wednesday, 23 April 2014

Game Dev poses

I big problem with our team was out of the three of us, none of us are particularly animators. While rigging and skinning took a while to get correct, we managed to find some basic animations online for the Main Character, while also using Unity's Mechanim, Luke managed to blend together animations with some unique static poses that were required for our game. It's a shame i didn't have the time or skill to get nice animations so poses will have to do for now.


Bug Spray Pose - This is used when a glitched enemy needs to be 'bug sprayed' 


Wall Jump Pose - Used for Wall jumping, when exporting into Unity we had a problems with the feet registering with being grounded on the Wall. In Unity the feet bend backwards and towards the wrong way, while this is something we would like fixed, it may have to be left for now as none of us are strong in the field of animating and would be far to time consuming to learn in the given time.

While ideally we would love fluid unique animations with cartoon rubber hose movement but this is one field where we have had to make do with what we can get so i could apply my strengths in other areas of the game.

Sunday, 20 April 2014

Ice Level Assets and Terrain

 Here is the collection of all the models used to build up the Ice zone. I think the low poly triangulated effect works especially well on some of the ice pieces and on the water.
As this level was smaller i didn't have to worry about making more modular pieces of terrain, so each part of the terrain more modeled more unique. I think on some pieces of the terrain some of the 'tris' are a bit too big in comparison to the rest of the game, if we get more time to polish this is defiantly something to think about as it is more noticeable in game.

 
 Below are the Ice zone assets, keeping to the colour scheme i set earlier i modeled the various parts we needed to fill out the scene. This included the parts needed for the puzzles and 'covers' to fill the front of the inside terrain. There is also a piece of flint and a stick, this is used for the puzzles near the end of the level. To avoid the level feeling completely blue and white i decided we need some other colours that all blend nicely, this is why i created each level colour scheme earlier on. Gems and icy blocks all keep to the colour scheme and will hopefully be lit up within Unity to give the whole level a more visual appealing game.


While i'm happy with the results and the visual style, i believe some of the ice terrain would need changing a little, some wall jumping has proven a little difficult on some of the sloped edges because i did this at the time without taking the game mechanics in the consideration. I wanted to give the terrain a jagged, sharp edged look but i think it would suit a more softer feel but i guess that's something that came with doing low poly triangulation. If i had more time i would of also of liked to do more assets or variations but as it's a shorter more difficult zone, i don't think it's too much of a problem.



Wednesday, 16 April 2014

Forest Level Assets and Terrain

Here is a collection of all the models and assets used to build up the forest level. Using basic triangulated shapes and trying to keep an interesting silhouette to make sure the assets were visual pleasing and consistent. We also thought it would be a clever idea to keep everything as modular as possible, meaning we can re-use terrain pieces and assets to build up the levels without having to model it all completely from scratch. 


As mentioned earlier in the blog, the forest level consists of a woody environment to begin with and then moves onto forest ruins. The ruin pieces could of probably had a better colour as the grey is a little drab but was hard to find a colour that wouldn't clash or not work with the rest of the environment. 



Here are all the modular Forest level assets, most of these are repeated throughout the zone to fill out the level. I think we could of had a lot more variation in each level but as a small 3 man group i think we did alright populating each area. As we went for this visual style and low poly models, means we spent a lot less time needing to un-wrap and texture each individual piece.

Monday, 14 April 2014

Lighting and Lightmapping - Forest, Ice, Fire

Once I had started building out the levels with our terrain models I begun doing a few lighting tests in order to see which method of lighting would best suit our game. Originally we were going to use all dynamic lighting, however after running a few tests with lightmapping in Unity, we found that it gave much better results that more closely resembled the art style we were aiming for. Setting up and optimizing the game for the lightmapping process was not as simple as we had at first hoped, as several of the models were too large to fit onto our lightmap atlas and would appear pixelated during gameplay. In the end some of the larger models had to be split and our max atlas size and lightmap resolution was adjusted accordingly to give us the best possible results. Below are some screenshots of the first three sections of our level fully lit and lightmapped:






Friday, 11 April 2014

Level Assets - Forest, Ice Fire

After the terrain had been imported and Jez and Elliot had finished modelling the majority of the level assets I started to fill out our level with the newly modelled assets. Below are screenshots of the levels with the newly imported assets:






Thursday, 10 April 2014

Starting Enemy AI

Once the level mechanics had been finished the next bit of scripting that I had to do was to start some sort of AI system for our enemies. The system itself will be pretty basic as our enemies are only really designed to patrol specific areas or simple stand still. The only slightly complex aspect our our enemy scripts will be the code that manages when our enemies are bugged and what that changes about our enemies.

The standard enemy uses a character controller component as it was more suitable than a rigidbody. The standard enemies will constantly move forwards in any direction that they are pointed. If they hit something or come to a ledge they will turn around and begin walking in the opposite direction. This is done by checking the current velocity of the enemy as well as using a raycast to detect the edges of platforms. In order to "kill" the enemies in our game each one has a collision box attached to their head that detects a collision only when the player is jumping down onto them. Below is a screenshot of the standard enemy in the engine and the code that manages the direction of the standard enemy:



As well as our standard enemy that remains grounded at all times, we also have a flying enemy that acts in a similar way to our standard enemy. However instead of moving forwards along the X axis, the flying enemy moves up and down along the Y axis, sort of hovering up and down. Below is a snippet of code that shows how the movement of the flying enemy is achieved:



3D Thorns

 
Official Thorns
 
 
 
This is the final model of the thorn hazard, based on the second 2D Version, Only one has been modelled as it will be a highly repeated asset. This model is in two parts, the main body and the actual spikey thorn bits, this allows us to easily change texutres and apply new ones.

Wednesday, 9 April 2014

Forest Level Mentalray renders.

Once i completely finished modelling the forest assets corresponding to Lukes initial sketches, i layed out roughly what the game could look like. Placing tree, bushes, rough backgrounds and other various assets to get an idea of what lighting and composition we want. Once i tweaked around with the Mentalray settings to try out different effects, this gave us a very clear idea of what lighting and overall art direction we were aiming for. 









Above was the closest to how we wanted the game to look, the colours blend nicely and nothing stands out too much. The only problem i had with mental ray was the white on top of the rolling hills, this was very hard to get rid of while preserving everything else. 


By changing the ground colour darker, this lead to this nice render of a possible night time version of the forest level. While this won't be used it was interesting to see what other themes could possibly be achieved. 

 Because of the block colours and low poly models is was very important to get this idea right, you can see below that a more over saturated look made the colours stand out way too much. While this did give a bright vibrant tone, i think we all preferred the more desaturated atmosphere in the earlier renders.




This then lead to Luke looking into how we were going to light our game, by light mapping and using light probes, we shall hopefully be able to recreate this look in Unity.