Categories
Game Design Game Development Geek / Technical

Freshly Squeezed Progress Report: Clown Skin Colors and Eyes

In my last report, I worked on audio sound effects and music in my second Freshly Squeezed Entertainment project called Clown Alley Creator, a creativity tool about creating your own fun clowns.

Since then, I’ve added an options menu and a few more customization options for the clowns you can create.

Sprint 2024-11: Options Menu

Completed:

  • Create gear icon for options menu
  • Allow player to mute SFX and music separately
  • Allow player to choose skin color for clown
  • Create eye options

I started the week working on adding the ability to mute and unmute music and sound effects from within the game, which is why the theme for this sprint was “Options Menu” instead of skin color and eyes, which ended up taking up the larger amount of time and effort.

There were already buttons to toggle audio from the main menu, but the player may want to do so while the game is running, so I created the gear icon and created a modal that pops up over the top of everything.

Clown Alley Creator - options button

Clown Alley Creator - options modal

Then I decided it was time to work on clown skin colors. So far the default was that you were creating a white face clown, but not all clowns have white make-up for a face.

For now, I just used the sample colors I’ve been using for everything else, which aren’t very realistic skin colors or even realistic clown make-up colors, but I’ll work on adding those skin tones and such later.

Clown Alley Creator - a clown with blue skin?

I also wanted to give the player options for eyes. The neat thing is that, assuming my math is correct, now it is possible to create over 9 billion unique clown faces with just the few options currently available! That’s a lot of creativity potential!

Clown Alley Creator - some clowns with unique eyes

And of course, over the next few months, I’ll be adding more and more variety to each menu, so you’ll be able to create your favorite clowns with just the right noses, make-up, and hair styles.

Thanks for reading, and stay curious!

Want to learn about future Freshly Squeezed games I am creating? Sign up for the GBGames Curiosities newsletter, and download the full color Player’s Guides to my existing and future games for free!

Categories
Game Design Game Development Geek / Technical

Freshly Squeezed Progress Report: Colors, Music, and Sound Effects

Last time, I reported that I was adding primary and secondary color options for each selection in my second Freshly Squeezed Entertainment project called Clown Alley Creator, a creativity tool about creating your own fun clowns.

After a somewhat productive week, I not only have finished creating most of the functionality the game needs but also added music and sound effects to make it feel more complete and real.

Sprint 2024-10: Clown Faces

Completed:

  • Create color picker for nose
  • Create color picker for hair
  • Create color picker for make-up layers
  • Create background music
  • Create button press sound effects

You can now not only choose a custom nose, hairstyle, or make-up layers, but for each of them you can now choose a primary and secondary color.

Clown Alley Creator - selecting primary and secondary colors for each option

Clown Alley Creator - selecting primary and secondary colors for each option

Clown Alley Creator - selecting primary and secondary colors for each option

Clown Alley Creator - selecting primary and secondary colors for each option

Now, please (PLEASE!) keep in mind that this is not the final art that I plan to ship with this game when it is released. The point is that each selection can be customized by having two separate colors available if you wish, giving you plenty more options for your creativity.

Normally, audio doesn’t necessarily find its way into a game until the end of a project, but I’m making good progress. As I said, most of features are finished, so in a way it already feels like the end of the project.

And I found a really nice music track on SoundRangers.com during their last Black Friday sale, so I had to get it and think it fits perfectly in this game.

You can hear and see the game in action this clip:

Even with just the test sample of options for the nose, hair, and make-up and six color options I have so far, it is possible to create over 1,000 unique clown faces!

In the coming months, I am expecting that most of the work will focus on creating the many pieces of art for more such options, giving the player a much greater variety of ways to create their own perfect collection of clowns.

And I will get to enjoy the sounds I’ve added whenever I run the game to test out any such changes.

Thanks for reading, and stay curious!

Want to learn about future Freshly Squeezed games I am creating? Sign up for the GBGames Curiosities newsletter, and download the full color Player’s Guides to my existing and future games for free!

Categories
Game Design Game Development Geek / Technical

Freshly Squeezed Progress Report: Creation Mode Layers and Colors

