Where should I start? Hmm, oh yeah – maybe with the fact that my game Why Am I Dead At Sea is basically done.
It’s kinda insane. I almost don’t believe it. After working on it for so long, and continuously pushing the finish line further and further back, you kind of forget that finishing is even possible. I’ve gotten so used to adding things to Why Am I Dead At Sea, that the thought of not adding another thing to it just seems crazy. There’s something I’m missing, right?
Well…Not really. All the alternate endings are finished. The epilogues too. The dialogue in the game has been rewritten three times over. I must’ve redone the menus half a dozen times. There’s even controller support!
This realization comes with two feelings – relief, but also anxiety. When I admit that the game is finished, I start to panic because a part of me still wants it to be better. Surely there’s other things I can do to improve it even more, just that little bit extra that will put it over the top, right? Imagine how much better the game could be, if I’d only add ______ .
The bottom line is, I will be moving forward with distribution/marketing on the basis that the game is in fact complete. Yeah, at the same time I will also be making small tweaks here and there, if only to satiate a compulsion to tweak. But don’t worry, I can stop whenever I want to.
I’ve gotten all incorporated and everything, and now I can work on putting my game on Steam! Well, technically it’s already on Steam, but there several extra things I need to do. Namely, I want to implement Steam cloud saves, achievements, and trading cards, and make sure everything is working smoothly with both Windows and Mac downloads. It’s a bit hard to say how long this will take, but progress has been very smooth so far.
Speaking of all that, this post is doubling as a bit of a recruiting call. You see, I want a final wave of testing with a larger group before the game goes public, and I also need to test and make sure the game is actually working with all these Steam features. That means I need some new testers!
If you want to get the game a bit earlier than everyone else, you want to get it for free, but most importantly if you want to help a solo developer in their hour of need, please email me at “email@example.com”. Things to include in your email (for fun, but also so I know you’re serious about testing):
1 ) The operating system you run / will play the game on
2 ) Where you originally heard about Why Am I Dead At Sea
3 ) If you played the original Why Am I Dead – who do you think was the serial killer?
The last time I made a call for volunteer testers I was really impressed by how many people responded, and how dedicated many of them have been. If you volunteered before and I didn’t get back to you, I apologize – but also know that this test phase will require much more people, so feel free to volunteer again!
Thanks in advance to any volunteers! Next blog update I may be releaseing a date of some import.
When people hear what Why Am I Dead At Sea is about and how you play it, they generally have a similar reaction: that’s like Ghost Trick! Or some people will less frequently say, oh, it’s similar to Murdered!
Looking at those games, the parallels are obvious. The funny thing is, I wasn’t even aware of Ghost Trick when I started on the original Why Am I Dead in 2012. And Murdered came out two whole years after Why Am I Dead, so that clearly wasn’t an influence. In truth, the real sources of inspiration that led me to make this game came from entirely different places.
What are those places? Well no one really asked, but I’m about to tell you anyway, so get ready!
About two-ish years ago I wanted to practice programming in Flash and put something small online, so I was thinking up a little project to motivate myself. The idea was to make something in a week that would teach me the basics. Something really simple, but still interesting and unique.
So you know what I looked at for inspiration? Other simple, interesting and unique free flash games! These were the games that taught me you can create a truly memorable experience with hardly any visuals or assets – that you can leave an impression on people even if the playtime for your game is as short as 5-10 minutes. And there are a couple such games in particular that gave me the little idea that led to today.
I Wish I Were The Moon
This is a small experimental game made by Daniel Benmergui in 2010, more well known for his games Today I Die and his upcoming Storyteller. In it, you have a camera of sorts that allows you to take snapshots of certain objects in the game and move them around. Depending on what you move and where, you can change the little story the game has.
So in this case, there’s a girl on a boat looking up at a boy on a moon. The girl likes the boy; the boy likes the moon. This strange love triangle can be played out in all sorts of ways, and the game will respond to pretty much all interactions you give it. For example, you can immediately dump both the girl and the boy in the ocean. You monster. Or you can swap their places, so the boy is on the boat and the girl is on the moon, so she is now also the object of his affection! Yay! (don’t think about it too hard)
If you’re quick, it takes maybe five minutes to discover all the possible permutations in the game. So why am I still talking about it four years after it was made? Because it was a completely different system than anything I had ever seen before. I was able to manipulate pieces in the story and directly change it in a way no other game let me, and as short-lived as that experience was, it was very impressionable.
Another experimental flash game made by Increpare and Terry Cavanagh, the latter of which is well known for VVVVVV and Super Hexagon. You control a small girl who, well…I’ll link to the actual game before I really get into it.
You can play it here, but be warned that it contains adult language and themes and is very very dark.
Simply put, you control a small girl who is charged with the task of putting the minds (souls?) of her mother, father, doll, and dog back into their respective bodies. The game doesn’t really make it clear which is which, and you have to figure things out by trial and error. The cool thing is that the game has an outcome for every permutation – put the mind of the dog into your father’s body, and one thing will happen. Put the doll’s mind into your father’s body, something else will happen.
Similar to I Wish I Were the Moon, this game allows you to manipulate things in the game in a strange new way. In the former, you could actually move them around – in the latter, it’s much more abstract. And both games allow for experimentation – you are encouraged to move things around in certain ways just to see what the result will be, even if it isn’t the “correct” interaction.
The defining thing in these cases is that you feel like you are creating meaning in the game. You aren’t simply picking up and moving blocks – you are manipulating actors in a story, and creating what feel like emergent scenarios.
So I thought, giving the player the ability to manipulate story objects was cool…what if I allowed the player to do so by directly assuming control of things in the game? Like in I Wish I Were the Moon, you could move them around to do different stuff. And like in Oiche Mhaith, different combinations of characters could lead to different results.
Except in this case, it wouldn’t be a combination of mind/body pairs – it would be a combination between the character the player is currently controlling, and the character they choose to interact with.
This was the core that I started with, and at this point there was still no ghost stuff going on. Instead, I was thinking of just arbitrarily giving the player this power to control people, without having a narrative explanation for it. I also wasn’t entirely sure that you would interact with people by really talking to them – the interactions might be more abstract or exaggerated than that.
I believe it was my sister who came up with the narrative idea first. I had voiced an incredibly vague and ethereal concept to her, and she thought it would make sense if the player was a ghost. And since they have to solve some sort of puzzle, they could be a ghost detective, charged with solving a mystery. I then made what now seems a somewhat inevitable last step – how about you’re a ghost solving the mystery of your death?
I’ve been trying to put together a post focusing on the time where I was less active on the blog/online, and as a bit of an overview for the past year…but writing it out in a way that fits the nature of this blog has been difficult. It’s a lot of material, so it’s a bit hard to decide how to organize it, and it’s a bit of a departure from game development. Meanwhile, the days keep ticking away, so I thought I’d give an update on the game just to get a post out.
I’ve been more active than ever in development, and things are moving along quite well. After taking a lot of time over the past several months to update visuals, add support for game options/configurations, and work on Rebirth, I’ve returned to filling out the game’s story. Over the past month I’ve added in all of the art, dialogue, and scripting for the game’s story, all the way up to the ending.
The ending is done?!
Well. One of them. As I’ve opted to have multiple endings for Why Am I Dead At Sea, I’ll have to finish the “ending” to the game several times before I can say that it’s actually been completed. However, what I have finished is the basic framework that the separate endings switch off from, which means that the remaining work is a bit simpler than what I’ve already done.
Given that all of this progress takes place at the game’s finale, it’s hard to show things I’ve worked on without immediately and blatantly giving away important details about the ending. Like its original, there are some revelations and plot twists at the final hour – and they can vary, depending on the ending you get.
But I can speak in generalities and talk about the structure of the endings without giving away details.
I can be a very compulsive person. As a result, I am all too familiar with player paranoia: when a player feels anxious about if they’re missing some content. If you’re walking through a maze and find the exit, only to turn around and check every last dead end so you know you didn’t miss anything – that’s player paranoia. When a game overwhelms the player with choices and gives them a clear right/wrong answer, it can be an unpleasant amount of pressure. I recall playing the acclaimed Metroid Prime for the first time. I was having a lot of fun with the game, until I learned from somewhere that there were multiple endings, and that they were determined in large by the amount of hidden upgrades you collected throughout the game.
…I never played it again. That knowledge turned the game, for me, from fun exploration into obsessive item-hunting. It’s exactly the kind of system I don’t want in my game – I don’t want to burden the player with the worry that they made the wrong choice or missed things early on and unwittingly doomed themselves.
Admittedly, there is a lot of story-telling potential to having the game remember the things that you do. And I plan for that to be an element in the game. However, the factors that influence the game’s ending will follow this pattern:
1) The more drastic a factor changes the story, the later in the story it occurs
2) Conversely, the earlier a factor occurs in the story, the less significant it is to the overall direction of the story
What this means is, essentially, there will be two types of variables that change the ending/epilogue that you see. Conversations that occurred in the early/middle parts of the game could change additional, flavor dialogue at the end. It would give a nod to some of the choices you made earlier on, but does not itself decide the direction of the story or the resolution of the mystery. On the other hand, there are larger revelations and clues you can find, which will be available all the way up to the end of the game, which will decide the ending you get.
To reference what has to be probably my (and many other peoples’) favorite alternate ending design to date, the Suicide Mission in Mass Effect 2 has lots of smaller factors that decide who amongst your crew lives or dies – but ultimately, that isn’t what decides the climax of the story. At the end, there is still a big choice you can make at the end regardless of what you’ve done beforehand, which means you don’t feel shoehorned. It’s a good blend between acknowledging the player’s previous choices and allowing them to make new ones, and the ending of Why Am I DeadAt Sea attempts to achieve that effect.
If you’ve been following this blog for a while (specifically a year), you may remember when I set a goal for myself to submit my game to Indiecade. Well, you see, though I may have implied that I was aiming for Indiecade 2013, I was actually planning on submitting to Indiecade 2014 the entire time! That is to say, in roughly the next week I’ll be submitting my game to Indiecade, right on time, just as planned.
Hmm. Yes. That’s what we’re going with.
It’s pretty exciting to send the game off for the first time to a real critical “audience” (if only of one or several people) – and it’s exciting that I feel the game is at a point where it’s really presentable and can speak for itself. Though aesthetics may or may not be critical for game competitions of this sort, I definitely took a lot of time recently implementing changes to the game’s visuals that I had been aching to for a while.
Let’s take a look, shall we? (NOTE: Below are some GIFs which wordpress resizes, and it kinda messes with the image. To see them in their proper resolution, simply click on them.)
Once upon a time, Why Am I Dead At Sea had no shadows. It existed in a world with purely ambient lighting; light was everywhere. It came from nothing and went nowhere, and therefore, no shadows! Someone pointed out to me that shadows were a relatively easy change that could make everything seem more grounded. It was obviously good advice, but at the time I wasn’t willing to go through every prop when I had a million other objectives, so I took a half-measure and added shadows to all of the characters.
Well now, all people and objects have shadows! And as expected, it didn’t take a huge amount of work, and definitely makes the game look better. Everything is less floaty and it’s much clearer where they’re positioned on the ground. It also just kind of breaks up the flat colors of the floors and adds some much needed detail.
2. Additional Backgrounds
As the content for the game continued to be made, there were points in the story where it is made clear that time is progressing, either from one day to the other or from morning to night – and yet when you go onto the ship’s outside deck, it was always the same time of day – sunset! That’s obviously because it was the only background I had made at that point. For some points in the game, though, it seemed really important that I get the alternate backgrounds which show different times up and running.
They help set the mood for the story in a big way, so once I got to a certain point it became a really high priority. But, that’s not all I did with regard to the outside-the-ship area!
3. Parallax Scrolling
If you’re not familiar with parallax scrolling, well, parallax is the effect of objects farther away not moving as much to us, thereby creating our perception of depth. Parallax scrolling is the simulation of parallax in media whereby different objects scroll at different speeds to signify depth.
After creating my lovely backgrounds for the outer deck, I brutally chopped them up and put them in separate images. I then created a special kind of Prop (ParallaxProp) that contains a set of images and has them scroll along with the game camera at different speeds. It was actually really simple to implement on the code-side; it probably took more time overall just cutting up the backgrounds and making sure the end visual result was what I was looking for.
Because the area is so relatively wide, if the scrolling is too extreme things don’t really match up or work out how I want them to. So, the scrolling difference is intentionally small, creating a subtle but still noticeable effect.
This was one of those features where it was “really cool if I could implement this, but I don’t know…” So, it feels really nice that I actually did end up getting it done! And it really didn’t take me a huge amount of time.
3. Water Animation
I always knew that the boat’s lower outline and the ocean were going to need some kind of…change. A pure and unchanging blue rectangle didn’t quite cut it. What I have now is still imperfect in several ways, but at least communicates what is actually happening and isn’t as blindingly static.
Figuring out how I wanted to do this and implementing it were surprisingly tricky. For one thing, the water was originally a part of the map itself and I’d never made an animated object as large as this before, so there were a lot of possible ways I could implement the small waves in the water. I could animate them tile by tile, in which case it might make more sense to make it an extension of the map itself, or I could make one huge animated object, in which case I would probably make it a prop. The latter would most likely put much less strain on processing time, but would result in a really unwieldy and humongous bitmap. I ended up taking the middle-ground and made some 7-8 animated props, each of which was a small but wide “strip” of the full thing. The image files are small and simple, and there still isn’t a lot of labor that the game has to do to animate them.
I also had to decide how I could get animated water to agree with depth, since the part of the background above the horizon has objects (ie the sun and moon) that are far in the distance, while the animated water is completely flat. Most ways of trying to actually get the water animation to obey depth seemed either ugly or way too hard, so I compromised again and simply had the opacity of the waves fade as they get closer to the horizon. This was only possible because of the approach I took in cutting up the animation into small little strips, so it’s nice how the two issues fit together!
Actually this is not all of the visual changes I made, but they’re probably the most apparent ones, and they’re the ones I’m proudest of. None of the changes I have made are huge, as I’m not looking to give the game a full make-over, of course…but they add up to a much prettier game nonetheless. While there are still some things I really want to fix or renovate, the game is actually really close to how I expect it will look as a final product.
Now then…fingers crossed on the whole Indie-Cade business!
When it comes to programming Why Am I Dead At Sea, there is one feature that sticks out above all the others in terms of time investment and difficulty. It has ruined many a day with debugging. It has at times leeched me of all enthusiasm to get work done. It haunts my very dreams (well okay, maybe it’s not that bad).
It is, of course, AI.
It’s not that I regret including it – I still think it’s almost a necessity for the game, and despite how much time it has wasted I’m sure it’s been a worthwhile investment. However, I can confidently say that I would have designed other things in the game differently if I had been able to predict how much they would complicate the AI.
But those concerns are buried deep in the game’s systems. Let’s start with a bird’s eye view of the game’s AI, and work our way down.
As you might imagine, one object being inside another symbolizes encapsulation – that is, they are literally an instance of that class contained within the other class. The lines next to Behavior symbolize the classes that inherit from it (Behavior being an abstract class).
Not surprisingly, the Character class is at the top – it is one of the game’s linchpin classes. It contains a CharacterAI class, which contains and handles everything pertaining to that given character’s AI. In turn, CharacterAI contains a Behavior object and a CharacterCommand object. The former deals with the higher level concerns of getting the character to move around – this generally means interpreting and/or setting waypoints, and then using those to create CharacterCommands. The latter goes deeper into exactly how to get the character to move – it takes in waypoints and generates a path with the Pathfinder class, then interprets that information to figure out when the character should move, and in which direction.
To hit everything I’d like to talk about will take a lot of time and space, so I’ve decided to split this subject into multiple blog posts, possibly as many as three. We’ll begin with an overview of the CharacterBehavior class and its children.
With the main aim of creating human-ish walk patterns, I have three overall behaviors that are used in the game, ranging from simpler to more complex.
Quite simply, under this behavior the character moves from tile to tile completely randomly. Aside from allowing the option to set boundaries that will stop the character from wandering too far, there isn’t any other higher level of thought outside of the path-finding.
Probably 90% of the RPGs that I’ve seen or played , especially of the 2D variety, seemed to exclusively have randomly meandering NPCs. It’s simple, but effective in breathing a bit of life into the background.
Sometimes I want the character to have a bit more direction, but I still don’t need a particularly detailed behavior; in this case, there is the pacing behavior, which creates paths based on whether to go horizontal or vertical, and how far in each direction. It is also good at demonstrating when a character is brooding, thinking or panicking, based on frequency and distance.
It might be worth noting that the behavior simply thinks of reaching the end-points in the pacing path, rather than explicitly in walking in a straight line. This means that if there is a pacing behavior in a room with obstacles in the way, the character will still move around them rather than exclusively walk in a straight line.
And lastly is the most versatile and communicative behavior, which is used (as the name implies) for when a character has a routine of some sort. The behavior takes in an arbitrary number of way-points and information about them, and the character is then made to move through them in a certain order.
This has been the most commonly used mode since it can get a lot of meanings across. On the smaller side, it could simply be getting across the idea of a single action: for instance, the cook has a routine where he walks from one kitchen appliance to the other. On the larger side, it could mean a daily routine that takes quite a long time to complete: for instance, the first mate has a large circuit across most of the ship in which you can see him checking up on everyone.
All of these behaviors are created before the game actually runs, and are stored in a separate place called the BehaviorLibrary. This is generally done simply with Tiled; I put an AI object right on the map where I want the waypoint to be, then give it properties. When the game loads the map file it also parses these AI waypoints and creates Behavior instances based on them.
When they are required in game, the CharacterAI sets its current behavior to one of them. Every tick in the game, CharacterAI queries Behavior to see if the character needs to go somewhere new – if it does, a new CharacterCommand is created with information about the new destination.
There isn’t a huge amount of gritty detail in this post, since the Behavior classes themselves don’t care too much about the details. When we get into CharacterCommand and Pathfinder, that will be different!
I had originally planned on opening up my series of more informative posts with a big post on AI, but since I’ve been mostly doing dialogue and cinematic writing, I’ve been inspired to make a post about the game’s overall structure instead.
Let’s start by describing the game in the simplest and most basic way possible. The gameplay involves me throwing a huge amount of writing and text at the player, and having them search for the important bits of information in there. Unlike other adventure/mystery games, there aren’t many puzzles or problems that if you can’t solve, you’re stuck. In WAID you always had access to everything you need. If you felt up to it, you could always brute-force through the challenges of the game by triggering every single dialogue and dialogue branch.
The challenge is to find the hints I’ve scattered in order to figure out which character interactions will get you on the right track. Of course, the non-vital dialogues are both an obstacle in that they obscure what you need, as well as a bonus in that they can flesh out the story and give further insight to the characters.
Let’s take a look at the structure of the previous “Why Am I Dead”. There is a wide body of what I refer to as ambient dialogue: the sum of dialogue which obscures the way forward. There are also smaller pieces of story dialogue which are actually needed to trigger the ending of the game. The way the game was structured, it could take you hours to finish it, or two minutes.
How does this structure look for a longer game, though? I would certainly like “Why Am I Dead At Sea” to last longer than that, whether “that” is two minutes or two hours. So how do we make that happen?
There were two challenges that I saw going into this project. Firstly, it seemed to me that a longer/larger game would run into the problem of overwhelming the player with far too much ambient dialogue far too quickly. As it was, the original WAID wasn’t extremely navigable and could bring the player down time-consuming dead-ends. Some people enjoyed this, but some did not!
And secondly, for a larger story I would want time to pass as the plot moves forward – that is, things would have to be a bit more sequential in order to make sure there was some plot. In the previous WAID nothing happens without player input except at the beginning and end, which was fine…but in this game that severely limits the kind of story I can tell!
So I decided I wanted to taper the beginning of the game, bringing the player into the ambient dialogue slowly. I also wanted to cut up certain parts of the game into self-contained ‘chapters’, in which there was only one entrance and one exit, so that some modicum of stage-setting could be done. The resulting structure for Why Am I Dead At Sea looks like this:
This is accomplished, admittedly with some awkwardness, by restraining who you can possess and where you can go at the beginning of the game. For the first two major parts of the game there is a substantial amount of optional dialogue accessible, but not so much that the player is drowning in it. Objectives are hopefully much more clear. As each new character becomes available to possess, however, the amount of ambient dialogue also increases.
This also allows for that oldest of design tropes seen so often in LoZ dungeons – if there’s a new character you just unlocked, you can be confident you will have to use them pretty soon. I wasn’t allowed to guide the player in this way before!
And just as importantly, having certain choke-points for the story allows me to do things such as have small periods of time pass, or move characters move around, and so on. This isn’t trivial. A weird thing about the last game was that, to preserve an interesting pace, characters had to spill their guts to each other very quickly, without knowing anything about each other! It was possible to suspend disbelief, but definitely felt off. This time around I want dialogue to feel more organic, which means at least the illusion of some time passing.
So that is, in a nutshell, the layout of the game.
Except, extremely not right on time. Although game development is always subject to delay (especially by indies), I think this large a time gap between when I said I was “just around the corner” for a demo, and today, still warrants some explanation.
A great deal of it is simply perfectionism – the constant feeling that the game isn’t ready for minor reasons that would certainly not disqualify it from play testing. This is aided by the fact that while I think of my goals in a linear way, I am often not able to accomplish them in that way. After working on a certain aspect of the game for so long, I begin to shut down and have to work on something else to maintain my sanity. Generally I’ll make a check-list with my main objectives at the top, but with lots of smaller issues that I’d like to get done at some point on the bottom. When I need a break, I tackle the smaller goals in whatever order I feel like. So while a main development goal may not appear so far away, this is a bit deceptive.
I also can’t ignore that my transition to China and my new job has slowed me down. Even though in the long run I think it will help my discipline and motivation to see the game through, it has in the short term taken a lot of my time and energy to get used to!
Back to matters at hand, I will now be taking applications for beta testers. For the first time, (some) people will be able to play Why Am I Dead At Sea, and I’ll be able to receive vital feedback whilst developing. If you would like to help me and receive early access to the game, please fill out the following (short!) application and email it to firstname.lastname@example.org : Beta tester application
Of course, I know that as a tester you are providing me a valuable service, for free! Although hopefully early access to the game is some recompense in itself, beta testers will also have the following incentives:
– Free copy of the game when it is released, along with whatever key codes are relevant, based on how it is distributed (this is an obvious one)
– Recognition: All testers who contribute will be shown in the credits (also pretty obvious). Those who contribute substantially more will get extra recognition.
– I would also like to have monthly best-bug-find competitions, the payoff for which could possibly involve leveraging my art assets/scripting to give the tester a little memento in the form of a screenshot/GIF made with the game engine (the contents of which being up to the tester).
At the moment, the version that testers can play will take them through the game’s introduction and first chapter (of which there will be five). It isn’t a huge amount of content to explore as of yet and mainly serves to introduce the player to the story and the patterns/concepts of the game, but is almost entirely content complete! And of course, later chapters will follow.
At this point, development will overwhelmingly mean writing dialogue and cinematics, as well as responding to bugs and player feedback. As a result, updates will probably be sparse in new shiny art or features. So, I’ll be taking the time to go into greater detail at some features I’ve brought up before, how they are implemented, et cetera.
There’s been a grab bag of progress since the last update.
1. Character AI / Behavior
Perhaps the most substantial accomplishment has been what I can only hope is the final slaying of multiple bugs in character AI and behavior — getting characters to move around the ship on their own, handle transitions between areas elegantly, and react to obstacles (including the player). I definitely anticipated that this feature would cause me some trouble, but I have to say that this has been extraordinarily tedious to implement. It has become something I dread working on by this point and definitely sucks on my energy to work on the project.
And I’m sure there are still several bugs that will only show themselves after play-testing. Hooray!
One feature that I lump into “character AI” is something I haven’t shown yet: the ability to have characters follow you around, caterpillar-style! This will be used at a couple points in the game when the plot demands it.
Getting the follower to work correctly was quite tricky. The normal pathfinding for characters moving on their own was too clunky and not responsive enough to follow the player around closely. So, I had to write a simpler sort of AI that beelines towards the point the player was in about 30 frames ago. However, this can be exploited by the player as well to get the follower stuck on obstacles, in which case the follower will walk in place for eternity.
Each approach had its faults, so I created a hybrid of these two behaviors. The follower now uses the simpler behavior until it finds itself stuck on an obstacle, at which point it shifts to the more complicated path-finding behavior in order to get around the obstacle. As soon as it reaches the player, it then shifts back to the simpler behavior. You can see this in action in the GIF when I get the follower stuck on a wall-corner, and she moves around it after about a half-second pause.
At some point I think I’d like to make a huge post about all of the small idiosyncrasies, bugs, hangups and annoyances of character behavior. It would be cathartic.
2. 100% More Kitty!
I don’t think I’ve mentioned this on my blog yet. There is in fact another possessable character, up until now never spoken of! Who could it be!?
Yes, you get to possess a cat. It may not be the most useful for getting other characters to open up about their dark and troubled histories, given that it can only say “meow” or “hiss”. But, it makes up for that by being the most agile and lithe of your potential hosts. Observe:
The cat has the ability to jump, a feat that no human in the game seems capable of (or at least interested in). And combined with its small size, this allows the cat to go through crawl spaces and open up new areas that you couldn’t access with your human hosts.
3. The Introduction
One of the final things standing in my way for a complete demo is a proper introduction that pushes the game off. This was something I could have pushed back; I could have released a demo without it. However, I’ve heard that feedback is a bit of a finite resource, and I’d really like my first ‘wave’ of feedback to include the introduction to the game.
In the previous “Why Am I Dead”, you are simply thrown into the game. Instructions are given as black text on the ground, and you are given a short conversation that explains the premise of the game. This time around, the introduction will still be short and sweet, but much more involved. This is partially because of a difference in premise — the last time around, you start hovering over your fresh corpse. Combined with the title, it really spoke for itself. In this game, things aren’t quite as simple, and it really warrants the extra effort to explain things.
This meant creating original art for the introduction and scripting things to get the timing just right. It’s been pretty easy to implement, but surprisingly time-consuming.
I know I’ve taken way longer to get to a closed demo than I had predicted, but I really am getting close now. I promise! For real this time!
Hello from Xi’an, China! Things have been a bit hectic; I’m just getting over jet-lag now, and I start teaching English classes tomorrow.
Lots of new stuff to adjust to. New country, new apartment, new school, new students (lots of them). It might be a while before I get comfortable with all of it! So, what better a time than now to make clear my goal to submit Why Am I Dead At Sea to IGF 2014?
The deadline is October 19, which gives me about a month and a half to get my current build to competition-readiness. That really isn’t much time at all! But more importantly, this gives me a solid deadline and a great reason to get back into full-time development. To be honest, even though I completely failed to reach my goal of submitting to Indiecade, that was by far the most productive time for me. I never really was able to match that pace afterwards. And now that I’m in China and teaching English and all that crazy and awesome stuff, it’s more important than ever that I have a clear goal that I’m working towards. It would be very easy to lose sight of development in the midst of everything else, and I am determined not to let that happen!
Most of the work left is writing and polishing. Prioritization is going to be key here — there are lots of side-features that I’d like to implement but which are by all means optional. If I want to even have a chance at submitting my game I’ll have to be much better at leaving that stuff to finish later.