Madness is power.
Mood 666 is a intense FPS in the style of Doom with a cyberpunk flavour. You play as a special operative charged with infiltrating and neutralizing all hostiles. As you kill enemies, you will build up your "Mood meter" which will give you bonuses at certain intervals. The speed and ferocity of the combat increases as your mood does. Staying on the offensive ensures your Mood does not fade, keeping you in the fight for longer.
Introduction
Mood 666 was the first time I was solely responsible for the UI in a game project and I am very proud of the work I did and thankful to the team I worked with that I was allowed to focus my skills in this area.
My work on this game can be summarised into three categories:
The Player HUD uses a parent UI widget that is populated by other widgets that contain their own logic. By and large, the parent HUD widget only handles the display of specific sub-widgets.
The most interesting part of the HUD, and the one that drives the unique parts of the game is the "Mood Meter" in the bottom left. It was made using a series of radial sliders that each measured one third of the maximum value for the "Mood Meter" of 666. The text is updated by receiving info if the player is taking or dealing damage.
One of the more eye-catching parts to be in the game is what I referred to as a "showstopper" effect. We achieved this with a slow motion effect when increasing the "Mood meter" past one third of the maximum value.
Each of the pop-ups are the same widget playing a different animation as requested from the main parent widget.
Each of the animations are declared in C++ and key-framed in Blueprint using UMG's built in variables for widget animation. Almost all animation are entirely dependent on the "Transform" property that is inherited by all UserWidget classes which allows for manipulation of position, scale and shear. These are purely visual manipulations, logically the UI stays in place.
Similar to the player HUD, the menus are all created in C++ and designed in blueprint.
The project used three different UI shaders.
UI Glow
Used in both the HUD and the menus. Effect was achieved by reading each element on the canvas and copying it in a radial pattern around the centre of the element. The shader allowed for adjusting of the values including the amount of copies in the radial, the distance from the centre and the opacity of each copy.
Parabolic Screen Curve
Used in the HUD. The effect was achieved by manipulating texture coordinates in the green channel in the shape of the curve. This is then applied to the screen in a "severity" that can be decided by a designer. This has the added effect of also causing a "stretching" effect when UI elements touches the bottom and top edges of the UI canvas. (This effect can be seen in the animations above!).
Glitch Effect
The third UI shader that is used on the HUD and in certain menus. This is my take on a classic distortion effect that is often used to simulate malfunctioning screens. It has a low intensity persistent effect on the HUD, which combined with the parabolic curve evokes the image of a helmets visor. The effect is also utilized in the event that the player takes damage for extra feedback. This effect is more intense but only plays for a short interval. It is made by multiplying a texture with the texture coordinate of the shader. The severity of the effect can be controlled by selecting a displacement texture with more extreme differences and by adjusting multiplication values.
C# | C++ | Unreal Engine | Unity | Perforce | Git
contact@jakoblindelof.com