In my previous report, I allowed the player to choose make-up in layers in my second Freshly Squeezed Entertainment project called Clown Alley Creator, a creativity tool about creating your own fun clowns.

After doing some end-of-year review work and writing a post about it, I got back to finishing up the layer work.

Sprints 2024-8 and 2024-9: Clown Faces

Completed:

  • Create make-up option and submenu

Started:

  • Create color picker for nose

If you’re paying attention, you might have noticed that I said I already completed the make-up submenu work last time.

But I realized I didn’t have a better place to capture the idea of adding the chosen make-up icons in the appropriate boxes on the screen, which is what I had left to do.

Clown Alley Creator - layer boxes now show icons

I also added an option to clear your selection.

Once that work was finished, I noted that I definitely have some clean-up work to do, mainly in terms of how the icons look kind of awful when tinted a particular color as it applies to the entire icon and not just the relevant make-up part.

But I’ll worry about splitting the icon up into multiple images later. For now, I am finally adding a color picker menu.

Clown Alley Creator - color picker menu

Basically, there will be a primary and secondary color for each option. So far, I have created the menu to choose a color, so this week I anticipate finishing the color selection menu, saving the player’s selection, and updating the clown previews to show those colors.

I will start with the clown nose, but a lot of this work will overlap with the rest of the chosen options, so I anticipate having the ability to choose colors for every option soon.

The main trick will be separating the nose, hairstyle, and make-up into a main colored part and a secondary highlight/texture part, but that just means each option requires two sprites to be rendered instead of one, so it isn’t much of a trick anyway.

Thanks for reading, and stay curious!

Want to learn about future Freshly Squeezed games I am creating? Sign up for the GBGames Curiosities newsletter, and download the full color Player’s Guides to my existing and future games for free!

Categories
Game Design Game Development Geek / Technical

Freshly Squeezed Progress Report: Clown Make-up

Last time, I reported that I had implemented clown noses and hair and was starting to work on the more complex layered make-up menus for my second Freshly Squeezed Entertainment project called Clown Alley Creator, a creativity tool about creating your own fun clowns.

I made great progress on it and think I’ve had a surprisingly productive December so far.

Sprint 2024-7: Clown Faces

Completed:

  • Create make-up option and submenu
  • Create clown preview make-up cut-outs

Much of this week’s efforts felt like a bit of a struggle, and I’m not sure if it is because I felt like I couldn’t focus on the work or if it was just because it was complicated.

Picking a clown’s nose is just choosing from a set of options, but I had envisioned the make-up menu to be made up of multiple layers.

That is, you don’t just pick a single make-up option. You can layer make-up on top of make-up, allowing you to mix and match options to create a clown face the way you want it.

Clown Alley Creator - make-up submenu with layers

As you can see, there are potentially four different layers of clown make-up available. I created some sample options that include the mouth as a smile or as a frown, a teardrop on either side of the face, and buckteeth.

Here you can see a clown face with a frown and a left teardrop.

Clown Alley Creator - make-up submenu with two layers of menus

To finish up this work, I want to show the icon in the box corresponding to the layer it applies to, number the layers to make it clear which order they go in (I think bottom to top is intuitive, especially for people who use art programs like Gimp or Photoshop), and finally choosing colors.

Right now, make-up is defaulted to a blue color just so I can see it differentiated from the hair and the nose, but I want to allow the player to choose primary and secondary colors for each option. What this means is that the various sprites for the clown face will need to be split into primary and secondary versions. In the case of hair, maybe it look like streaks of color, and in the case of make-up, perhaps outlines around the mouth and teardrops and such.

With Christmas coming so soon, I doubt I’ll be as productive as I’ll be spending more time at family and social events, plus I’ll want to spend time creating my annual year in review blog post. Still, I feel like I’m ending this year having made some great progress on this new project.

Thanks for reading, and stay curious!

Want to learn about future Freshly Squeezed games I am creating? Sign up for the GBGames Curiosities newsletter, and download the full color Player’s Guides to my existing and future games for free!

