10/30-11/13: The Final Feature Push
I’ve had a lot of progress over the past two weeks. Here are my updates:
Improved Tutorial (3 hours)
A lot of the feedback from last sprint’s stable build was focused on the way the tutorial works. The tutorial works properly, but there is a lot of text, not a lot of visual indicators, and can be circumvented (or broken) if the player performs actions in a different order than the tutorial wanted. I worked with our UI designers to improve the tutorial. The major improvements are:
We now only have a single tutorial box in the game. The player only needs to focus on a single area of the screen, which has been specifically designed to not block anything else, for their tutorial messaging. Unlike the previous version, the tutorial box does not disappear until the player completes the action, ensuring they don’t feel soft-locked.
The tutorial has far fewer lines of text. Much of the narrative “bloat” has been stripped out of the tutorial, making it much more readable for players.
We now have far more visual indicators for how the player needs to perform actions. These include overlays, which block out specific parts of the screen to highlight objects, and arrows to show the player how to drag items.
Ship Building Improvements (5 hours)
I worked with our UI/UX designers to make substantial improvements to the ship-building flow. These were some final features in how the player interacts with the phase, and they include:
The addition of “filters” for ship systems. This is just like a filter in a store website, in that it enables you to focus on a specific category of items (in this case, weapons, shields, medbays, and other).
The ability to select items in the shop rather than just drag them. By selecting an item, you can view it’s information even when other items are hovered.
The ability to buy back health from the game if your ship is damaged.
Various bug fixes for the shop, including a fix that allows you to buy ship upgrades.
Designer Support (4 hours)
A lot of my time this sprint was spent on supporting designers in their role as they integrate assets into the game. Almost every designer went into Unity for the first time this sprint, and they were lost. I told Kelly, the design lead, to tell her designers to contact me for support. The designers were working on everything from balancing to narrative integration to UI/UX design, and there was no one-size-fits-all approach to helping them. I spent a lot of time this week answering their questions individually on discord, and pointing them to the correct places.
In addition, I participated in two meetings with designers to assist them. I had a one-on-one meeting scheduled with a combat designer to show him around the engine and point him to where he would need to make changes. I also had a design session with Kelly and a few designers from the messaging squad, where I walked them through how our UI was structured and where to make design changes. I was very happy with their work, as they are picking up in-engine work relatively quickly.
Repository Management (4 hours)
I spent a lot of my time on maintaining the repository, which involves merging pull requests, fixing Merge Conflicts and hotfixing the build when needed. I merged in 54 pull requests these past two weeks, which was (thankfully) not as high as the previous sprint. However, there were more substantial merge conflicts this time, due to the speed at which we were getting features in and the fact that designers were merging things into the game themselves. I was able to successfully navigate a lot of the conflicts (although we get strange errors about broken pointers).
A bigger thing this sprint was the amount of time I spent looking at other people’s branches to finish their implementation. Several of my programmers told me that they felt like they were mostly complete, but we’re getting stuck on the final step of their implementation. As a result, they asked me to look at their branches and try to find the bugs. I was able to do this successfully thanks to my knowledge of the codebase and good debugging tools.
Programming Meetings and Office Hours (2 hours)
A lot of my time this week has been spent in meetings. There are two types of meetings:
The weekly all-hands meetings. This is where every programmer is required to come every week to meet with their squads and then meet with me to discuss their tasks for the week. These meetings can go on for two hours, as there are a lot of things to discuss and the teams are large. During these meetings, I go through my members one by one, discuss what they talked about in their squad meetings, and ensure they have good tasks. These meetings have been shorter as we exit feature work and go into bug fixing and polish.
Office Hours. These are a type of optional, opt-in work sessions that I host once a week for two hours. These are places where programmers can go to get help or work collaboratively. Only a few programmers have taken advantage of this, and I hope more do.