Project Obelisk
“Place your weapons strategically and fight your way through rooms of guards to complete your contract to topple Obelisk Incorporated in this 3D isometric shooter”
Team Size: 20+
Tools: Unity3D, C#, Visual Studio Code, Git, GitHub, Trello, Discord
Time Constraint: 5 months, January–May 2023
Role: Programming Sub-Lead, Programmer
Organization: VGDev at Georgia Tech
Repository: https://github.com/OhNarts/ProjectObelisk
Background
Project Obelisk is a 3D isometric shooter/action game developed by a team of 20+ students through the VGDev (Video Game Development) club at Georgia Tech. It incorporates a weapon inventory and placement system that allows players to drag and drop their weapons on the battlefield at any location.
After a couple of programming courses, I was eager to prove myself with a true video game. I joined Georgia Tech’s VGDev club during my second semester and chose Obelisk to start my young career. This was my first big game using back-end development and Unity, and it was my first project working with a group of more than five people.
Concepts
Project Obelisk hails from a friend of mine at Georgia Tech, Reinart. Typical shooters are linear in their weapon placement and choice; Reinart envisioned a shooter/action video game revolving around the core concept of player freedom in weapon placement and choice. Players can pick up weapons from safe rooms and enemies and place them anywhere on the battlefield in any given level. Players can stick to one or two guns to use or place down their entire inventory if they desire. This allows for a greater sense of strategy in combat, as players must pinpoint exact locations for unique weapons to optimize their gameplay and properly succeed through the game’s difficult challenges.
Learning Curve
As my first video game development experience on a grander scale, I faced a steep learning curve. Unity and C# were both new to me, and being in a group of 20+ other developers and designers with more experience was frightening. I was determined to prove myself though, and I set myself on a mission to learn both Unity and C#. C# was not as challenging as I assumed, as I was already adept at Java, but Unity proved to be the greater struggle with its unique intricacies. I ended up going to VGDev’s Unity breakdown meeting and followed along with Unity’s free training videos, and after 20 or so videos, I was finally ready to begin working on the game.
I became the Programming Sub-Lead, helping coordinate the other programmers and being assigned certain assets. My first challenge came in the form of reading and understanding everyone else’s code, as up until then I only had to update one or so small files at a time or write my own program…now I had to alter multiple files with hundreds of lines of code. It took me a while, but I got the hang of it. Unity and C# became easier and easier as the semester progressed, and by the end of production, I had come a long way! I helped program multiple assets and created many of my own. Some of my favorite things I implemented were the punching mechanic, inventory UI, and double-barrel shotgun.
Takeaways
I will never forget being part of my first video game team. Overcoming my programming hardships and helping create a true passion project have further cemented my love for making video games.
Additional information about VGDev is available at their website: gtvgdev.com
Paddle Home Before Dark
Team Size: 5
Tools: Unity3D, C#, Visual Studio, Git, GitHub, Trello, Discord
Time Constraint: 2 months, May–July 2024
Role: Lead Gameplay Designer and Programmer, Quality Assurance
Repository: https://github.com/alrob22/CS4455-Shark
Background
Paddle Home Before Dark is a physics-based adventure game developed by myself alongside a team of four others using Unity and C#. It is a unique experience due to the realistic paddle controls.
Concepts
The game came from Kruti’s then-recent experience paddling down the Chattahoochee River. While she described her experience, the rest of the team thought of the great idea to create a game that simulates kayaking, with realistic paddling. With the gameplay concept in mind, the rest of the game was built off of our experience with other adventures (and adventure games). The idea of making it home before dark came from our collective love of seeing the sunset while hiking or traveling and in games like Firewatch and our collective fear and dread that came with the nighttime.
Development and Learning Curve
I solely designed and implemented the core gameplay, including the player controls, enemies, objects, and win screen and conditions, alongside various UI elements. This was a huge undertaking, but it is an undertaking I am immensely proud of. I had near full reign of how the game felt and played, and it really felt like the game reflected my output.
I wanted to create a unique movement system that was not simply “push up to go forward,” so as stated, the controls mimic real-life kayak paddling. This includes having normal, wide, side, and back strokes all accomplished via positive to negative axis values. To successfully integrate these controls, a complex physics system was incorporated to better perfect the paddling simulation; although, we did supe up the speed and rotation for some of the strokes to make it more fun. The enemies of the game were sharks … odd choice, I recognize, but we were Team Shark so we wanted them on brand. The enemies were implemented with an AI state machine that had the sharks patrol, chase, and attack at the proper distance from m the player. These states came equipped with their own movement and animations. The enemies’ movement was accomplished thanks to Unity’s NavMesh baking and NavMeshAgent. The gameplay revolves around the player dodging various obstacles and outrunning sharks to make it to the end. Using Kruti’s terrain as a base, I implemented both the sharks and obstacles in specific locations that proved to be a fun challenge for any player. This gameplay was user-tested multiple times in order to be perfected and to make sure it felt right for experienced kayakers and those new to kayaking or video games.
Game Trailer:
Takeaways
Having free reign on a project, either entirely or for a specific component, will always feel special to me. It is a way for me to prove to everyone my skills and talents, and I did exactly that with this project.
No-Face: Absolution
Team Size: 4
Tools: Unity2D, C#, Visual Studio, Git, GitHub, Discord
Time Constraint: 2.5 months, March–May 2024
Role: Lead Designer, Level Designer and Programmer, UI/UX Designer, Storyboard Writer and Editor
Repository: https://github.com/alrob22/NarrativeGame
Background
No-Face: Absolution is a multi-leveled game developed using Unity and C#. It spans three distinct levels with interactive cutscene-esque dividers that serve to introduce each level, all held together by a morality system. This was developed by myself and a team of three others.
The game heavily features characters, settings, and themes from Studio Ghibli’s Spirited Away. This was our first time working within the bounds of an existing story, and it was tough creating a product that existed within the source’s characters and themes while also expanding said characters and themes. Ultimately, we produced a product that accurately expands the character of No-Face and delivers an experience that acts as a rich, fun supplement to those who want more of him.
DISCLAIMER: This is a student project and is in no way affiliated with Studio Ghibli.
Concepts
No-Face: Absolution came from our team’s love of Spirited Away and its character No-Face, who embodies the change a person can go through when surrounded by those who are compassionate to themselves and others. During the film, we see No-Face change from a rageful monster in the bathhouse into someone who is a lot more calm and caring when he arrives at the swamp. This change seemingly happens as No-Face and Sen (the main character in the film) make their way to the swamp in the Spirit Train, but the film never explicitly shows or describes this change — it is all inferred. This subtlety benefits the film in how it explores its themes while also leaving it up to the viewer's interpretation. That viewer interpretation was the catalyst to developing this game, as each member of our team had a unique viewpoint as to the true nature of No-Face’s change. This led to the idea of creating a game that took very distinct levels and tied them together with divider sections and a varied ending to show No-Face’s overall growth. We achieved this by framing his growth as an empathetic observation of a passenger on the train, as the film shows how he seems to be very susceptible to a personality change depending on who he is around. Each level has No-Face “delve” into the memories of another passenger and learn how to be more empathetic.
Elliott, Nick, and I developed our own unique level, while Jessica focused on the divider sections. These three levels differed in genre, objective, characters, setting, art style, and pretty much everything else. The only thing that tied our levels together was the theme of bettering yourself, implemented through a morality system. Each level has two methods of completion: peaceful and rageful, and it is up to the player to decide what method they want to pursue. The game does not explicitly tell the player this mechanic; rather, the game will display a different ending after the last level depending on how moral the player’s actions were. This system is dynamic; if the player is rageful in the first level and feels bad, they can make it up in the following levels for example.
My level sees No-Face delving into the mind of Yubaba, the vile owner of the bathhouse, as she decides which customers deserve the nicer baths. She only has a limited expense budget, and the nicer baths cost more to operate. The player can make two choices for each of the customers: be greedy and keep the money or put the money towards those who need it. No options give any direct benefits; it is all dependent on the player’s own sense of morals. This was all created using Unity’s UI in the creation of button events that dynamically alter specific UI asset values.
Learning Curve
In the past, my games’ story and theme(s) had always been a backdrop to help give context to certain assets, but this whole game’s experience and development hinged on the development of a strong story and theme. This was a struggle, as no one in our team had any previous writing experience for games, nor did we feel capable enough to delve into and expand upon such a complex film as Spirited Away. We took the challenge incrementally, first having multiple meetings where we discussed ideas and how certain problems would be tackled. This tremendously assisted in finalizing the game’s details at a later date, as we had a variety of ideas that we got to experiment with. This gave me a better appreciation of patience in writing and designing. After many discussions, we developed a storyboard, also a first for us all. I had always just thrown myself into a project and learned “on the job,” but I don’t think I will ever do that again. Storyboarding this game made developing and connecting each level so much easier as we all knew how our own work would fit into the game as a whole. This game taught me the value of forethought when it comes to development, both in terms of the gameplay and the other aspects of a game.
Takeaways
I am always grateful for the opportunity to tackle a project in Unity. This was the first game that I was able to develop without any help (in terms of how to do something), which allowed me to perfect what I already knew, heavily growing my knowledge, skills, and experience when it comes to game design and development.
Arborreal
Team Size: 4
Tools: Unity2D, C#, Visual Studio Code, Usenti, Git, GitHub, Trello, Discord
Time Constraint: 2.5 months, October–December 2023
Role: Overworld Lead, Lead Programmer, Lead Designer, Background Artist
Repository: https://github.com/alrob22/GameStudiesFinal
Background
Arborreal is a turn-based role-playing game developed using Unity and C#. Its unique mechanic is the integration of terrain into battle. This was developed by myself and a team of three others.
For the rest of our team, this was their first bigger project in Unity and Git, so this was tough to tackle. Each of us had grand ideas and ambitions for this game, though, and we ended up with a satisfying product.
Concepts
Arborreal came from our team’s passion behind themes of loneliness and exploration, a color palette of orange and cyan, and unique turn-based combat. Elliott had the idea of integrating terrain into turn-based combat. He created a unique implementation that rewards the player for gaining the high ground and strategically degrading the enemy’s terrain. For the gameplay outside of combat, I wanted a true-to-form experience for a turn-based role-playing game. The player crosses different rooms, avoiding enemies that chase them. A collision map surrounds the player, making their movement limited.
Learning Curve
This was my first game where I struggled with my team. Another teammate and I were designated to the entire game outside of the combat and excusing art; however, I ended up implementing roughly 90% of the project outside of the combat and 45% of the artwork, on top of being the only one with experience in Git and GitHub and creating initial assets and an initial layout for the combat. Needless to say, I put in a lot of hours on this project. It was difficult and extremely frustrating, but I wanted to produce a satisfying product, and even though we ended up making some cuts in some aspects, we pushed through to the end. It taught me a hard lesson about the value of myself and the value of a great team.
Takeaways
Although I had hardships with this project, I always enjoy making games in Unity. This was my first Unity 2D project as well, which opened the door for me to modern 2D game development.
Animations
Team Size: 1
Tools: Unity3D, C#, Visual Studio, Blender
Time Constraint: 2.5 months, October–December 2024
Role: Animator, Programmer
Concepts
Both of these animations were created primarily using Unity3D with C# for necessary scripting and Blender for necessary asset manipulations.
The ideas for these animations came from … well, no one source I’ll tell you that. Animation has never been my strong suit, so I was excited to have two projects that solely focused on animation. Although, even after these projects, I am not sure animation will ever be my strong suit! These projects were very open, and I had the option to take them down any path I chose given I focused on a key area. Seeing as camera movement is extremely important in video games, and I have never truly focused on camera work, I wanted that to be the focus of these animations. I decided to make both of these first-person experiences to get the full effect of the camera movement and challenge me to make first-person cinematics.
Development and Learning Curves
Having recently been playing a lot of first-person shooters at the time of prototyping, the idea I had for the first animation was a gallery shooter like what you see at carnivals. From there I built a Wild West setting, thankfully finding or creating the necessary assets with relative ease (except for Stinky Pete who would not rig properly for the life of me). Camera movement is extremely important in first-person shooters, and it was a challenge to line everything up correctly. I swear I moved the camera around in the scene over 200 times to pinpoint the exact rotation and position I wanted. The initial version of the animation had the camera standing back from the gun a bit, almost like the camera was just watching the gun work itself instead of actually shooting it. It hurt when I finally moved the camera into the correct position and realized that I had positioned all of my animations incorrectly... The biggest challenge came from correctly adjusting the speeds of each animation. I had fully developed the gun shooting part before I created the camera walking up to it, which I never intended to do before project feedback. This created a big problem as the camera walked up onto an ongoing animation. To resolve this problem, I created a script that delayed each of the gun and target animations and tested multiple, multiple times to accurately sync up everything. This was a pain because my camera was on 1.0 speed and everything else was on 0.5 speed, and having them the same speed would have caused multiple problems. This taught me very valuable lessons about animation, particularly in Unity. I guess I kind of imagined animating in software like Unity to be more like where you have a big single dope sheet that you can place every animation on and have it sequential like a film or audio. It made me realize just how complicated animation in games is; it is often not a single continuous animation, like what I am used to with my previous film and audio editing, but rather many different pieces with their own dope sheets that have to be coordinated. I look back on this project with a lot of clarity in my hindsight.
Since I focused on first-person shooting with the first animation, I decided to focus on first-person parkour for the second, another genre of game (and film) that requires excellent camera work. This time around, the project requirements made me purely focus on the camera, allowing me the luxury of not animating anything else and running into the previous animations’ problems! It also allowed me the time to better focus on world-building and story, which really intrigued me in the first-person space, especially after playing Mirror’s Edge. The game became a huge inspiration for this animation. This animation is well-documented with both a proposal and a final artist statement/summary. Do note: The proposal is very rough as it was written to be a simple script for me to read off of, with the inspiration section being added later for the purpose of a later demo.
Do not hesitate to reach out to me for more details!