Categories
Game Design Game Development Geek / Technical

Freshly Squeezed Progress Report: Giving Clowns Hairstyle Options

In my previous report, I got the spine finished for my second Freshly Squeezed Entertainment project called Clown Alley Creator, a creativity tool about creating your own fun clowns.

I continued to build upon the work, focused on finishing the Gallery view and adding hair in the Creator mode.

Sprint 2024-6: Clown Faces

Completed:

  • Paginate gallery view
  • Create Clown Specific View
  • Delete clown
  • Create Hair & Make-up menu
  • Create hair option and submenu
  • Create clown preview hair cut-outs
  • Create Clown Specific View

As I said last time, I pretty much have everything in place that the player might do.

And yet, there is always something to enhance or improve.

For instance, the Gallery View allowed you to see 12 clowns at a time…but only the first 12 clowns.

So I added pagination in order to see more of them.

Clown Alley Creator - gallery view pagination

You may also notice that I added eyes to the clown faces. It was getting weird not having eyes, and while eventually I’ll let the player select eye options as well, for now it looks less strange.

Since you can add new clowns, you should be able to edit and remove clowns, so I added a close-up clown view with those options.

Clown Alley Creator - close-up clown view

Eventually you will be able to name your clowns and see that name instead of something like “Clown 6” in the title bar.

Editing just opens up the clown creator mode with the existing clown’s settings instead of a completely new clown. I’m very happy with how easy it was to do. In fact, I feel like this project has been surprisingly smooth sailing in terms of writing just enough code to not be wasting time while also writing good code that is easy to expand and extend.

Anyway, finally I added the hair menu. I had some concerns about how to actually implement hair. Clown hair/wigs can be quite wacky, extending quite a ways from the clown’s head, and I wasn’t sure how to approach it. Do I create separate sprites for the top and sides?

For now, I’ve created larger sprites. Basically, the head shape is one size, and the hair sprite is much larger, which allows for the hair to be fairly big if it has to be while also covering any part of the head that needs to be covered. Here are my mock-ups:

Clown Alley Creator - hair mock-ups

Clown Alley Creator - hair mock-ups

Clown Alley Creator - hair mock-ups

And here they are in the Gallery view:

Clown Alley Creator - clowns with different hairstyles in the Gallery

I ended the week getting started on the make-up menu, but I was also trying to figure out how to allow the player to customize colors for various options.

Clown Alley Creator - Hair & Make-up menu with Hair, Nose, and Make-up buttons

Clown Alley Creator - mock-up of color picker

Clown noses should not just come in red, and I think being able to choose primary and secondary colors for hair would be great, too.

But I feel like choosing colors is getting ahead of myself, so that’s on hold for the moment.

The biggest thing I’m trying to figure out is how to implement make-up. I’ve already decided to allow the player to do so in layers, which means making it clear which layer they are working on as well as the ordering of those layers. I mocked up this tabbed view, with the idea that you are currently selecting options for a given layer, and I think it should be intuitive that the layers are applied in order from top to bottom.

Clown Alley Creator - make-up menu mock-up with tabs

I need to do more work on this menu’s design. I expect it would be nice to move layers up and down, which means I need space for buttons to allow for it. I like buttons because expecting the player to know something like drag & drop is an option is harder to communicate, and I think too many modern UI elements are inexplicably hidden from the player, presumably to keep the interface looking cleaner or something.

It’s been a joy to see this project get more and more finished while at the same time feeling like it is always in a good state to be considered done. Last week you could customize noses for your clowns, and this week you can pick clown noses and hairstyles. Assuming I have time to work on the project as we head into the deepest parts of the holiday season, I expect to make it possible to choose make-up options in layers after this coming week, and after that point I’ll introduce color options. Each week, I’ve managed to make the game richer and fuller.

Of course, there is a difference between something being “technically” releasable and something being “marketable.” It is not unusual for projects to struggle with or even ignore being able to create a release until the very end of the schedule, so I feel really great about the way this project has been going.

