{"id":33343,"date":"2016-07-19T06:00:43","date_gmt":"2016-07-19T10:00:43","guid":{"rendered":"http:\/\/www.shamusyoung.com\/twentysidedtale\/?p=33343"},"modified":"2016-07-19T05:18:51","modified_gmt":"2016-07-19T09:18:51","slug":"good-robot-postmortem-2-gameplay","status":"publish","type":"post","link":"https:\/\/www.shamusyoung.com\/twentysidedtale\/?p=33343","title":{"rendered":"Good Robot Postmortem #2: Gameplay"},"content":{"rendered":"<p>My original design for the game was &#8220;2D Descent&#8221;. That was the core inspiration for the project: Bright colors, electronic music, shooting lasers at crazy robots in caves. But <a href=\"?p=21973\">this design wasn&#8217;t working<\/a>. I didn&#8217;t know how to fix it and I was worried I was too close to the project to be able to analyze the thing objectively. <\/p>\n<p>Lots of people offered advice. I had a dozen different, completely contradictory suggestions on how the game might be fixed. Everyone was happy to tell me how to fix the game by making a completely different game, but if I couldn&#8217;t realize my own vision then I probably wasn&#8217;t qualified to build theirs either. My original vision didn&#8217;t work out, and I didn&#8217;t know where to go next. <\/p>\n<p>One of the key problems was that I&#8217;d never really worked out a proper fail state for the game. I had the moment-to-moment stuff down, but the win \/ lose states were undefined. If you died you&#8217;d just respawn, BioShock-style. It&#8217;s not that I thought having a game with no lose state was a good idea, it&#8217;s that I&#8217;d just never settled on a particular system. <\/p>\n<p>How should death work? Maybe like Borderlands, where you&#8217;re taxed 10% of your money \/ XP when you respawn? Maybe like Dark Souls, where you drop all of your money \/ XP when you die, but can recover it? Maybe like Pac-Man, where you have a fixed number of deaths before a game over? Maybe like a modern game, where death reloads the last checkpoint? I fiddled with all of these and a few other ideas, but none of them really jumped out as the &#8220;correct&#8221; solution. <\/p>\n<p>I guess early in the project I sort of assumed the answers to these sorts of questions would become obvious as the game took shape. I expected mechanics to &#8220;click&#8221; into place, but that never happened. I had a dozen different directions the game could go in and I didn&#8217;t have a good sense of which way was best. I was paralyzed by choice. I realized I could spend the rest of my life prototyping stuff without ever moving any closer to my goal.<\/p>\n<p>And so the project stalled.<\/p>\n<p><!--more--><br \/>\n<div class='imagefull'><img src='https:\/\/www.shamusyoung.com\/twentysidedtale\/images\/Good-Robot-Weapon-7.gif' width=100% alt='Man, that recoil.' title='Man, that recoil.'\/><\/div><div class='mouseover-alt'>Man, that recoil.<\/div><\/p>\n<p>Then later when I teamed up with <a href=\"http:\/\/pyrodactyl.com\/\">Pyrodactyl<\/a>, we returned to the question of &#8220;What does this game need to be fun?&#8221; As we began working together the game began moving in a very &#8220;roguelike&#8221; direction. <\/p>\n<p>Lots of people have said, &#8220;I&#8217;m surprised you made a game with feature X, Shamus, since you&#8217;ve spoken out against it in the past.&#8221; But I hope it&#8217;s clear at this point that I wasn&#8217;t the only person who contributed to the final product. My original idea had failed to produce a viable game. Sure, I could have put my foot down and refused to let the team implement features that fell outside of my personal preferences. Here is how that conversation would go:<\/p>\n<p><tt>Shamus: No! We can't have escalating difficulty mixed with permadeath in my game!<\/p>\n<p>Everyone else: Okay. So what's your suggestion?<\/p>\n<p>Shamus I literally don't have one. That's why I joined up with you guys.<\/p>\n<p>Everyone else: So what are we supposed to do?<\/p>\n<p>Shamus: I don't know what I want but I'll know it when you suggest it. Just keep suggesting ideas for me to shoot down.<\/tt><\/p>\n<p>I&#8217;ve worked with people who behaved this way. It was not fun. More importantly, they didn&#8217;t tend to carry projects to victory. Part of being on a team is trusting that the other people know what they&#8217;re doing. Whatever faults people may find with our final design (lots of people have offered insightful critiques in the comments) it&#8217;s still better than the dead-end shooting gallery I&#8217;d put together on my own.<\/p>\n<p>I&#8217;ll let Ross talk about how the gameplay took shape&#8230;<\/p>\n<h3>Rhythm<\/h3>\n<p><div class='imagefull'><img src='https:\/\/www.shamusyoung.com\/twentysidedtale\/images\/GoodRobot_GIF3.gif' width=100% alt='Note the lack of quicktime events. That was a deliberate design choice!' title='Note the lack of quicktime events. That was a deliberate design choice!'\/><\/div><div class='mouseover-alt'>Note the lack of quicktime events. That was a deliberate design choice!<\/div><\/p>\n<div style=\"color:#306\">\n<a href=\"http:\/\/www.seventh-house.org\/\"><img decoding=\"async\" src=\"images\/profile_ross.jpg\" align=\"left\" title=\"Ross\" alt=\"Ross\"\/><\/a><\/p>\n<p>Coming into Good Robot as a game with its core systems basically completed was an interesting experience. After Unrest and Will Fight For Food it would be the third time starting my job on a game part-way through development, but among them only Good Robot had so much of the base game complete before I got my hands on it. This wasn&#39;t so much a project to finish putting together a video game as one to <em>take a game apart and reassemble it<\/em>, adding on as few new pieces as possible.<\/p>\n<p>Firstly, as might surprise you, I played the game. I played the game <em>a lot<\/em>. Simple enough, but often underestimated &#8211; especially by me, and doubly so in the midst of development. My first thought, after noting and instantly enjoying the thumping, booping soundtrack, was that this game was solid. Levels generated in a reasonably diverse ribbon shape (as Arvind already elaborated on); bullets had punch to them and shooting felt good; power-ups were easily understood; the robot&#39;s movement and aiming were precise and challenging enough to feel rewarding. Picking up the Good Robot for the first time was a breeze and a joy. The only immediate lack I felt was variety, with only a single weapon to my name.<\/p>\n<p>Variety is hard to call an easy fix, since the result is cracking down and creating <em>more types of things<\/em>, but it&#39;s certainly a simple one. More weapons! More robots! More levels! It sounds like a mistake in the making, but this wasn&#39;t actually wrong &#8211; more weapons made more styles of gameplay and gave us another variable to randomize, more enemies extended the shelf life of our shooting mechanics even further, and more levels made good on that promise. Sometimes bigger really is better. <\/p>\n<p>But in spite of all this, a sort of listlessness still hovered over the game after a short bit of play. Even though we had more options than ever, the drive to use or discover them was slipping away once the player was familiar with the game&#39;s fundamentals.<\/p>\n<p>So where was the interesting-ness going?<\/p>\n<p>Rhythm. It&#39;s not a perfect analogy, but it&#39;s close. Every game has a series of core decisions that form a loop which makes up the moment-to-moment play. <strong>Survey the environment, see a demon, dodge its fireball, shoot, collect a powerup, repeat<\/strong>. <strong>Head towards un-eaten dots, reach branching path, evaluate threat of ghosts vs. potential score, repeat<\/strong>. Depending on the game, these loops can be long or short. Most have several types of loop strung together, or a core loop with wildly divergent branches. Put all of them together and you have a series of repeating actions forming a larger whole &#8211; a rhythm. This is where our problems stemmed from.<\/p>\n<p>If you were to somehow graph ten minutes of gameplay in terms of the number, type, and weight of decisions made within that time, the earliest build of Good Robot I played would closely resemble a straight line. You moved horizontally for five screens, shooting the level&#39;s enemy type and collecting their score nuggets; as your score increased you bought simple upgrades (damage, speed, rate of fire, shields&#8230; and &#8220;energy&#8221;, but we don&#39;t talk about energy); soon enough you dropped down and looped back the other way for another level. The line ticks up once in a great while as a boss appears, but it&#39;s not that major a change &#8211; and only a brief interlude before the player descends another shaft, reverses direction, and enters the next level. As mad as it sounds, even seamless level transitions were working against us.<\/p>\n<p>What we needed were moments of tension and uncertainty, and instances of downtime where the player could take a breather to juxtapose them with. Rather than a consistent, predictable simmer, our line needed its peaks and valleys. The same principle goes into just about every form of entertainment, from composing music to writing stories. It&#39;s amazing how far good rhythm can carry a game &#8211; I strongly suspect it&#39;s the secret sauce behind a game like Diablo II&#39;s success, and the mixed results of its imitators.<\/p>\n<p>With this as a guidepost, it&#39;s easy to explain a lot of the changes Good Robot underwent before release: more lethal combat, meaningful death states, hand-designed levels and profiles for the types of robots that could appear in them, weapons as powerups, warranties, randomly-chosen shop types with randomized contents. The goal was to make it possible for a player to fluctuate between being on the ropes and relaxing safely behind their contingency measures over the course of a game; to let them to walk into a seriously bad situation now and again, or catch a lucky break. We engineered breather periods by breaking the game into distinct levels with shops at the start and end, and built bosses and enemies which played with the player&#39;s expectations and altered their tactics.<\/p>\n<p>In so many words, we changed up the rhythm to keep it from growing stale or predictable, and this time the interesting-ness hung around for another go.<\/p>\n<h3>No Plan Survives The Meta<\/h3>\n<p><div class='imagefull'><img src='https:\/\/www.shamusyoung.com\/twentysidedtale\/images\/Good-Robot-Weapon-4.gif' width=100% alt='The part of the game with the shooting.' title='The part of the game with the shooting.'\/><\/div><div class='mouseover-alt'>The part of the game with the shooting.<\/div><\/p>\n<p>In what&#39;s certain to be the second time I lead an article with a piece of obvious-seeming insight, I offer you this: no game designer in mankind&#39;s colourful history has ever been <em>entirely correct<\/em> about how another human being will play his game. <\/p>\n<p>I stressed the importance of rigorously playing one&#39;s own game before (and chided myself for not doing it enough &#8211; bad Ross!), and this is the main reason why. No matter how far ahead you think, no matter how predictive or canny your reasoning, the meta will outwit you. It is the gestalt of a hundred thousand minds, pulling in different directions &#8211; none of them quite where you intended &#8211; and it will eat your carefully-laid strategies for breakfast.<\/p>\n<p>As it turns out, predicting humans is hard. Take a recent game of Pathfinder I ran: a five-man party was working its way through the hallowed crypt of their nation&#39;s royal mausoleum, leagues under the earth, having just pulled themselves from a tricky encounter with a legion of ghostly soldiers. They stopped to rest, and the session ended. My dark work began. <\/p>\n<p>I built a long hallway full of corners and alcoves that emptied into a dark, maze-like chamber full of standing pillars. Like any sensible person, I reasoned they would see the superfluity of hiding places and enter with extreme caution, checking every recess&#8230; but two dozen fruitless searches later, their guard would drop enough to miss a skulking assassin pressed into the shadows. To extend this time and build out my world a little more, the spirits of two small children would draw the party&#39;s attention, and make them doubt the possibility of combat so close by. One of the pair would flee into the darkness at the sight of them, naturally leading the group in that direction. A body with an important item lay squirreled away in an out-of-the-way passage far to the south &#8211; something they would be asked to come back for in a future encounter. The stage was set.<\/p>\n<p>As my group assembled for the night, I played out in my head the way this ruse would go down: after confirming nothing was hiding, the party would find the first of the two ghosts and stop to interact, leading into the second&#39;s retreat. The band would follow, passing enough of the pillars to get a sense of the place before stumbling upon the little ghost hiding behind one&#8230; and the assassin would strike from behind. This would lead them into a cautious advance, fighting through ambushes and uncovering bits and pieces of the room&#39;s story. Caution and wit would come to the fore &#8211; a stark contrast to the running bedlam of the previous combat encounter. I knew how people thought, you see, and I would use that to build for them the game of their lives.<\/p>\n<p>The fighter &#8211; a towering half-demon juggernaut with a maul &#8211; entered my first passage, took a single look at the terrain, and proceeded to roll his Perception to look for danger. He repeated this roll every ten steps. The others followed in a tight formation. Peering playfully out from behind a hanging tapestry, the spectre of a small girl beckoned the man&#39;s attention. I silently grinned. And then my plans disintegrated.<\/p>\n<p>&#8220;I ignore the ghost.&#8221;<br \/>\n&#8220;I do the same and follow him.&#8221;<br \/>\n&#8220;I talk to it.&#8221;<br \/>\n&#8220;I&#39;ll listen in.&#8221;<br \/>\n&#8220;Yeah.&#8221;<\/p>\n<p><div class='imagefull'><img src='https:\/\/www.shamusyoung.com\/twentysidedtale\/images\/Good-Robot-Weapon-6.gif' width=100% alt='Game footage unrelated to current D&D anecdote.' title='Game footage unrelated to current D&D anecdote.'\/><\/div><div class='mouseover-alt'>Game footage unrelated to current D&D anecdote.<\/div><\/p>\n<p>Three of my party remained behind &#8211; the other two barreled right into the second ghost immediately and led off in pursuit. <em>Careful<\/em> pursuit. The most deliberate pursuit Torvus had ever seen, featuring torches and night vision and dutiful Perception checks. The pair branched south a corridor later, and branched again. They missed my assassin; they missed the assassin after my assassin. Preternaturally they dodged every threat &#8211; <em>every trap<\/em> &#8211; for a solid five minutes, without realizing a thing. <\/p>\n<p>Hundreds of feet from their eagerly-chatting comrades, they found the rare thrice-nested assassin. By rolling max dice on a Perception check. Which they were still doing. They killed him in a single round, never realizing he was an assassin, then walked smack dab into the quest-hook body before knowing why they needed it. They thought this session was even more fun than the last.<\/p>\n<p>Putting aside my pedestrian GMing skills, this is something that happens to every game designer at every level, from multiplayer FPS titles to turn-based card games. You can see it every time Hearthstone prints an Alarm-O-Bot, or a tooltip in Overwatch advises you to shoot Mei&#39;s ice walls. Even in games with no multiplayer component like Good Robot, how one expects the game to be played does not resemble the way others will play it. It&#39;s only natural &#8211; we&#39;re not psychic; most of the time we&#39;re passing crafty at best. Our planning serves to improve the odds, not eliminate them.<\/p>\n<p>Valve has had this worked out for years &#8211; they know that they don&#39;t know, so they playtest rigorously and early in development, making changes to their games in progress based on the behaviour they see forming rather than anticipating the reactions of the players in their minds. It shows in their games (now of yore?), that almost every mechanic does what it&#39;s intended to&#8230; because if it ever didn&#39;t, it was probably noticed early on and altered. Even then, their games see regular balance patches and variable tweaks to adapt to the developing meta.<\/p>\n<p>Of course, not everyone can <em>be<\/em> Valve, and as my anecdote hopefully showed, not every break from the designer&#39;s intentions is a bad experience for the players. Whole new genres of game have come to be through some hapless designer&#39;s ruined plans, and others are swiftly patched without much issue. It&#39;s something that has to be considered on a case-by-case basis.<\/p>\n<p>On the subject of which: Good Robot&#39;s meta maladies were enlightening to study. As Shamus has written about before, we considered homing missiles too strong before I started to dodge them laterally rather than break their line of sight. Before release none of us put much weight on the range of weapons as a balancing factor, and after realized that firing from the safest position was literally the most important aspect of the game at high levels, especially in the environment of a no-hit run that we had just constructed. Bouncing projectiles struck me as fun and skillful when I included them on a handful of weapons; they became vital survival tools to kill enemies without danger in the eyes of the playerbase.<\/p>\n<p>Some of these revelations have led to changes in the rules &#8211; others have become canonized and remain core parts of the game. The majority of my work on Good Robot post-launch has been dedicated to exactly this: playing a strange game of chicken with the meta, a move at a time &#8211; forever trying to outwit the human race.<\/p>\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p>My original design for the game was &#8220;2D Descent&#8221;. That was the core inspiration for the project: Bright colors, electronic music, shooting lasers at crazy robots in caves. But this design wasn&#8217;t working. I didn&#8217;t know how to fix it and I was worried I was too close to the project to be able to [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[498],"tags":[],"class_list":["post-33343","post","type-post","status-publish","format-standard","hentry","category-good-robot"],"_links":{"self":[{"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/posts\/33343","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=33343"}],"version-history":[{"count":0,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/posts\/33343\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=33343"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=33343"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=33343"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}