Enemy Designer

Apr 2024 - Jun 2024 (8 weeks)

23 people

Unreal Engine 5.3, Jira, Perforce

Sounds of Shadows is a Horror Survival game with Stealth aspects.

The main character is a robot that wakes up in an abandoned and destroyed underground facility. There are no light sources anywhere so the player can only see by using the echolocation module of the robot. You walk around slowly getting the story of what happened and who you are. Eventually you get introduced to the enemy. The game takes you through 3 levels slowly letting the player discover the story and what is really going on and ramping up the difficulty with enemy encounters.

On this game I was the only Enemy designer. So, I carried a lot of weight with the Enemy being the ‘star’ of the show. I worked in close proximity with animators, level design, programmers and the team in charge of the main character.

The enemy is a mutated human which has been trapped in this facility for a long time now and has adapted to the lack of light and has its other senses heightened. The main inspiration for the enemy was the Xenomorph from Alien Isolation. I designed the entire enemy going through multiple iterations but always with the idea of the Xenomorph at its base. I wrote all of its behaviour in the prototype we made and then in later development I got a single programmer to help me with implementation.

About my work

  • Roaming: At base the enemy would always roam: around. It would have a priority for using high traffic sections and had an extra check that would make sure that every now and then it would go towards the current objective of the player and ‘be in the way’.

  • Investigating/Alerted state: Any sound the player would make either by walking or throwing objects, would put the enemy in an Alerted state. Here it would run at the source of the sound and attack it, In the case of the player being the source the player could either quickly distract it with a new sound or disorient it with the sound blast gun the player has. If the enemy did not register a hit on the attack it would give it self a moment to process where it ran to and then run to the closest place that the player could be hiding behind, entering its Investigating state, giving it that intelligent feel.

  • If the player gets in too close proximity of the enemy, it will enter the Attacking state. This could either happen by the player having made a sound and having failed to evade the enemies charge or by positioning themselves badly and having the enemy run into you. In this case the enemy would attack you instantly killing you.

Behaviour

Some screenshots of the behaviour tree and how it grew throughout development.

The enemy is there as an ever looming presence, you can hear its footsteps echoing in the distance reminding you of its existence and growing threat. It definitely is a threat, but the player has a lot of counters to the behaviours of the enemy making sure it is ‘easily’ beatable.

With the way the echolocation works (not quite like actual echolocation) the player can see the anything around a sound source I.E; humming electronics, doors opening/closing, throwables hitting a surface and any footsteps.

Player Experience

One of the main tropes with this echolocation as our main mechanic is that when there is complete silence it creates a real fear factor for the players since they can’t see anything. This has created some great player experiences where the enemy stops walking in front of them causing the player to freeze in fear.

This was my first experience creating a large-scale enemy and collaborating with a team of this size, which taught me valuable lessons as a designer. For example, the level designer and I worked independently, resulting in an AI with a backstage mode for downtime and a menace gauge to gradually ramp up the enemy’s aggression. While levels were short and snappy with no need for these systems.

When we tested this within the level, we realized that the level's short duration didn't allow these mechanics to come into play effectively. Recognizing this, we decided to refine our approach. We streamlined the AI logic and redesigned the level to better align with the enemy’s behavior, ensuring a more coherent and engaging player experience. The redesign process was carried out in Miro, and the updated design can be seen in the image to the right.

Since the project was only 8 weeks, we got the animations quite late into the project. The artists had to first create an enemy, model it, rig it and then animate it. So, when I got the animations to finally implement them in the character with the behaviour this was a very exciting moment for me and the entire team. I finally saw my Enemy come to life. this feeling is really something that proved to me that I want to keep creating AI’s for games and I want to keep creating experiences.

(This is old footage from when I first got the walk and run animations, I took this video to show it in action to the team and it created a real morale boost to see this horrifying monster walk around our level.)

Take-Aways

The Journey

This project started off by having the tags of “Fast paced movement shooter”. So the early versions of the enemy were quite a bit different than this creature I ended up with.

First I made simple enemies with zombie behaviour that would run to you attack you etc. The only twist being we were trying to go for a game loop close to the Titanfall 2 time travel mission.

My focus on enemies here was to make sure 2 instances lived. One in the ‘now’ and one in the ‘past’ and they would correctly stop moving and pause when the player was in the other world.

Now we are seeing a big jump into the direction we actually end up going with.

Enemies are invisible when you are playing normally, but the player can “open and close” their eyes. Enemies are only visible when your eyes are closed, but the level is not as visible. Here you can see we slowly started working with echolocation as a mechanic and that the player could see parts of the game this way. Enemies would make sounds when passive warning the player they are there when their eyes are open.

At this point we had decided that we liked the idea of the player going insane and playing around with ‘insanity’ as a concept. We also agreed to make our game more focussed on scary since a horror game hadn’t been done by anyone in our school for a long time.

We are in week 6 of our 8 week project and we just made the decision to make the player permanently blind and show the level through an echolocation type vision.

The enemies in this version went a bit more back to basic with one slight addition in behaviour but especially in the way we showed them. Every sound would make a snapshot of the world and that would be shown to the player so you could see the enemy but only where they were the last time a sound made them visible. Since players often lost track of the enemy when reloading or trying to run away I decided to add a small EQS that made the enemy favour the backside of the player and create for some good scares in people.

Another week passed and we pushed our gameplay loop more into a “slender man” type objective system. Find the 3 buttons and the enemy grows in strength and aggression on every button press. We still had the echolocation and I made an observation when playtesting the last version: People are often unsure if the enemy is dead and I tried to lean into this. The enemy still only shows snapshots and after 2 shots it would fall on the floor seemingly dead, then after a second it would crawl away quietly. this caused players to sometimes freak out and become paranoid for the next couple seconds until the enemy would return in its second phase. It is now a crawler and moves over the floor while only standing up to attack. This snapshot system really allowed me to save effort on animations and we used poses instead.

We reached week 8 and overhauled the game one last time because of teacher feedback. The fast moving enemies, echolocation and no real counter play other than shooting the enemies felt boring after a while and was lacking. We completely overhauled our core gameplay loop and made it into a stealth game. Took away the gun and added a one time use taser that you would have to manually recharge making a lot of noise and possible attracting the monster. Here the enemy became more like the final product. I redesigned the entire enemy in two days and created this whole stealth behaviour in it.

He would roam around randomly and since the level was quite large and I wanted to create a balanced experience where the enemy doesn’t just get stuck in the corner and is never spotted. So, I created a max distance that the enemy can be away from the player. Forcing some encounters between player and enemy. I also added a small chance for the enemy to pause creating a really tense atmosphere between player and enemy. Both standing still not moving or making a sound. this is something that was loved by our testers and teachers and is how the monster from Sounds of Shadows was born.