I anticipated that December would be a slow month for me so part of my schedule assumes I’ll be working on these mock-ups and figuring out flows into January. Even so, I’m impressed with what I’ve put together in just the last couple of weeks. Soon after I’ll switch my focus to creating lots of options for each submenu, allowing a player to create potentially thousands of unique clowns using the existing menus. Then I’ll be polishing things up, testing things, and getting it ready for an official release.

Thanks for reading, and stay curious!

Want to learn about future Freshly Squeezed games I am creating? Sign up for the GBGames Curiosities newsletter, and download the full color Player’s Guides to my existing and future games for free!

Categories
Game Design Game Development Geek / Technical

Freshly Squeezed Progress Report: The Spine of the Game Is Done

Last time, I reported that I was focusing on getting a thin slice of work to create, load, and view the clown faces in my second Freshly Squeezed Entertainment project called Clown Alley Creator, a creativity tool about creating your own fun clowns.

I focused on creating the infrastructure to support this work.

Sprint 2024-5: Clown Faces

Completed:

  • Create nose option and submenu
  • Create Finish modal
  • Update Gallery View to show all loaded clowns
  • Create clown preview nose cut-outs

I had a fairly productive week, and I am very, very pleased to say that I finished making the game already.

Or at least the spine of the game.

What I mean is that the work I did this week cut across almost all aspects of the project.

As of today, you can start creating a new clown, choose from among a few customization options, then save the clown with those options, then view your creations in the clown alley gallery.

That’s pretty much the scope of this project. Anything else after is content and polish, with perhaps some extra features if I decide I have time for it.

Here’s a video that shows pretty much everything you can do in this game so far:

Now, you might think, “That’s it? You can’t say you are finished making the game yet!”

And you’d be right in that all you can do at the moment is pick from among four nose options. Clowns are more than red noses, obviously. While I could technically publish this, it would definitely feel unfinished and wrong to do so.

Clown Alley Creator - picking a nose

Clown Alley Creator - saving the clown

Clown Alley Creator - clown face gallery

But what else do I have to do? Adding more nose options is just adding more options to the existing menu. Adding color variations is just a different menu and a different variable to save and load. Creating better art is just replacing the existing art. And everything else from hair styles, skin colors, and make-up options are just variations of the same kind of work I’ve already solved.

Basically, instead of adding features and hoping it all comes together in the end like in many projects, I’m in a position of confidence that this project is always shippable from here on out. It just becomes a matter of how much I want to keep investing in it before I actually publish the game.

Now I still anticipate some challenges. Choosing mutually exclusive options such as clown noses is different from picking options that can layer on top of each other such as clown make-up. My code easily handles the former but would need to be changed to accommodate the latter. And I haven’t even touched on the UI problem of communicating to the player that these interfaces would behave differently.

But it is still early in the project’s schedule, and I have time to solve these problems.

Thanks for reading, and stay curious!

Want to learn about future Freshly Squeezed games I am creating? Sign up for the GBGames Curiosities newsletter, and download the full color Player’s Guides to my existing and future games for free!

Categories
Game Design Game Development Geek / Technical

Freshly Squeezed Progress Report: Plans to Create Clown Faces

In my last report, I finished creating navigation menus, only to rethink the prioritization of my project’s tasks for my second Freshly Squeezed Entertainment project called Clown Alley Creator, a creativity tool about creating your own fun clowns.

I started this week by focusing on how to work on things differently to make it more likely that I can ship something in the six months I originally wanted to.

Sprint 2024-4: Clown Faces

Planned and incomplete:

  • Create Hair & Make-up menu
  • Create hair option and submenu
  • Create make-up option and submenu
  • Create nose option and submenu
  • Create Finish modal
  • Update Gallery View to show all loaded clowns
  • Create clown preview nose cut-outs

I did some rearranging of my backlog and created a subset of tasks much like how I described in my last report. I didn’t expect to actually get all of these things done in a single week, especially not in a week with a major family holiday such as Thanksgiving, but I did like that this list captures what needs to be in place for the spine of the project to be in place, something I can build upon.

Unfortunately, I decided to keep my high level features/tasks as-is rather than rewrite them to more accurately reflect what I was done. It’s not an issue to work within, but it is harder to report here because it looks like I got nothing done.

