0:00:00.240,0:00:07.040 Last time on developing, I picked my game engine [br]- Unity - and I started to learn how to use it. 0:00:07.040,0:00:13.840 But now it's time to reveal the idea for my [br]game and, well, get started with making it. 0:00:14.400,0:00:21.600 But where does one begin when developing [br]a game? And I think this is a vitally 0:00:21.600,0:00:27.600 important question because, as you are about [br]to see, if you take the wrong direction 0:00:27.600,0:00:35.637 when you start developing a game it can be [br]disastrous for the project. Let me explain. 0:00:44.800,0:00:49.840 Okay so let me start with the idea [br]for the game. I am going to make, 0:00:49.840,0:00:56.640 and brace yourself because this is crazy, a 2D, [br]side-scrolling, platform game. Yes, I know, every 0:00:56.640,0:01:02.320 indie developer starts by making a side-scrolling [br]platformer. But I think I have some good reasons. 0:01:02.320,0:01:07.360 I love the genre. Platformers are [br]relatively easy to make in the 0:01:07.360,0:01:12.640 grand scheme of things - it’s not a MMO at [br]least. And I've made loads of videos about 0:01:12.640,0:01:17.760 platformer level design and character [br]design which should prove helpful. 0:01:17.760,0:01:24.240 Now this is also going to be a, brace yourself [br]again, platformer with a unique twist. The 0:01:24.240,0:01:31.680 idea is that the character in my platformer is [br]magnetic which means they will repel away from 0:01:31.680,0:01:38.560 some platforms and attract to others. And you [br]can change your polarity with a button press. 0:01:38.560,0:01:43.200 The idea actually came from this game: The [br]Legend of Zelda: Oracle of Seasons. In this 0:01:43.200,0:01:49.040 game you have a magnetic glove power-up which [br]allows Link to repel from some surfaces and 0:01:49.040,0:01:54.400 attract towards others. You can also use it to [br]pick up large metal balls for puzzle solving 0:01:54.400,0:02:00.720 and use it to fight enemies. It's a really cool [br]mechanic but it does feel somewhat limited by 0:02:00.720,0:02:06.960 the genre, the top down camera perspective, and [br]of course the limited technology of the Game Boy. 0:02:06.960,0:02:14.240 So I thought… what if I were to borrow that [br]game idea and put it in a different genre: 0:02:14.240,0:02:20.000 a fast-paced, 2D platformer. Something [br]akin to Celeste or Super Meat Boy. A game 0:02:20.000,0:02:25.360 where you have to master the magnetism [br]for speed and fluidity and precision. 0:02:26.080,0:02:31.440 So that is the idea. And the question now [br]is: where do I begin with it? Do I just 0:02:31.440,0:02:37.840 jump into Unity and start coding? Do I jump into [br]Photoshop and start making some artwork for it? 0:02:37.840,0:02:42.880 Do I start thinking about the storyline [br]or the characters? Where do I begin? 0:02:43.600,0:02:49.360 I'm going to level with you: this is not the first [br]game I've ever tried to make. Ever since I was a 0:02:49.360,0:02:54.720 little kid I've come up with ideas for games, and [br]at various points in my life I have tried to make 0:02:54.720,0:03:02.720 those games in different tools and whatnot. But [br]I almost never finish those games and I think 0:03:02.720,0:03:10.640 the reason is the same, every single time: I [br]start in the wrong manner. Let me show you. 0:03:10.640,0:03:18.640 So I got this folder from my parents house [br]and it is full of notes and sketches and 0:03:18.640,0:03:24.000 ideas for a game I was going to make a few [br]years before I started Game Maker’s Toolkit. 0:03:24.000,0:03:28.640 That is actually just a mouse mat for [br]Starcraft Ghost. That game never came out, 0:03:28.640,0:03:32.800 did it? That might be worth [br]something actually, put that in the eBay pile. 0:03:32.800,0:03:38.560 So this game was going to be called Carter's [br]Curse. It was about famed archaeologist Howard 0:03:38.560,0:03:43.680 Carter, the dude who discovered Tutankhamen's [br]tomb. And, in my game at least, he would also 0:03:43.680,0:03:49.440 awaken an ancient Egyptian curse meaning he'd [br]have to fight zombies and mummies and ancient 0:03:49.440,0:03:57.600 Egyptian gods. I remember spending hours and hours [br]drawing all of this stuff. I mean… what a nerd! 0:03:58.480,0:04:04.480 Anyway. So how would you go about fighting these [br]enemies? The answer: playing Picross puzzles. 0:04:04.480,0:04:10.000 Picross is this logic-based, grid-based, puzzle [br]game… a bit like Sudoku. Nintendo's made loads 0:04:10.000,0:04:15.200 of Picross games. I was really inspired by games [br]like Bookworm Adventures where you have a puzzle 0:04:15.200,0:04:20.240 at the bottom of the screen, and completing the [br]puzzle does damage to enemies in a little fight 0:04:20.240,0:04:25.200 scene at the top of the screen. And so my idea was [br]kind of the same: you'd have a Picross grid at the 0:04:25.200,0:04:30.000 bottom of the screen and Howard Carter would [br]be fighting monsters at the top of the screen. 0:04:30.000,0:04:36.080 So I jumped into development. I was making the [br]game in an app for iPad called Codea which lets 0:04:36.080,0:04:42.080 you make iOS games on your iPad. I'd actually [br]previously used it for a very standard Picross 0:04:42.080,0:04:48.480 app for iOS so I knew I could probably code [br]it, but I wanted the graphics to be amazing so 0:04:48.480,0:04:52.800 I jumped into Photoshop and just started [br]making loads of sprites and animation frames. 0:04:52.800,0:04:59.280 I actually have a Dropbox folder that is full of [br]sprites and animations. I made loads of different 0:04:59.280,0:05:05.760 characters, I made finishing moves for Howard [br]Carter, I made an introductory cutscene, I made 0:05:05.760,0:05:10.480 menus with big juicy buttons [br]to press. I really got into it. 0:05:10.480,0:05:16.080 But then I realised something. [br]Something quite important. Something 0:05:16.880,0:05:26.080 quite detrimental to the project. The game wasn't [br]any good! It was really bad, it wasn't fun at all. 0:05:26.080,0:05:29.440 And the more I coded it and [br]the more I developed it the 0:05:29.440,0:05:35.920 more I realised what the problem was: Picross [br]just doesn't have enough depth for this 0:05:35.920,0:05:41.120 type of game. You can't really have tactics [br]or strategy, you can't change what you're 0:05:41.120,0:05:47.040 doing depending on which enemy you're fighting, [br]and ultimately it was immaterial that you were 0:05:47.040,0:05:51.920 fighting enemies. You could ignore that entire [br]top part of the game and the game would still 0:05:51.920,0:05:55.760 work because all you're doing is just playing [br]Picross puzzles. So it meant that I didn't have 0:05:55.760,0:06:00.480 the ability to make the game more difficult [br]or more interesting depending on which enemy 0:06:00.480,0:06:05.040 you were fighting and it meant the player was [br]just doing the same thing over and over again. 0:06:05.040,0:06:11.520 I had made a game that was shallow and repetitive [br]and dull. And maybe I could have fixed it but I 0:06:11.520,0:06:18.240 was so far gone at that point and so demoralised [br]that I just kind of scrapped the whole thing. 0:06:18.960,0:06:26.640 So what was my mistake? Well, with many, many years [br]of hindsight… it's been almost a decade now… it's 0:06:26.640,0:06:31.840 pretty obvious to me what happened. And it's [br]this: when you're making a game there's a bunch 0:06:31.840,0:06:38.000 of different things you have to create. The main [br]ones being the music, the art, the game design, 0:06:38.000,0:06:44.400 the story, and the code. And now it's easy [br]to think of them as being equal… but they're 0:06:44.400,0:06:50.560 not. In a lot of cases, the game design is [br]not equal but instead it is the foundation 0:06:50.560,0:06:58.000 upon which all the other parts sit. And so if you [br]get that bit wrong the whole thing falls apart. 0:06:58.000,0:07:02.000 I mean you can fix the bugs and you can [br]redraw the graphics, but if the gameplay 0:07:02.000,0:07:07.760 is fundamentally flawed well the whole [br]project can sometimes be unsalvageable. 0:07:07.760,0:07:11.840 And this is pretty much what happened [br]to me. I spent so much time on the art 0:07:11.840,0:07:15.680 and animation that by the time I [br]finally got around to the gameplay, 0:07:15.680,0:07:20.640 I realised that the whole thing was flawed. [br]I had basically built a house on really 0:07:20.640,0:07:26.560 shaky foundations and then I was surprised and [br]upset when my toilet fell through the floor. 0:07:26.560,0:07:31.520 Embarrassingly this is not the only time this [br]has happened to me. I wanted to make a film noir 0:07:31.520,0:07:35.840 point-and-click adventure game with a unique [br]procedural generation clue system - but 0:07:35.840,0:07:39.520 I spent so much time on the story [br]and researching the time period that 0:07:39.520,0:07:42.240 I never got around to actually [br]designing that system. 0:07:42.240,0:07:46.640 And I wanted to make a fast-paced [br]modern twist on the mobile game 0:07:46.640,0:07:51.920 Snake but I got bogged down in bug fixing [br]and trying to get the movement code perfect 0:07:51.920,0:07:56.640 that I never found out if that game was [br]any fun before I got bored and burnt out. 0:07:57.200,0:08:02.480 So every time I've tried to design my [br]own game I've put other elements like 0:08:02.480,0:08:06.960 story and graphics ahead of the gameplay. Why? 0:08:07.680,0:08:15.040 Well I think it comes down to making two very [br]wrong assumptions. Assumption one is that the game 0:08:15.040,0:08:20.400 always felt kind of cool in my head, so I just [br]kind of assumed that the game would be fun 0:08:20.960,0:08:28.320 when I made it. Obviously that was wrong. And [br]assumption two is that I'm not able to find out 0:08:28.320,0:08:33.760 if the game is fun until I've built the [br]game. I have to just kind of keep making 0:08:33.760,0:08:40.400 the game and at some point I'll realise [br]if it's any good… right? No, wrong again. 0:08:40.400,0:08:47.520 And this is all very cringe-worthy to say because [br]now the answers are so obvious. But they weren't 0:08:47.520,0:08:52.560 obvious then - it's only since doing Game Maker’s [br]Toolkit, since researching game development, since 0:08:52.560,0:09:00.080 interviewing dozens and dozens of game designers [br]that I now know how most successful games start. 0:09:00.080,0:09:05.680 You see game designers have loads of ideas all [br]the time and I'm sure they all seem amazingly 0:09:05.680,0:09:12.400 fun in their heads. But the best game designers [br]know that their brains are horrible smelly liars. 0:09:12.400,0:09:19.040 The only way to know if a game idea is [br]good is to build it, to test it. But 0:09:19.040,0:09:25.760 instead of having to build the entire game, [br]designers just have to build a… prototype. 0:09:25.760,0:09:32.480 A prototype is just this small scrappy test bed [br]for an idea, just designed to see if the idea 0:09:32.480,0:09:37.680 is fun or not. These prototypes are [br]usually incredibly ugly with just 0:09:37.680,0:09:45.280 unfinished art or basic shapes or sprites stolen [br]from other games. They're often buggy and broken 0:09:45.280,0:09:51.280 and they have nothing in them but the bare minimum [br]features needed to test that mechanic. They are a 0:09:51.280,0:09:55.760 just functional enough version of the [br]game idea, built as quickly as possible, 0:09:55.760,0:10:03.520 with the only purpose being to see if that game [br]idea works. Is it fun or interesting? Is it 0:10:03.520,0:10:09.760 worth pursuing? Is it a strong foundation [br]upon which to build the rest of the game? 0:10:09.760,0:10:15.280 And so that's what I'm gonna do. This time I'm [br]gonna get it right. I’m gonna focus exclusively 0:10:15.280,0:10:19.280 on making the prototype and I am [br]going to be extremely disciplined 0:10:19.280,0:10:23.120 and not do anything other [br]than just test this game idea. 0:10:23.120,0:10:28.240 So in terms of art, I'm just going to pull stuff [br]off Google Images. There's going to be no music, 0:10:28.240,0:10:33.840 there's no story, I'm not going to think about the [br]name of the game or the name of the characters. 0:10:33.840,0:10:38.240 I'm not gonna start designing an app icon [br]for a game that hasn't even been built yet, 0:10:38.240,0:10:43.520 Mark, you idiot. The code will definitely [br]be buggy and broken because I'm still just 0:10:43.520,0:10:46.880 learning Unity, but it should be good enough 0:10:46.880,0:10:52.960 to see if this idea works. Just a sandbox to [br]test out game mechanics and see what's fun. 0:10:52.960,0:10:56.400 So let's get started, and open up Unity. 0:10:56.400,0:11:00.720 The first thing I needed to do was to have a [br]character who can just move left and right and 0:11:00.720,0:11:05.520 jump, so I just have it apply forces to [br]the rigidbody when I hit the right keys. 0:11:05.520,0:11:10.880 This already had some problems, which wasn't a [br]great start, but I got there in the end. Then 0:11:10.880,0:11:17.200 I put a magnet in the scene and needed to make it [br]so the character would attract towards the magnet. 0:11:17.200,0:11:23.200 Now to get this working I had to become an [br]expert programmer, I had to use my galaxy brain 0:11:23.200,0:11:29.200 coding skills, so I limbered up my fingers and [br]typed in the following line of code… how do I 0:11:29.200,0:11:34.240 move a rigidbody towards another object. [br]Okay, yes, I Googled it, found some code, 0:11:34.240,0:11:38.880 and slapped it in my project. But I did make [br]sure I understood how it works - it basically 0:11:38.880,0:11:44.080 finds the direction between the character and [br]the magnet and applies forces to the rigidbody 0:11:44.080,0:11:49.680 in that direction. I also tweaked the code so that [br]it would speed up as you get closer to the magnet. 0:11:50.320,0:11:54.960 Then I made it so you could turn off the magnet [br]with a button press which had the intended 0:11:54.960,0:11:59.120 effect of keeping the character's velocity [br]going, sending them flying through the air. 0:11:59.120,0:12:04.640 So if I slap a platform up here I can attract [br]the character towards the magnet then let go 0:12:04.640,0:12:10.880 and jump up here. Which does feel pretty [br]good… but it's a little hard to control 0:12:10.880,0:12:15.360 things. This code maybe isn't perfect, [br]things get out of hand pretty easily. 0:12:15.360,0:12:20.000 But as I was researching this stuff, I [br]stumbled upon something really useful in 0:12:20.000,0:12:26.720 Unity. It's a built-in component called the point [br]effector, and it's basically… a magnetic field. 0:12:26.720,0:12:31.760 I don't know how I missed this, the icon for it [br]is literally just a magnet. Here's how it works: 0:12:31.760,0:12:37.440 you give a GameObject a collider and a point [br]effector, and then set an attract strength. 0:12:37.440,0:12:42.720 And now when a rigidbody is in the collider, [br]it's attracted towards the center of the field. 0:12:42.720,0:12:48.720 You can also use Unity's layer mask system to [br]make it so it only attracts certain objects. 0:12:48.720,0:12:52.560 So this would certainly make the game [br]a lot easier to make, so I decided to 0:12:52.560,0:12:56.400 remake the prototype. And, yes, [br]the game feels more grounded. 0:12:56.400,0:12:59.840 It's easier for me to tweak things [br]and I can do cool stuff like 0:12:59.840,0:13:04.880 if I put the attract point on the poles of the [br]magnet, this happens - which looks pretty sweet. 0:13:04.880,0:13:09.760 But when I made this second prototype, for [br]some reason… not quite sure why, I decided 0:13:09.760,0:13:16.400 to not use Mario this time, but replace him with [br]a picture of a magnet for the main character. And 0:13:16.400,0:13:23.120 this kind of gave me an idea: what [br]if the character is not magnetic, 0:13:23.120,0:13:29.760 but there is a magnet in the game world. And the [br]character can walk over and pick up the magnet. 0:13:29.760,0:13:34.960 To achieve this I used Unity's built-in [br]joint system, it's another component. 0:13:34.960,0:13:39.520 This allows you to connect two rigidbodies [br]together using different types of joints like 0:13:39.520,0:13:44.960 hinges and springs. So now the character is [br]essentially holding the magnet and if the magnet 0:13:44.960,0:13:49.920 is attracted to a piece of metal, the character [br]goes with it. Until you let go of the magnet, 0:13:49.920,0:13:53.040 and now you can walk around again. [br]And that gameplay I wanted before, 0:13:53.040,0:13:57.680 with using the trajectory of the magnet to [br]send your character up to a higher platform, 0:13:57.680,0:14:01.680 that can still be achieved by just [br]letting go of the magnet in mid-air. 0:14:01.680,0:14:04.560 Plus it allows for all sorts of [br]other things, like you can have 0:14:04.560,0:14:07.600 two magnets, or more. And you could maybe, like, 0:14:07.600,0:14:13.120 place the magnet up here, then get an enemy to [br]chase, you turn off the magnetism, and splat! 0:14:13.680,0:14:20.240 Oh this is kind of cool, actually. Maybe this [br]could work. Suddenly the game felt way more 0:14:20.240,0:14:25.680 interesting than my original idea, which I have to [br]admit I was starting to get a little bit worried 0:14:25.680,0:14:30.720 about. When your character is magnetic and being [br]attracted and repelled it's very easy to feel 0:14:30.720,0:14:36.160 a bit out of control, but having the magnet be [br]a separate object means you get times where you 0:14:36.160,0:14:41.200 are completely in control as the character, and a [br]bit more out of control when holding the magnet. 0:14:41.200,0:14:46.080 Plus, I was a bit worried just how many ideas I [br]could come up with for a game where the character 0:14:46.080,0:14:52.320 is magnetic. But as soon as I had it as two [br]separate entities, the ideas just started flowing. 0:14:52.320,0:14:57.760 Plus I really like games where you move back and [br]forth between two distinct types of gameplay, 0:14:57.760,0:15:03.200 like, think how Mario Odyssey changes when [br]you do and don't have the hat. So in my game, 0:15:03.200,0:15:09.760 the character is nimble and can jump really high [br]without the magnet, and slow and leaden when 0:15:09.760,0:15:14.960 holding the magnet - but, of course, that magnet [br]allows for all sorts of amazing possibilities. 0:15:14.960,0:15:20.720 Now I shouldn't be surprised that an even better [br]idea emerged during the prototyping process. As we 0:15:20.720,0:15:26.880 saw in the GMTK episode The Games That Designed [br]Themselves, it's pretty common for new ideas to 0:15:26.880,0:15:31.760 emerge during prototyping. Take a look at the [br]game Crypt of the Necrodancer: when that game 0:15:31.760,0:15:37.440 was originally designed, it was just supposed to [br]be a roguelike with a tight time limit in between 0:15:37.440,0:15:42.560 your turns. But as the designers made it, they [br]realised that it would be even more interesting 0:15:42.560,0:15:46.400 if, instead of it being on a timer, [br]it was set to the beat of a song. 0:15:46.960,0:15:51.600 So prototypes aren't just a way to [br]test and prove the validity of an idea: 0:15:51.600,0:15:55.920 they are a way to generate [br]new and even better ideas. 0:15:55.920,0:16:00.160 Now during this whole stage I made [br]another interesting discovery in Unity: 0:16:00.160,0:16:04.800 this one is called sprite shapes. And [br]it's generally used to make really cool 0:16:04.800,0:16:08.080 organic level design, like you [br]might see in the Ori games, 0:16:08.080,0:16:13.600 but for my purposes I just put on a blank colour [br]and this allowed me to make level design really, 0:16:13.600,0:16:18.400 really fast. I could just snap together a [br]prototype area by dragging handles around 0:16:18.400,0:16:22.960 like doing something in Photoshop. So I built [br]the prototype again and this time I wanted the 0:16:22.960,0:16:28.240 character to be a little bit better to control, [br]something closer to a real video game character. 0:16:28.240,0:16:33.920 Now I don't want to get bogged down in [br]coding movement and jumps, so I downloaded a 0:16:33.920,0:16:39.040 character control script off the internet. [br]It works really good, I can focus on tweaking 0:16:39.040,0:16:45.520 it or remaking it or whatever in the future: [br]right now I don't want to put time into that. 0:16:45.520,0:16:50.160 Also in this prototype I started looking [br]at some more mechanics like being able to 0:16:50.160,0:16:54.800 throw the magnet and then being able to [br]recall it back to you like Thor and his 0:16:54.800,0:16:59.760 hammer. And because the magnet rigidbody bumps [br]into the character's rigidbody, it gives you 0:16:59.760,0:17:04.800 this little bit of feedback when you catch the [br]magnet. It's like free game feel, it's amazing. 0:17:04.800,0:17:09.520 And then I came up with various scenarios [br]that you could use the magnet in, like 0:17:09.520,0:17:14.160 throwing it at a wall to create a platform. [br]Maybe connecting it to a piston and then 0:17:14.160,0:17:18.480 disconnecting it at the right time to send [br]it flying. Maybe switching its polarity to 0:17:18.480,0:17:24.400 jump between two conveyor belts. Or how about you [br]weigh down this platform, stand on the top of it, 0:17:24.400,0:17:30.160 and then change the magnet's polarity to shoot you [br]up in the air? Whoa this is actually pretty cool, 0:17:30.160,0:17:35.120 right? This is looking like a [br]video game. This is pretty fun! 0:17:35.120,0:17:41.120 And this really was the point where I felt like [br]this game idea certainly has some potential. It's 0:17:41.120,0:17:46.160 original: I've seen a bunch of magnet-based [br]games but nothing quite like this. 0:17:46.160,0:17:52.080 It allows for both platforming and puzzle [br]based gameplay. It feels like ideas for this 0:17:52.080,0:17:56.960 game just flow really easily so I can build [br]loads of different levels. And, best of all, 0:17:56.960,0:18:02.320 it's just really fun to play. I can just jump [br]into this scene in Unity and pick up a controller 0:18:02.320,0:18:06.720 and it's quite enjoyable. That [br]is surely a very good sign. 0:18:06.720,0:18:13.120 And so this is the power of prototypes: [br]you can use them to test if a game idea 0:18:13.120,0:18:16.320 is actually any good. And, if you're really lucky, 0:18:16.320,0:18:20.720 you might find that new ideas emerge [br]during that prototyping phase. 0:18:20.720,0:18:26.880 Now I think you do have to have a certain level [br]of discipline here, you really do have to say ‘I’m 0:18:26.880,0:18:32.000 not going to focus on anything extraneous right [br]now, just the gameplay’. And, I mean, it is hard. 0:18:32.000,0:18:37.520 Like, in this video I didn't show you the entire [br]week I spent looking at particle effects and 0:18:37.520,0:18:43.280 shaders and UI elements and things like that - I'd [br]gone right back to that old behaviour of getting 0:18:43.280,0:18:49.520 distracted and carried away by stuff that just [br]doesn't matter right now. But luckily I caught 0:18:49.520,0:18:54.400 it in time and scrapped that prototype, before [br]getting back to the stuff that is important. 0:18:54.400,0:18:59.600 And ultimately I think it worked out: I ended up [br]building something that I think is pretty fun, 0:18:59.600,0:19:06.000 that does have potential, and that I am excited [br]to work on. My previous games which I tried to 0:19:06.000,0:19:11.600 make when I was much younger were built with a [br]sort of blind hope that the game would be fun, 0:19:11.600,0:19:16.640 which isn't the most confidence-inducing [br]way to make a game. But now it feels like 0:19:16.640,0:19:22.000 I'm building on a really strong foundation [br]and so all those other aspects - the story, 0:19:22.000,0:19:29.200 the music, the artwork - that can be built with [br]faith that the underlying foundation is solid. 0:19:29.200,0:19:34.400 And so I feel like this is [br]the way to start making games: 0:19:34.400,0:19:39.840 building a prototype. The only question [br]is: what the hell do I do next? 0:19:40.720,0:19:45.120 I guess we'll find out next time, in the [br]next episode of Developing. Thank you 0:19:45.120,0:19:51.840 so much for watching and I hope you'll join me [br]on the next episode of this journey. Goodbye. 0:20:14.320,0:20:18.320 The idea actually came from this game, [br]The Legend of Zelda: Oracle of Seasons. 0:20:19.600,0:20:22.240 Damn it. From this game. Oops. 0:20:25.120,0:20:31.760 From this game. It came from this game. This [br]game. This game. This game: The Legend of Zelda: 0:20:31.760,0:20:38.080 Oracle of Seasons. The idea actually came from [br]this game: The Legend of Zelda: Oracle of Seasons. 0:20:39.920,0:20:41.120 That was pretty good.