This is the last day for my February project, but the game may not be released today. The game can be made ready today, and that’s still possible, but before that happens, I need to get a web-component setup. This component is not part of the game, but it will hopefully help with promoting Pixelbyte’s upcoming games. Once I get it working, I will put a link to it in the game and we’ll be good to go. I don’t expect this to take too long, and it might possibly all get done today, but it could also take 2 or three more days.  I’m just not sure. I do know that this does need to be done, and it will only need to be done once, so my next 5 “1 month challenge” games will not suffer this delay. My original plan was to release 6 games for 5 platforms in 6 months. I still plan to do 6 games, but I may reserve one or two of those games for the desktop.  I’m still not sure about that, but some genres just don’t do well with virtual joysticks and buttons. To be honest, I don’t like virtual joysticks/buttons for any kind of mobile action game. They just frustrate me, and that’s because of the lack of tactile feedback that a keyboard, mouse, or joystick gives you.  When you push on a real joystick, you can feel when you reach the limit. Not so with a virtual joystick.  I feel like a hypocrite though because I have a virtual joystick in Buggers.  I don’t like it, but if I want to release to the mobile/pad ecosystems, I have to do it.

Here is what has been accomplished this week:

  • Squashed many more bugs in the Tiled loader scripts. They actually are working quite nicely now.
  • Implemented a new enemy using my behavior library. This is the first real thing I’ve done with behaviors and my library. As a result, I learned good stuff and many enhancements/additions were made to the library. [I spent way too much time on this]

    The little green bug is controlled by a behavior tree
    The little green bug is controlled by a behavior tree
  • Many improvements were made to Pixelbyte’s core libraries.
  • Polished and fixed many UI elements
  • Added multiplayer support (only for PC/Mac/Linux and it will probably not be in the first release)
  • Updated the in-game instructions screen
  • Added some cool features that allow for level development and testing using a build of the game.
  • Added sound effects for the player’s food vacuum. This was an interesting and fun exercise in that the sound needed to be broken up into 3 parts: vacuum start, vacuum on, and vacuum stop.
  • Implemented a scoring system that gives a player points for all bugs killed. Each piece of food put into a basket gives the player points plus a bonus multiplier that is applied to every bug killed. For example, if the player baskets a single piece of food, the bonus multiplier increases to 2x.  Every bug killed by the player then give 2x the normal points, unless a bug steals the food from the basket.
  • Added an in-game poll which allows players that complete the game to vote on a couple of questions about the game.

    voting
    In-game voting dialogs

Stay tuned.

It’s been over a week since my last update and according to my rules I’m supposed to do at least one of these per week. Since my last update I have:

  • Improved/refactored a bunch of my Tiled map importer code
  • Converted all my levels (there’s only 11 so far) over to the TMX map format
  • Added a more interesting end of level dialog that shows bugs killed and all the food you kept safe GIF2
  • Made changes/improvements to the virtual joystick controls for mobile
  • Refactored some of my UI code into what I think is a pretty good re-usable mobile dialog class for Unity’s UI
  • Made many changes to my core Unity3d library code
  • Many bug fixes
  • Installed El Capitan and the newest XCode on my MAC mini
  • Got all my expired iOS certificates and other assorted Apple obstacles cleaned up
  • Got a build of the game up and running on an iPhone
  • Ripped out the Ludum Dare quality “sound system” script stuff and integrated Audio Toolkit into the project
  • Found a nice SerializableDictionary implementation complete with a property drawer from spacepuppy’s Unity framework
  • Found a great free 32×32 outdoor tileset and spent far too much time slicing and dicing it into something I’m not even sure I’ll be able to use.
  • Went off on a tangent and updated my Paint .NET animation plugin with a UI redesign and another option for outputting an animation strip. I haven’t officially released the changes yet.paintNet-anim-helper-updates

Things I still need to get done:

  • Redo any sound effects I don’t like, make new ones for some stuff that doesn’t have a sound
  • Do something with the current little musical pieces. Throw them out, redo them, or something. I’m not quite sure what to do about this one yet.
  • I think I want to implement some sort of scoring system that gives you points for bugs killed and some sort of bonus multiplier for each piece of food you get into a basket before the level is completed.
  • I’ve been thinking about letting the player poison food so that when bugs (except for roaches) try to pick it up, they get poisoned and die. This should impose some sort of tradeoff for the player i.e. the player looses a bonus multiplier or pays some points to do this because he is essentially ruining a piece of the food he is trying to protect
  • Make the player’s health persist between levels
  • Add something to let the player heal
  • I think I would like a high score list. I though about using Google’s Play Games Plugin for Unity but it doesn’t work for PC/Mac/Linux. I want to have something like dreamlo’s free leaderboard but running on my own server. I wonder if I have time to implement it…

 

If you’ve been around game development for any length of time, you have probably heard of the Tiled Map Editor.  It is a great open-source editor that supports orthogonal, isometric, and hexagonal maps. I’ve been eyeing it for a while and considered using it for HackBotZ but ended up settling on Ogmo Editor instead. That was a while back, and since then I’ve moved to Unity3d which does not natively support loading Tiled maps. I looked around a bit and found a lovely Tiled2Unity framework but it does not support loading Tiled maps at run-time. Instead, you import your Tiled maps into the editor and it makes prefabs of them. I however want the ability to simply open up a map in Tiled, change it, run the game and have the changes just show up. With that in mind, I began the process of coming up with some code that would parse a native Tiled .tmx format into some data structures I could work with.  The .tmx format is really just an xml file with specific elements to describe map configurations, so I started on Saturday to write some simple C# to parse it. I had things going pretty well until I hit the data section of the layer element that describes exactly which tiles go where. There are several tile layer formats supported for this data : base-64 uncompressed, base-64 zlib compressed, base-64 gzip compressed, CSV, and XML.  I took one of the example maps that comes with Tiled and changed the format to CSV, then XML, then the compressed formats.  The difference in file size, as you might imagine, is significant. CSV and XML formatting make the files much too large for my purposes.   I could have compressed the whole file, but that would not allow me to edit it in Tiled without decompressing it, so I set about looking into the two base-64 encoded compressed formats.  Unfortunately, my cross-platform solution for compression in Unity3d, 7-zip’s LZMA SDK, does not support either gzip or zlib compression.  I didn’t want to write compression/decompression code (although it would have been fun), so on Sunday night, I set about looking around for some C# implementations of either gzip or zlib. I found a few but ended up settling, at least for now, on ZLIB .NET which has a BSD license. When compiled, you end up with a 64kB dll that will compress/decompress zlib data. I will probably go back later and setup my 7zip helper shim to work with either library but for now it all works rather nicely. By Monday afternoon I had a solution that would pull in a .tmx file, parse it, and instantiate tiles in the correct locations in Unity3d.

tiled
Level 1 of Buggers recreated in the Tiled map editor
unity3d
Level 1 of Buggers loaded from the level1.tmx Tiled file

 

The next thing to do is refactor the game code for buggers to utilize a single unity3d scene instead of loading a scene for each level, and that along with modifications/fixes to my Tiled loader is what I will be working on today.