In reality, what I actively worked on and finished looked more like:

  • Create Hair & Make-up menu with only the Nose option
  • Create Nose submenu

My thinking was that while the entire subset above makes for a good spine, I can get there pretty quickly if I focus on the simplest thing. Rather than provide a bunch of hairstyles or make-up options, I could create a couple of noses.

So my big goal is to make it possible for the player to choose a custom nose from among at least two options, see that nose in the clown preview while doing so, save the clown with the chosen nose, and then see that clown in the gallery: a thin slice/spine for a game about creating clowns!

I imagine if I hadn’t traveled to see family and instead had a normal amount of productivity last week, I would have some better screenshots for you today.

Clown Alley Creator - Hair & Make-up menu

Clown Alley Creator - Nose submenu

Part of the reason for the lack of finished tasks is because I recognized the need for a way to define my menus better than simply hardcoding the buttons into place on each menu.

I originally was writing entire functions to create and setup each menu. It could work, but it is a lot of manual work that risks looking inconsistent from one menu to the next. Instead, I could write an algorithm to lay out the options in a reasonable way, which led to me wanting to make my menus a bit more data-driven.

So two major things came out of this past week’s efforts:

First, I made the menus more data-driven. The menu titles, the submenu titles, and the menu button options and their locations are defined somewhere, and when the menu is created, it is able to grab all of that data and put it together.

It still has some things that are hardcoded, though, but the point is that it does go through this indirection in a way that makes it easy for me to replace those hardcoded values with values that are defined separately.

And second, I think I keep relearning that sometimes the first step to abstracting and generalizing is to get something concrete in the place first. Having a nose submenu with actual nose options hardcoded into place would have informed how to generalize such a menu better than me trying to generalize it upfront.

Doing the generalizing upfront risks creating a tool that I feel stuck with or have to work around rather than one that feels useful and helpful.

Anyway, I will continue to work on the spine of creating a clown with saved options that I can preview and load.

And since we just started the last month of the year, I also need to remember that December is usually one of the least productive months for me (more family holidays, after all) and that I shouldn’t expect to get a full month’s worth of effort out of it. Getting that simple spine in place before the start of the next year will feel like a pretty big win, I think.

Thanks for reading, and stay curious!

Want to learn about future Freshly Squeezed games I am creating? Sign up for the GBGames Curiosities newsletter, and download the full color Player’s Guides to my existing and future games for free!

Categories
Game Design Game Development Geek / Technical Post-mortem

Freshly Squeezed Progress Report: Navigation Menus…and an Agile Course Correction

Last time, I reported that I had created some backgrounds and menus for my next Freshly Squeezed Entertainment project called Clown Alley Creator, a creativity tool about creating your own fun clowns.

I had fixed a defect in some of my oldest code and continued to work on the initial in-game menus this past week.

Sprint 2024-3: In-game Menus

Completed:

  • Create Gallery View menu
  • Create Clown Creator Mode general navigation button icons
  • Create Clown Creator mode general navigation menu

Started and incomplete:

  • Create clown preview cut-outs
  • Create clown preview in Creator mode

I mentioned the ButtonControl defect last time, but buttons now work in a much more intuitive and correct way:

Then I started creating the in-game menus. The Gallery View is currently very simple because there is nothing to put in the gallery yet. So I created a button to return to the Main Menu, and I created a button to start creating a new clown in the Clown Creator Mode.

Clown Alley Creator - Simple Gallery View

I worked on some infrastructure code related to menus and widgets, mainly so that the animated button widget I had created would function properly. Basically, I wanted any interactive buttons to periodically let the player know that they are interactive, so every few seconds they will grow and shrink.

Then I created the Clown Creator Mode navigation menus. Basically, creating a clown will involve going through a sequence of menus to choose options related to the head and body shape, wardrobe, shoes, and make-up and hair. When you get to the last menu, you can choose to finish the clown, which will allow you to name the clown and save it to your clown alley and see the clown in the Gallery View.

Clown Alley Creator - Creator Mode view

