3/20-4/3:
I’ve had a lot of progress over the past two weeks. Here are my updates:
Bug Fixes & Tweaks (5 hours)
A lot of my time was spent fixing various bugs and adding various tweaks in the game. These include:
Fixing the hitbox of the boss to allow it to damage the player.
Adding “encounter bounds” to the boss to allow the camera to move with the player, rather than restrict the player to just moving right.
Fixing a bug where the boss would not flip horizontally
Allowed players to collide with the door at the club entrance
Removed the ability to roll while in the air
Reenabled the sideways jump kick
Fixed the ability to preserve momentum while jumping
Fixed a latent bug where the mouse will be disabled after enabling the developer console
Added i-frames to the player’s roll
While each individual bug did not take much time to solve, a lot of the time was spent actually replicating the bug so it could be fixed. These bug fixes ended up improving the player experience significantly.
The Brandon Move (1 hour)
In addition to bug fixes and minor tweaks, I spent some time this week implementing a new move for the player’s mobility. Informally called the “Brandon Move” after its designer, Brandon Schultz, the move launches the player in the air if they double-tap the roll button twice. This allows the player to have greater mobility options and forces them to jump in the air and potentially use the kick.
I spent some time refactoring the player’s dash to accommodate this new move. One thing that surprised me was that the roll functionality was on the PlayerController script rather than the CharacterMotor script. While not a big deal, it is something I would refactor because the PlayerController was not meant to directly handle dashing.
Enemy II Adjustments (3 hours)
Last week, our programmers completed the functionality for the heavy enemy (enemy II). However, there was a miscommunication between art and design about what the enemy would do for an attack. Design originally wanted a really strong attack, such as a big punch, and made the state machine diagram with this in mind. However, the art department made the animations into a dash. When programming implemented the state machine diagram exactly with the dash in place of the attack, it led to really strange behavior.
To solve this problem, I contacted our enemy and combat designer, Brandon, to talk about how the dash changes the enemy’s behavior. He created a new state machine that accounted for all of this. The main difference was the enemy will move to somewhere near the player before initiating the dash. In addition, the enemy should blink before doing the dash to telegraph the attack. I spent a couple of hours making the necessary adjustments to the heavy enemy script. By the end, the heavy enemy was much better to play with.
Leads Meetings (4 hours)
As Project Lead, one of my responsibilities is to create the agendas for leads meetings. These are meetings where we talk about our department’s progress, ensure we’re on the same page about important decisions, and discuss the next weeks of development. I spent roughly one hour a week typing up the agenda before the meeting. This allows us to create our quickly discuss all the points we feel are relevant. The leads meetings take roughly an hour per week. Overall, these meetings are really helpful for us to understand where we are and answer cross-departmental questions and dependencies.
Studio Meetings (6 hours)
As Project Lead, one of my responsibilities is to create half the slides for and host the studio meeting. I create slides on the project’s progress (including our burndown chart), what we’re doing in this sprint, and the MDP devlog process. The slides usually take an hour to create. Having these slides allows members to feel like the content of the meetings are structured. The meetings last for about two hours, as we now have members talk directly to designers after their department meetings. At each studio meeting, I usually hop into one of the department meetings (this week it was programming, last week it was art) and listen in, actively providing answers and insights.