Skip to main content
  1. Blog/

Devlog Update #1: Sprites in a 3D world

Apr 10, 2024 · 907 words·2 mins· loading · loading · ·
Devlog Unreal Game Design

Learn how I built multi-directional sprite characters in Unreal Engine, creating fluid, dynamic animations that respond seamlessly to player movement and camera angles.

Table of Contents
Devlog - This article is part of a series.
Part 1: This Article
Junker Punk concept

Hello, Junkerpunk fans and fellow game developers! In this dev log, we’re diving into the fascinating process of integrating 2D character animations into Unreal Engine using Aseprite and the powerful third-party plugin, PaperZD. My goal was to create a richly animated 8-directional sprite character, capable of seamless movement and interaction within this game world.

Diving into Character Design for Junkerpunk
#

The vision for Junkerpunk’s character design was ambitious from the start: I aimed to meld the richness and depth of classic 2D characters with the dynamic possibilities of a 3D world. Inspired by the iconic sprite work in games like Homeworld, Zelda, and Gaia for the SNES, I sought to capture that same nostalgic essence but with a modern twist. These characters are not just sprites; they are full personalities, designed to convey emotion and intent through their movements and interactions.

Each character began as a series of sketches, evolving through iterations into detailed pixel art. Using Aseprite, I tried my best to pay homage to the SNES era’s aesthetic, focusing on vibrant colors and clear, expressive animations that would read well from any angle.

Running concept

Crafting Character Animations in Aseprite
#

Our journey begins in Aseprite, an intuitive pixel art tool that is perfect for crafting detailed 2D animations. For Junkerpunk, I needed my first character to not only look good from any angle but also to move fluidly in eight directions: north, northeast, east, southeast, south, southwest, west, and northwest. This was not only to serve as my proof of concept but also the one character I really couldn’t afford to skimp on since it’s the one you see on the screen 99% of the time.

The challenge was significant: each character needed eight directional sprites for multiple actions—idle, attacking, running, jumping, and falling—which amounted to a massive library of sprites – around 48 frames of animation for every single one of these, and 240 total for the entire set. This library was essential not only for visual variety but also for ensuring smooth transitions and responsive gameplay in a fully 3D space with dynamic lighting and particle effects.

Running concept sheet

Integrating Animations with PaperZD in Unreal Engine
#

Once the animations were ready, the next challenge was to bring them into Unreal Engine and set them up for interaction using PaperZD. PaperZD simplifies the process of implementing 2D animations with Unreal’s powerful Blueprint system, which is essential for adding logic to game elements.

Setting Up AnimBPs (Animation Blueprints)
#

Using PaperZD, I created AnimBPs for each character state. AnimBPs are essentially state machines within Unreal Engine that dictate how a character transitions from one animation state to another based on gameplay variables—like moving, jumping, or falling.

For each direction of a character’s movement, I set up a unique animation state in the corresponding AnimBP. This involved configuring transitions between states so that they occur smoothly, providing a realistic portrayal of character movement. PaperZD’s intuitive interface made it possible to drag and drop animations directly into the Unreal Engine and seamlessly connect them to my character’s Blueprint. There would be a check run on the camera to ensure that the correct sprite would be shown depending on it’s angle with the character to allow 360 degree rotation eventually, but I started small with more of a sidescroller view to hammer down the basic mechanics and make my life a little easier.

Blueprint Configuration
#

In the character Blueprint, I used variables to track the direction the character was facing and the specific action being performed. These variables were then referenced within the AnimBP to determine which set of sprites to display. For instance, if the character was running northeast, the AnimBP would play the corresponding “running northeast” animation sequence.

some visual scripting nonsense

Enhancing Visuals with Directional Edge Lighting
#

To enhance the visual quality and depth of our character sprites, I also developed a system for edge lighting that reacts dynamically to the game environment. By creating directional light maps in Unreal Engine, I could modify the intensity and angle of lighting on any sprites based on their orientation and surrounding light sources. This technique brought an extra layer of polish and realism to the 2D visuals, making the character blend more naturally with the fully rendered 3D environments and Unreal’s amazing lighting effects and shadow casting. some edge lighting maps

Conclusion
#

Integrating 2D animations into a 3D engine like Unreal presents unique challenges, but with tools like Aseprite and PaperZD, it becomes an entirely manageable and rewarding process. My work on Junkerpunk has not only pushed the boundaries of what I can achieve with 2D sprite-based characters but has set the stage for much more to come.

I hope this peek into my development process has been enlightening. Stay tuned for more updates as I continue to build out the vibrant, gritty world of Junkerpunk! Happy gaming!

Hey you: Trees can talk, but they just gossip about the weather all day, it’s probably pretty boarding. Oof. Okay. Forget I said anything, that hurt me too. 😅
Devlog - This article is part of a series.
Part 1: This Article

Related

The Story of Mimick – A Post-Mortem
Jun 4, 2023 · 2456 words·12 mins· loading · loading
Pixel Art Game Design

A postmortem of a game that got started but never finished.

Jones Lang-Lasalle (JLL)
Mar 21, 2022 · 2377 words·12 mins· loading · loading
Portfolio

My time working for the world's second largest commecial real estate management company.

343 Industries
Jan 19, 2018 · 2434 words·12 mins· loading · loading
Portfolio

343 Industries needed to unify multiple tools used in the development of Halo Infinite under a single user interface while making the overall experience for their developers more simplified.