Eventually. For now, the menus are navigable, either by hitting the previous and next buttons at the bottom or by picking one of the menus along the right side:

I finished the week by starting to work on creating a Clown preview in the Creator Mode. The idea would be create a bunch of sprites that, when composed together, create a clown that might eventually be animated.

Saturday night I went to bed feeling good about how productive the week was.

Sunday morning I woke up and realized that I wasn’t approaching this project in a very Agile way.

What Do I Mean by “Agile”?

Agile has become one of those terms that mean wildly different things to different people, so I want to clarify what I mean.

Some people think “Agile” means some form of dysfunctional approach to running a software project in which certain awkward practices and processes take primacy over everything else, no matter how painful it is.

If it wasn’t clear, that is NOT what I am talking about. You might hear people call it Agile where you work, but it isn’t really Agile. It’s just your probably-large organization not actually figuring out how to apply Agile to their existing processes so they keep a lot of baggage and then blame Agile for it.

But I can complain about dysfunctional work practices all day. For now, I want to talk about how my own approach to this project might be a problem, and I’m kicking myself for not recognizing it sooner, but I’m also patting myself on the head because I saw it early enough in the project to make some changes that I can still benefit from.

When I think about “Agile” I like to think of it as approaching the work in a way that acknowledges that we don’t know what might happen in the future, in a way that allows us to change, add, or cut anything based on what we learn as we go.

I don’t know how long a feature might take to work on and complete. Taken to the extreme, it also means I don’t know how long the entire project might take to work on and complete. I may or may not get sick, or have someone in my family get hurt, and so I end up with a lot less capacity to work on the project.

What does all of that have to do with being “Agile”?

Well, imagine that I continue the work as I have been. Here is a sample of my current backlog of identified work items:

  • Create Clown Creator Mode general navigation button icons
  • Create Clown Creator mode general navigation menu
  • Create skin color menu options
  • Create Head option and submenu
  • Create Body option and submenu
  • Create Wardrobe menu
  • Update Clown Preview to display clothing in layers and colors
  • Create clown preview wardrobe cut-outs
  • Create Shoes menu
  • Create clown preview shoes cut-outs
  • Create Hair & Make-up menu
  • Create hair option and submenu
  • Create make-up option and submenu
  • Create clown preview hair cut-outs
  • Create clown preview make-up cut-outs
  • Create nose option and submenu
  • Create clown preview nose cut-outs
  • Create Finish modal
  • Save/Load individual clowns
  • Update Gallery View to show all loaded clowns

If I were to work on these items in this order, it would make sense in terms of the order of the menus. I would work on creating the skin color and head and body submenus in the Head & Body Menu, then I would work on the Wardrobe Menu, and so on.

And this might work out fine, but it introduces some risks. This is supposed to be a six month project, which means that new development needs to stop before that sixth month, so really I only have a handful of months to implement everything.

Let’s say hypothetically either I take too long to make the Shoes menu or otherwise need to stop working on the project shortly after that point. If I absolutely had to publish the game at that point, what would be the state of the project?

Well, it would be unfinished! There is an entire set of menus related to hair and make-up that would be completely missing, and to make it worse, you could still navigate to that empty menu!

In fact, you couldn’t save or load anything, so the Gallery is perpetually going to be empty even though it is the first place you go after hitting Play on the main menu. How confusing and awkward for the player!

Even if you think it would be fun to just create clowns that you couldn’t save or load, how fun could it be to create clowns without being able to do their make-up? When you think of clowns, you probably think of clown noses, hair, and make-up before you think about their clothing. And yet this game would ask you to make clowns and ask you to ignore the hair and face entirely.

In short, approaching the project in this way would limit how adaptable I could be in the future.

A more Agile approach?

Imagine if I approached the work differently.

There are many valid ways to do so, but let’s pretend that last week I didn’t work on the Creator Mode navigation menus but instead focused on the Hair & Make-up menu as the sole menu. That is, when the player enters Creator Mode, they are exclusively working on hair and make-up.

  • Create Hair & Make-up menu
  • Create hair option and submenu
  • Create make-up option and submenu
  • Create clown preview hair cut-outs
  • Create clown preview make-up cut-outs
  • Create nose option and submenu
  • Create clown preview nose cut-outs
  • Create Finish modal
  • Save/Load individual clowns
  • Update Gallery View to show all loaded clowns

