Pooh’s Honey Hunt
Team Size: 1
Tools: C, Visual Studio Code, Docker, mGBA, Usenti, Tiled, Audacity
Time Constraint: 2.5 months, October–December 2023
Role: Sole Project Developer
Background
Pooh’s Honey Hunt is a 2D turn-based action role-playing game designed and developed solely by me. The game was developed for the Nintendo Game Boy Advance, altering many of the system’s data locations to provide a tailored experience. Using Makefile and Docker software, the game is available in a .gba format that can be experienced through any Game Boy Advance emulator, such as mGBA, which was crucial in the development of the game.
The inspiration for this game and its main mechanics came from my then-recent playthrough of Mother 3, a Game Boy Advance title developed by Nintendo. I was enamored by the various mechanics and systems running throughout the game, and having been in a class specializing in making Game Boy Advance games at the time, I realized just how complex and impressive games such as Mother 3 were. The Winnie the Pooh theme of the game was directly from my adoration of all things Winnie the Pooh, plus I loved the sprite sheet I found. I wanted to juxtapose that friendly atmosphere of Winnie the Pooh in the creation of some comedy and some horror.
Concepts
Pooh’s Honey Hunt takes direct inspiration from Mother 3 in the core gameplay (as shown).
The game begins in an overworld, where the player explores the Hundred Acre Woods as Pooh. The overworld is top-down, with enemies scattered throughout that will chase the player if they approach them. When the player collides with an enemy, they will be taken to a battle state, where the player can use three attacks, defend, heal, or flee. I decided to streamline the battle options due to time constraints. Mother 3 fleshes out all of these battle options. When the enemy is defeated, the player will return to the overworld. As the player defeats more and more enemies, text screens will reveal hidden elements of the game. The first reveals the location and input required to gain the second attack, the second reveals the cheat attack that can wipe out an enemy in one blow, and the third reveals the location and input required to access the final boss. The boss is a suped-up enemy. I chose to have these elements accessible anytime in the game based on the game Outer Wilds, where the only thing stopping the player’s progression is their own knowledge. This unfortunately is not a core gameplay element, but it is a nice feature that I enjoyed implementing. These gameplay mechanics allow for an overall fun, challenging, and rewarding experience for the player.
Learning Curve
I had never been responsible for a project of this size on my own before. It was a truly daunting task. It was hard for me to even decide on the initial direction of the game. As a gamer, I have had multiple ideas on how to improve practically every game I have played, and have stated “So-and-so should hire me” more times than I can count, but when it finally came to creating an entire game on my own, I froze. But I took all of the aspects of game development I had learned so far and used them in the creation of this game, alongside fantastic help from my peers and studying my inspirations closely. I ended up coming up with an ambitious idea for a role-playing game, one I had thought out down to the specific lines of code, and after a month of cutting it down to fit the deadline, I finally finished it. I cannot express how wonderful the overall experience was, and I am extremely proud of this game and how I approached it and excelled at it. Plus, it got great reviews!
Takeaways
I will never forget my first solo game. I mean, I had made games on my own before but none that I truly felt were my own or that stood alone as a full game as much as this game does. This heavily increased my adoration and respect for game development.
Artwork
The first two images are a couple of the drafts I did for the game. The first is the map I wanted to do and the last is the gameplay UI. I drafted out the game a lot, which taught me the importance of prototyping instead of just diving straight in, even if that is what I did for a lot of the game…
The last two images are some of the final artwork that I used in the game.
The finished map changed a little due to both over-scoping with the draft and having not yet familiarized myself with my tilesheet at the time of the draft. I had to learn from the tools I had available, which made the game exciting to work on. I never knew what the final product was going to be, no matter how much I planned it out. It was a challenge too to develop everything within my constraints while still having it match at least a version of what I wanted.
The sprite sheet shown is the primary sheet that is used in the overworld, housing all overworld sprites for Winnie the Pooh, the enemies, and the items. It was extremely fun to customize my own sprites based on existing sprite sheets, namely from Kingdom Hearts: Chain of Memories and Mother 3. It was a bit of work though; I had to lobotmize and physically shorten each Pooh sprite a bit in order to fit him into the game, both in terms of the sprite size and memory size I needed for the entire sheet!
Sprint One
Team Size: 5
Time Constraint: 4 months, August–December 2023
Tools: Java, XML, Android Studio, Trello, Git, GitHub
Role: Lead Programmer, Lead Designer, Character Artist
Repository: https://github.com/alrob22/CS2340C_Team53
Background
Sprint One is an action, adventure dungeon crawler game designed and developed by a team of myself and four others. The game was developed for Android platforms utilizing Android Studio. In Sprint One, the player must traverse across four different rooms in order to win, defeating enemies and getting power-ups along the way.
The game was designed to utilize design patterns. Multiple design patterns were used, such as the Singleton, Strategy, Decorator, and Factory patterns in the implementation of game mechanics, and the Model-View-ViewModel pattern was used in the structure and format of the game’s code. All of these design patterns were utilized to their full ability, allowing for an experience with high functionality.
Learning Curve
Software design patterns are extremely complex and difficult to implement in some cases. This was my first time learning about and implementing them, and having to do so for a complex game was no easy task. I had to hone my programming skills and pay closer attention than ever before to how I programmed. This resulted in a more focused learning and programming experience, one where I learned how to be more efficient and functional, in both my code and my work overall.
A lot of my struggles with this game rested on my personal implementations. No one in our team had one select duty, at least not when it came to the mechanics and assets of the game, so I contributed to multiple front-end and back-end parts of this game. This was challenging, but I enjoyed gaining the experience of both, plus the front-end aspects of the game were a lot less challenging compared to the back-end aspects. Android Studio is an intimidating platform. I needed to learn its unique systems and how they could be employed in order to better our game. This was especially difficult, but after a couple of weeks or two, I was able to utilize it in the creation of the groundwork for the game’s score and the attacking mechanic, both of which became a lot easier. I also utilized its systems in the implementation of the Model-View-ViewModel design pattern—a task that, once completed, made me understand the ability of these design patterns and how they can be properly used to enhance implementation. The other design pattern I worked closely with is the Factory Pattern. This was used in the integration of enemies into the game. This was actually the easiest task I had to do in the game, as the Factory Pattern fit perfectly in with the implementation of multiple semi-unique enemies. Design Patterns look complex at first, but working on this project taught me the value of them.
Takeaways
Having to implement software design patterns for the first time on a complex game, on top of Git implementation and developing complex mechanics, made this project a bit of a headache, but I was ultimately glad to tackle a tough project such as this one, especially with our amazing team, as I learned a lot more about programming effectively, working within a team, and managing responsibility.
Crystal Dragon
Team Size: 3
Time Constraint: 1.5 months, April–May 2024
Tools: GLSL, C++, Visual Studio, Git, GitHub, Discord
Role: Project Manager, Lead Programmer, Lead Designer, Environmental Artist, Conceptual Artist
Repository: https://github.com/alrob22/cs3451-final-project
Background
Crystal Dragon is an image developed utilizing computer graphics skills with OpenGL Shading Language (GLSL) and C++. It was developed by myself and two others as a demonstration of our developed computer graphics skills, utilizing a variety of algorithms, techniques, and linear algebra in the construction and manipulation of complex 3D models, texturing, lighting, shading, ray tracing, and particle creation. It was also a showcase of how we could expand past the scope of the project; I developed the use of a point light and skybox with this in mind.
The image was designed as a homage to a classic computer graphics trope: a cool dragon flying around a volcano. We added our own flair to have ours stand out.
Technical Details
I worked on the entire volcanic mountain range (including the main noise terrain, the smaller noise terrains inside the volcano’s top, and point light) and skybox for the project.
The volcanic terrain was made using a standard Perlin noise implementation in a terrain vertex shader file. I halved the mountains’ heights which had a height of over 0.5 and multiplied it by 0.75. This made a single mountain in our range decrease its height in an odd and spiky way, producing the perfect volcano. Inside the volcano’s top sits multiple smaller terrains stacked on top of each other to fill in the gap of the top and simulate a light source and visual that makes the volcano look active. These smaller terrains are spheres using our terrain shader, allowing them to be curved and fit decently into the volcano’s top. All of these terrains were lit using a red-colored point light to simulate light coming from the volcano. This was done in our terrain fragment shader by first making a pointLight struct with new attributes: constant, linear, and quadratic. PointLight and vec3 fragment position variables were then added to the phong shading method to calculate the light’s unique distance (distance between the light position and the fragment position) and attenuation (an equation using the new point light variables to make the light dimmer the farther it is). The attenuation is then multiplied to the ambient, diffuse, and specular colors in the method to dim them accordingly. Lastly, a pointLight variable in the main terrain shading method was instantiated that was used as the terrain light source. It was instantiated with linear and quadratic values correlating to a distance of 100.
Learning Curve
It was a challenge to make a terrain that accurately reflected our theme. I started with the volcanic landscape, which proved to be challenging to construct since we needed a volcano amongst the regular mountains. Thankfully, using our gained knowledge in the creation and manipulation of noise terrains, I was able to accurately manipulate the height function into producing something abnormal, creating our volcano. To enhance the theming, I decided to implement a point light and volcano topper. The point light was difficult to implement as it required a lot of manipulation in our terrain shader, but our previous lighting and shading knowledge from previous smaller projects allowed for a great starting point. The volcano topper became smaller terrains, which were a pain to maneuver, needing very accurate positioning to look realistic. I eventually got these positions set by utilizing matrix manipulation skills in the transformation of these models.
The skybox was a challenge in itself, but not in terms of implementation thankfully. It took hours to find the right images, as many sites only had panoramas or a single image. Chopping a single image into six other images never worked either, since they were all extremely blurry. Thankfully, I finally found six images that only needed to be converted. They are still a little blurry and some of the images are not rotated correctly (for some reason), leaving some edges visible, but both of these limitations were not an issue for how we wanted our final image to look. Plus, the images being a little blurry makes the sky more smokey/ashy and makes much of its scenery look distant, giving even more focus on the volcano.
Takeaways
This was my first big computer graphics project that incorporated all of the individual skills I learned, allowing me to expand my skills in a way that focusing on only one implementation does not allow for. This project has thickened my skillset and allowed me to gain a better appreciation for the work of computer graphics. As a game designer/developer, this has further increased my appreciation for every aspect of the design and development process, and I am glad to have learned more about this side of that process.
I am grateful for the opportunity to learn and use these computer graphics skills.
Additional C Projects
I have also created a lot of smaller projects in C for the Game Boy Advance. Some are more complex than others, but they all demonstrate my progression with the C language and the Game Boy Advance hardware.
Some highlights include:
A game where the user controls a square, can select a color, and can paint the screen. This was my introduction to conditionals via input
A brick-breaker-type game, which introduced me to different game states
A connect four game utilizing complex sprite work and palette and tile modification
An animation of a dancing stick figure utilizing vBlank interrupts to shuffle through the animation
A song player where the player can flip through, repeat, pause, and shuffle songs. This was my introduction to audio sampling and its intricacies
A snake game utilizing a complex linked list and struct system, transforming my C files into an object-oriented project
Frogger. This was my first C game with multiple systems at play. It was tough to tackle, but it allowed me to gain a better understanding of how multiple different mechanics can come together
FROG GANG WAR (top picture). This was an original idea where I could use the art from Frogger and transform it into another game completely. It was a real fun and challenging prospect to tackle
Walter’s Hat Hunt! (middle picture). This introduced me to more complex artwork and animations, and it was hilarious to make
Bubble Bobble (bottom picture). Created two fully realized levels of the game Bubble Bobble
Additional Java Projects
Throughout my tenure in programming, I have developed a multitude of smaller projects in Java, my first programming language. These projects may not be very complex, but they show my growth over the years and provide a glimpse into my first-ever programs. Most, if not all, of them require some form of input from the user via the terminal.
Some highlights include:
A Fibonacci sequence where the user inputs the size
A maze game (pictured)
A semester GPA calculator
A program to find a CD from an inputted CD collection
An action RPG
A program to get the GCD of two inputted numbers using the Euclidean Algorithm
A randomized Pokemon battle where the user selects their Pokemon
A program to keep track of/list items from the grocery store
An adventure/quest game using CSV files alongside Java
A to-do list using JavaFX (pictured)
Do not hesitate to reach out to me for more details!