With just this smaller subset of the backlog completed, what would the project look like?

Well, it would be more or less complete as a game. It wouldn’t have everything I wanted, obviously. Clown faces aren’t the same things as entire clowns. I would want to continue working on the project.

But there would be a strong spine in place: you could create clown faces, save them, and see them in the Gallery.

In fact, rather than have “Save/Load individual clowns” as a separate work item, I would instead make it part of the work of each menu. That is, “Create the hair option and submenu” would also have an associated “Save/Load player’s hair option” task. Each menu wouldn’t be considered done until I could make something real happen by using it.

And that’s a much more Agile approach. Instead of merely splitting up the work, I am thinking through how to ensure that whenever I finish some piece of work that the project as a whole is more finished.

I’ll repeat that, because I think the core reason for some of the dysfunctional approaches to work I’ve seen is that people don’t seem to understand this concept.

Instead of just splitting up a project into pieces and then working on those pieces, instead of hoping that by putting enough finished pieces together that they will eventually become an integrated whole (and more likely have extra work trying to make it actually integrated as a whole), I could approach each piece of work as contributing to the whole in an incremental and iterative way. I could create the spine of the project, then continually add more and more to the bones while both maintaining and building a functional whole the entire time.

You know, how Agile is supposed to be.

I can’t go back and change how I worked last week, and it would be silly to completely rip out the menus I already created, but I am going to take some time to rearrange my backlog so that I can build that spine sooner.

Thanks for reading, and stay curious!

Want to learn about future Freshly Squeezed games I am creating? Sign up for the GBGames Curiosities newsletter, and download the full color Player’s Guides to my existing and future games for free!

Categories
Game Design Game Development Geek / Technical

Freshly Squeezed Progress Report: Backgrounds, Menus, and Plans

In my last report, I had started work on implementing my next Freshly Squeezed Entertainment project called Clown Alley Creator, a creativity tool.

I continued the initial work of the project.

Sprint 2024-2: Menus

Planned and complete:

  • Create a main menu

Unplanned and complete:

  • Create an exit menu

Unplanned and incomplete:

  • Create Gallery View menu

You know, reading the above, it makes it sound like I had a bunch of “unplanned” work, when really I just mean that at the start of the sprint I had identified only one set of tasks to work on and the rest were expected to be pulled in from my project backlog as I finished work.

I need a better way to report this progress.

Anyway, I finished the main menu work, which involved adding variations on the buttons so that they can be animated.

But I was unhappy with the background, and I ended up redoing it. It is still not great, but it is an improvement, and I like the look of the circus tent more.

Clown Alley Creator new title screen

The new font for the title looks great, too, and I decided to use it for the buttons as well.

Next up was sticking the landing and creating a background for the quit verification screen:

Clown Alley Creator quit verification screen

I liked the idea of the Quit button leading you to the Great Egress, which comes from a potentially apocryphal story about PT Barnum.

As you can see, I need to figure out a single art style. I’m kind of all over the place right now. Expect more iterations in the future.

About halfway through the week I needed to leave town for a family emergency. I was in the middle of working on the first in-game screen. Basically, you press the Play button, and it should take you to the Clown Gallery menu.

Unfortunately, other than creating the menu background, I hadn’t gotten to the actual menu options. So for this coming week I will add a button to return to the Main Menu and another button to Create a New Clown, which will take you to the Create a Clown set of menus.

This entire project is just a series of menus, so expect a lot of talk about menus and options.

I did discover that the code for a ButtonControl had a defect in it.

ButtonControl is some of the oldest code in GBLib, my bespoke collection of code I’ve built up over many years of refusing to use an existing game engine. It is based upon the concept of Immediate Mode GUIs, primarily from Jari Komppa’s imgui tutorials. Since my code was test-driven, it has a suite of unit tests, so I added a new test to capture the bug, which has to do with the button’s state getting reset from “active” to “hot” too fast, which explains why sometimes when you click a button that you don’t see it being pressed down.

I can’t believe I’ve ignored this issue for so long and across so many games, because it is a pretty obvious bug, but I suppose I’m paying a lot more attention to the game’s responsiveness to the player in recent years, and maybe this brand new project has almost nothing else to distract me from noticing it.

So expect that to be fixed, too.

Thanks for reading, and stay curious!

Want to learn about future Freshly Squeezed games I am creating? Sign up for the GBGames Curiosities newsletter, and download the full color Player’s Guides to my existing and future games for free!

Categories
Game Design Game Development Geek / Technical

Freshly Squeezed Progress Report: Initializing a New Project

Last time, I reported that I was still designing and planning my next Freshly Squeezed Entertainment project, which will focus on clowns.

Since last week was the first full week of November, I wanted to get started on actual development while I still figured out the full project plan’s scope.

Sprint 2024-1: Pre-production and Initialization

Planned and complete:

  • Get a basic project building/running/quitting

Unplanned and complete:

  • Create a title screen

Unplanned and incomplete:

  • Create a main menu

As you may know or recall, I write all of my own code. I don’t have a game engine so much as decades of built-up layers of bespoke code that I use as building blocks for my projects.

Unfortunately, it means that each time I start a new project, I need to disentangle the old project to create a new project.

It’s not as messy as it sounds. I’ve already separated out some generic code into something called GBLib. And when it comes to the game-specific code, most of that goes into a directory called GameSpecific, so I can pretty much delete everything in there.

But unfortunately there is still a small part of the game-specific code that gets into what should probably be a more generic area, and THAT’s where most of the effort lies.

Which frankly was still pretty smooth, and I made notes to try to improve the situation so that next time it is even easier to start a new project. The main delays came from spending time on other priorities (there was an election to reel from, after all).

Once I got the project building and running, I had a functioning but ugly main menu (much of this code is the same between projects) with an otherwise blank screen, so the next thing was to create a title screen.

So I created a few thumbnails of how the main menu/title screen would look.

Clown Alley Creator title screen thumbnails

I liked the idea of being outside of a circus tent, so that when you hit the Play button, you are indicating that you want to go inside. Having posters and signs for the other buttons, such as Quit taking you to the Giant Egress, seemed more fun than random floating buttons.

Then I spent time on implementing one, and…well, I’m not happy with it.

Clown Alley Creator main menu with background image

I know I’m not an artist by trade, but I feel like my programmer art skills are better than this.

BUT! This background image doesn’t have to be the final product. I can always improve it later.

For now, I have a menu, and I have buttons for it, and I’d otherwise be done with the Main Menu task except that the buttons need to have a few variations so that they animate when hovered over or when pressed.

Otherwise, I spent part of Saturday updating my project plan’s backlog with all of the scope I could identify upfront. I periodically had to create more mock-up screens to help me figure out what that scope could be.

Clown creation mock-up screen for unnamed next project

Looking at my last two completed projects, I had identified over 100 different backlog items by the end. However, each of those projects took me longer than six months, so while it was helpful to look through those backlogs to see what kinds of things I should document for this project, such as tasks to create app icons and create ports and create ways for the player to toggle audio on and off, I also guessed that maybe around 50 items is likely doable in six months?

I don’t actually know. Some tasks are bigger than others, and I still need to estimate how big some of them are relative to each other. I don’t have some of the more complex features I was hoping for, such as the animation work I was investigating in the last few weeks, and I worry that even without them that it might still be too much for a six month project.

However, I am being mindful to front-load a lot of the core system and coding work in the first few months, with the expectation that later months are all about adding content. I expect this approach means that the project will be considered finished in six months no matter what, and the only unknown is how much or how little variety I can provide, plus how much animation the clowns might have.

Thanks for reading, and stay curious!

Want to learn about future Freshly Squeezed games I am creating? Sign up for the GBGames Curiosities newsletter, and download the full color Player’s Guides to my existing and future games for free!