NY HTML5 - Game Development with HTML5 & JavaScript
Upcoming SlideShare
Loading in...5
×
 

NY HTML5 - Game Development with HTML5 & JavaScript

on

  • 16,107 views

In this talk I will bring you up to speed with using HTML5 tools and techniques for game development. I will discuss some basic and advanced techniques and highlight the key lessons that I've learnt, ...

In this talk I will bring you up to speed with using HTML5 tools and techniques for game development. I will discuss some basic and advanced techniques and highlight the key lessons that I've learnt, as well as the technologies and game engines that you should be aware of.

Statistics

Views

Total Views
16,107
Views on SlideShare
14,274
Embed Views
1,833

Actions

Likes
34
Downloads
356
Comments
5

20 Embeds 1,833

http://makoto-tanaka.com 1539
http://nb.colegionexus.edu.mx 79
https://twimg0-a.akamaihd.net 50
http://www.techgig.com 47
http://localhost 29
http://jetgon2932.tistory.com 28
https://si0.twimg.com 26
http://blog.catchexception.net 7
http://webcache.googleusercontent.com 5
http://murat.dev.udemy.com 5
https://twitter.com 5
http://a0.twimg.com 2
http://virtual.uptc.edu.co 2
http://zootool.com 2
http://www.udemy.com 2
http://paper.li 1
http://br2016.orbitive.com.br 1
http://15mins.tistory.com 1
https://www.google.co.jp 1
http://timesjobs.techgig.com 1
More...

Accessibility

Categories

Upload Details

Uploaded via as Adobe PDF

Usage Rights

© All Rights Reserved

Report content

Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
  • Full Name Full Name Comment goes here.
    Are you sure you want to
    Your message goes here
    Processing…
  • 3--Bom dia galera, Venham conhecer nossos Servidores de Mu Online
    O Jogando.net/mu Mu Online Season 6
    Fazemos sua Diversão com qualidade,há mais de 5 anos
    Servers ON 24 horas por dia.
    Vários Server esperando por você.Venha se divertir de verdade.
    Venham participar do 6° Megaultrasuperhiper Evento Castle Siege
    Sejam benvindos ao nosso Servidor.
    >>Kits DIAMOND,Com asas LVL 4,os kits mais fortes e raros do servidor ,venham conferir.
    >>Qual o seu Time ?? Tenha o seu Time do coração no Mu Online.Sets do seu Time preferido
    >>Confiram a nova versão do Shild mais usado no servidor o SHILD POWER v3.
    >> Lançamento do NOVO Kit Fusion V2,Kit hiper top e bonito.
    Você só encontra no http://www.jogando.net/mu/
    Facebook: http://www.facebook.com/profile.php?id=100002113910611
    Site http://www.jogando.net/mu/ HYCLEN Divulgadora Oficial !!!
    Boa Semana á todos !!!
    Are you sure you want to
    Your message goes here
    Processing…
  • cool
    Are you sure you want to
    Your message goes here
    Processing…
  • @MikaelLefebvre What makes you say that?
    Are you sure you want to
    Your message goes here
    Processing…
  • The buzz around html 5 is fading... For now at least
    Are you sure you want to
    Your message goes here
    Processing…
  • very good :p faved
    Are you sure you want to
    Your message goes here
    Processing…
Post Comment
Edit your comment

NY HTML5 - Game Development with HTML5 & JavaScript NY HTML5 - Game Development with HTML5 & JavaScript Document Transcript

  • NT ME P O ript EL EV JavaS c E 5 D & aw kes M HTM A ing L Ro bH G s UHi, I’m Rob Hawkes and I’m here today to talk about creating games on the open Web usingHTML5 and JavaScript.
  • I work at Mozilla, a non-profit fighting for a better Web. The guys who make Firefox.Unsure about how much I like Mozilla? This here is a beautiful chicken and leek pie with extraFirefox goodness.It was made by my talented girlfriend and it was delicious.
  • My official job title is Technical Evangelist, but I prefer what it says on my business card.Part of my job is to engage with developers like you and I about cool new technologies on theWeb.And for those of you with no idea of what a rawket is, I made a multiplayer game calledRawkets in which players fly around in little rockets and shoot each other in the face with thelatest Web technologies. It’s quite addictive!http://rawkets.com
  • I’m not sure how much time we’ll have for questions at the end, but feel free to grab me inperson after the talk or on Twitter.These slides will go online after this talk.I’ll put all the details up at the end.
  • Before we move on I just have a quick disclaimer.This whole talk is about HTML5 and JavaScript as technologies for the creation of games.They’re technologies that are intrinsically linked to each other by nature, but saying HTML5and JavaScript every single time makes my head hurt.So instead I’ll just be saying HTML5.Just bear in mind that whenever I mention HTML5 I’m also referring to JavaScript as well.
  • So let’s go back in time for a moment.Now I don’t actually remember when I first started playing computer games, although I knowthat I started with consoles.
  • My first experience was with the ZX Spectrum and its amazing noises and epic loading times,which I sorely miss…
  • Then there was the SNES, which really got me addicted to gaming.Although it turns out my SNES was stolen when I was a kid. I did wonder where it went…
  • My parents replaced it with the Megadrive which, although not quite as awesome, was just asfun.From there it has been a constant stream of consoles, each smashing the performance andfunctionality of its predecessor.The N64, the Gamecube, the Dreamcast, the Playstation, the xBox.You get the idea…
  • And spread throughout that time I dabbled in PC gaming, starting with games like Sim City…
  • And Megarace.Who remembers this one?
  • And playing multiplayer Doom at my Dad’s Internet cafe.What I’m getting at here is that gaming has been a big part of my life growing up, as it hasbeen with a lot of other people as well.They’re fun to play, and they’re surprisingly fun to make.
  • ow is n e cool tim thing he om e T do fs ol resh ThToday we’re now on the threshold of something cool; being able to create awesome andaddictive games with nothing more than the technologies that we normally use to makewebsites, namely HTML5 and JavaScript.Since I began developing on the Web I really can’t remember a time when so many people areworking together to achieve something like this.
  • n ts e ve ng ble am i ota L5g N HTM in s-on going nt rta po ImRecently there have been some particularly notable events surrounding HTML5 gaming.
  • ns itio uis up Acq g boug ht in be es gin e en am 5g TML HThe acquisition of HTML5 gaming engines by large companies.Like Aves being bought by Zynga and Rocket Engine bought by Disney.
  • n t e itm ted ecru an R arew ers velop e de am L5g HTMThe recent recruitment of HTML5 games developers for well-known gaming companies, likeCrytek.http://crytek.com/career/offers/overview/frankfurt/programming-engineering/html5-game-dev
  • in g nd Fu eers ion thep in sting InveThe huge amounts of funding being made available to games that help prove the Web as agaming platform.Like the Game Lab from Bocoup and Atari’s general sponsorship of HTML5 games.http://gamelab.bocoup.com
  • ce s n re mes nfe ga Co L5 HTM of ture fu the ssing cu DisThe two large-scale HTML5 gaming conferences last year; onGameStart in Poland and NewGame in San Francisco. As well as a whole bunch of HTML5-related sessions at GDC this year.Each attended by hundreds of game and Web developers alike.
  • n t e m es olve am v in HTML 5g ser for row e tech B th ing rovid PThe investing of time and resources by Google, Mozilla and Opera into the creation oftechnologies and services for the benefit of gaming on the open Web.Some of which we’ll be looking at in a moment.
  • ling to o r te ceable rate et B a no ti at oving pr ImGame engines and tooling for HTML5 development have been improving at a noticeable rate.I’ll cover some of these game engines further on in the talk.
  • e s g a m iO S ap ab le h it than c ing ore ort L 5ism P HTM wing ShoAnd the recent port to HTML5 of massively successful iOS games like Angry Birds,Fieldrunners, and Cut The Rope.http://chrome.angrybirds.comhttp://fieldrunnershtml5.appspot.comhttp://www.cuttherope.ie
  • es g a m ing ples ist exam Ex he be st ft eo SomThe number of HTML5 games out there is growing every day.In any case I thought I’d show you a selection of my favourites, just a tiny amount of what’sout there.
  • Quake IIMultiplayer Quake II remake with Google GWT (Google Web Toolkit).http://code.google.com/p/quake2-gwt-port/
  • Angry BirdsThere isn’t much to say about Angry Birds really, most of you probably know about it.The HTML5 version uses WebGL for accelerated 2D graphics.
  • FieldrunnersFieldrunners was ported from iOS to HTML5 by Bocoup.Like Angry Birds, it also uses WebGL for accelerated 2D graphics.
  • Cut The RopeCut The Rope was also ported from iOS to HTML5.
  • BejeweledBejeweled is a massively popular game on a whole variety of platforms.Popcap recently released a purely HTML5 version that uses WebGL for accelerated 2Dgraphics.
  • Command & ConquerCommand & Conquer: Tiberium Alliances is a HTML5 game from EA that uses canvas for thegraphics.
  • GT RacingGT Racing: Motor Academy by Gameloft and Mandreel. Using WebGL for accelerated 3Dgraphics.http://www.mandreel.com/?page_id=1312
  • BrowserQuestBrowserQuest is a massively-multiplayer RPG that Mozilla recently launched to the public.It was created by Little Workshop in France and uses HTML5 canvas for the graphics,WebSockets for real-time communication, and a whole range of other tech to handle save-game data and other things.It works great on mobile and desktop devices but what’s even better is that, aside from beingan addictive game, the entire source code is on GitHub.http://browserquest.mozilla.orghttps://github.com/mozilla/BrowserQuesthttp://hacks.mozilla.org/2012/03/browserquest/
  • It’s clear that HTML5 is something that is really becoming a contender for games on the Web.It’s an open technology stack that is pluginless, doesn’t require compilation, and works thesame across devices and platforms.
  • But just because HTML5 is the trendy thing doesn’t mean that you need to use it.So why might you not want to use it?
  • ility a tib re p m everyw he ll co ted Fu pp or ’tsu ren ga hin et SomNot every browser supports every part of HTML5.For example, canvas isn’t supported out of the box by any IE below 9. Although, you can useExplorerCanvas to replicate canvas functionality, but it’s not ideal and as doesn’t perform aswell.WebSockets is only support in IE10 and has poor support on Android. But again, you can fakethis by using Flash for the sockets, like with Socket.IO.WebGL also has patchy support with absolutely no support in IE, and Safari and Operarequiring a development build.There is no denying that the cross-browser situation is by no means perfect for somefunctionality.
  • RM o D N ologies echn eset th st again goes ItIf you need DRM or have a burning desire to hide absolutely everything about your code.Remember, the code isn’t compiled, so where would the DRM go? The beauty of Webtechnologies is that they can be read as plain text by simply viewing the page source.However, DRM isnt bulletproof in itself and you can still crack into things like Flash.You can obfuscate and minify your code if you think it will help, but even this can be workedaround with relative ease.
  • ns t io ita thing y lim every log do no ed to Tech er prom is nev L5 HTMIt is wrong to see HTML5 as a one-size-fits-all solution.There are things that it’s meant to do, and things that it’s not meant to do.Comparing HTML5 to other technologies always results in, “but HTML5 doesn’t to this, orthat.”In cases like that, perhaps HTML5 isn’t the right technology for you.
  • g y o lo chn es Te L5g am TM fH so cene s he dt hin BeThere are a few key technologies that are involved in the development of HTML5 games.Here are some of my favourites.
  • vas an C tfo rm pla ics raph g 2DCanvas is a 2D graphics platform that uses both HTML5 and JavaScript.It’s quite amazing what can be done with such simple drawing and image manipulation tools.https://developer.mozilla.org/en/HTML/Canvas
  • Silk is a stunning example of what can be achieved by combining the simple drawing toolsavailable in canvas.http://weavesilk.com
  • GL eb W form lat sp hic grap 3DWebGL brings the ability to provide advanced 3D graphics directly within the browser.https://developer.mozilla.org/en/WebGL
  • HelloRacer is a little game that lets you drive a Formula One car around your browser. It’s abeautiful example of WebGL in action.http://helloracer.com/webgl/
  • Rome is a music video created with WebGL. It’s an amazing example of what the technologycan achieve in a real-world situation given a large team.http://ro.me
  • This is a rather freaky example of how interesting WebGL is.It’s a demo that shows just how realistic WebGL can render materials, like skin. This isn’tmuch unlike the quality of modern games consoles!http://www.everyday3d.com/j3d/demo/014_Head.html
  • m e Fra on ps ati ati on loo nim d anim estA timise qu Op rerequestAnimationFrame is the new, better way of managing animation in JavaScript.Instead of constantly running a setTimeout or setInterval function, which lack performanceand spike CPU usage, requestAnimation frame puts the browser in control of things andkeeps things running smoothly.
  • d io a u L5 usic TM nd m H grou ck ba nd ctsa effe nd SouHTML5 audio allows for plugin-less game sound effects and background music.Audio data APIs implemented by Mozilla and Google allow for manipulation of audio andmuch more fine-grained control.https://developer.mozilla.org/en/HTML/Element/audio
  • This is something I made especially for the ASSEMBLY 2011 event in Finland.It’s an audio visualiser that uses WebGL and the HTML5 Audio Data API.http://robhawkes.github.com/webgl-html5-audio-visualiser/
  • e ts ock bS ation e W omm un ic yerc ltipla MuWebSockets can be used for the real-time communication between a player and the gameserver.With WebSockets you can create multiplayer games with relative ease.https://developer.mozilla.org/en/WebSockets
  • ge ra to vice cal s r de Lo pla ye he t on ta da ng StoriMethods like the application cache, Local Storage, and IndexedDB are great for storing datalocally on the player device.This way you can cache game data and allow the game to pick up where the player left off.https://developer.mozilla.org/en/DOM/Storagehttps://developer.mozilla.org/en/Offline_resources_in_Firefoxhttps://developer.mozilla.org/en/IndexedDB
  • e rs ork b W aS cript e W eaded Jav i-thr MultWeb Workers allow you to run JavaScript in separate background threads.This allows you to offload computationally-heavy tasks with a single worker, or tackle largequantities of data in a fraction of the time by spreading tasks over multiple workers.https://developer.mozilla.org/En/Using_web_workers
  • PI n A re e ul Sc we rf ull et po F im ple ,y SThe Full Screen API allows you to expand any HTML element to fill the users screen, even ifthe browser isn’t running full screen itself.The Mozilla implementation is not perfect yet because you can’t use the whole keyboard infull-screen mode without a message popping up, but it’s in the latest Nightly builds andworks in all other respects.https://bugzilla.mozilla.org/show_bug.cgi?id=545812http://blog.pearce.org.nz/2011/09/mozilla-full-screen-api-progress-update.htmlhttps://wiki.mozilla.org/Platform/Features/Full_Screen_APIs
  • P I A o ck ace r L pl te ne oin rso rino P cu he gt ockin LThe Pointer Lock API is an attempt at improving the mouse as an input device.It would be used in situations like games and 3D visualisations where the mouse positionrotates or moves you around a 3D space.As it stands there’d still be a cursor moving around the screen causing all sorts of troublewhen you want to click on something in your game.With the new API you can lock your mouse position and stop it from getting in the way andbeing a nuisance.Both Google and Mozilla are working on an implementation of this right now, it’s available ina custom build of Firefox.https://developer.mozilla.org/en/API/Pointer_Lock_APIhttps://bugzilla.mozilla.org/show_bug.cgi?id=633602
  • P I d A p a eb me he W Ga et ot ol ns co he gt gin BrinThe Gamepad API is one of the major improvements to input that is coming.Both Mozilla and Google are working an an implementation of this and there is actually anexperimental build of Firefox available to the public that has it working. The API is also in thedev build of Chrome.What I find most interesting about the Gamepad API is that it might be just the thing we needto finally justify HTML5 gaming on a TV or console.Who wants to use a keyboard and mouse while sitting on the sofa?https://wiki.mozilla.org/GamepadAPIhttp://www.gamepadjs.comhttps://github.com/jbuck/input.js
  • Gamepad API demoI’d like to show you a quick demo of the Gamepad API working in Firefox Nightly and GoogleChrome.In this example I’ve connected my Logitech controller to my Mac, but I could also use a PS3controller or practically any other USB controller.
  • This is another little demo that I put together to show off the Gamepad API implemented inmy game Rawkets.
  • n s tio plica bsite ap yw e eb ta fanc W ot jus NThe concept of Web apps is something that is gaining a lot of traction at the moment.HTML5 games are effectively glorified Web apps.It’s no doubt this this traction is as a result of the success of native applications and gameson the desktop and mobile, particularly with iOS and Android.
  • nce erie exp scre en like ho me p- op or Ap eskt thed from ch un LaSomething that needs to be tackled with Web apps is how to make them feel like realapplications rather than glorified websites.One way that is being considered is completely removing the browser chrome and runningthe application in it’s own window.This will effectively mean that you have full control of the app UI and it won’t look like it’sbeing run in a browser.
  • At Mozilla we call this WebRT, which stands for Web Run-Time.By using WebRT you can install a Web app directly into the OS just like you would a nativeapplication.The WebRT app will look and feel like a native application when launched but will actually berunning a browser rendering engine behind the scenes.This is an example of Rawkets running as a WebRT app with the Firefox rendering engine.Notice the lack of browser UI.
  • e.js od N cation uni m com rk etwo dn an logic e GamNode is often used as a multiplayer game server, controlling the logic and handling theWebSockets connections to the players.It can be used for player authentication and the storage of data so gameplay can persist overmultiple game sessions.This is all made relatively easy with great third-party modules, like Socket.IO for WebSockets,and others that handle Redis and MongoDB for storage, for example.http://nodejs.org
  • e s gin e n ay e m game st od Ga ML5 HT te CreaIf you haven’t already then I encourage you to give HTML5 game development a go.And you dont have to create an entire game infrastructure from scratch, you can use some ofthe existing engines that are proving popular.
  • Impact. A 2D game engine.I used this recently, and it’s really well made and has a good level editor and developmenttools.The documentation is great and the author is active and very helpful.http://impactjs.com/
  • Crafty. Another 2D game engine.It’s a free engine and is doing much better than other free engines out there.http://craftyjs.com/
  • Isongenic Engine. A 2D to 2.5D game engine.One of the most promising engines out there today.Massively multiplayer networking built in, uses Node and MongoDB, and has canvas or DOM-based graphics.http://www.isogenicengine.com
  • ing ort e & p bas ion ec od e- vers a sin gl on ing C UsA lot of game developers want to target browsers but don’t want to rewrite their existinggames in JavaScript.To help this process, various methods of converting an existing code-base to JavaScript arestarting to appear.
  • Emscriptenhttps://github.com/kripken/emscripten/wiki
  • Mandreelhttp://www.mandreel.com
  • PlayNhttps://developers.google.com/playn/
  • PhoneGaphttp://phonegap.com
  • CocoonJShttp://www.ludei.com
  • nt e m ey ay d p gm on an kin io n dm a u t ce an trib ud ien Dis ng an a indi FMaking games is only half the battle.Once you have a game finished how to you promote it and get it in front of players?And even more important, how do you earn money from it?
  • Mozilla MarketplaceWe envisage Web apps to run on any device, any browser, and to be distributed through anystore or website.Right now the payment provider is PayPal, though you can set up your own store using ourAPIs and use any provider you want.https://apps.mozillalabs.comhttps://developer.mozilla.org/en/OpenWebAppshttps://marketplace.mozilla.org
  • Chrome Web Store.Uses Google Checkout for payment.https://chrome.google.com/webstore
  • FacebookUses Facebook Credits for payment.https://developers.facebook.com
  • iOS App StoreBy using services like PhoneGap and CocoonJS you can package your game up and sell it onthe iOS App Store, just like any other native application.Uses the iTunes store for payments.https://developer.apple.com
  • es u ss ge I n lle ha ac be an esc gam aking MIt’s not all plain sailing when making a gaming using HTML5 and JavaScript.I’m going to cover a few of the main issues that tripped me up during the development ofRawkets.
  • io n a t n im ontrol g a r in c akin ow se we he br T uttin gt POne of the simplest fixes is to stop using setTimeout or setInterval and to userequestAnimationFrame instead.If you use setTimeout or setInterval and don’t manage it then you put a huge amount ofstress on the CPU and continue that stress even if you switch tabs or minimise the browser.By using requestAnimationFrame you give the browser control over when a new animationloop should occur, reducing load on the CPU and saving battery life on mobile devices.requestAnimationFrame also automatically limits the number of updates if you switch toanother tab or minimise the browser, again saving resources and keeping your players happy.Right now you can’t easily set a specific framerate when using requestAnimationFrame but solong as you use time-based updates (not frame-based) in your game then you’ll be fine.
  • in g o rk etw ug ht N Itho y as as se ta NoIssues with networking have plagued development of the game right from the beginning.This probably stems from my lack of prior experience with socket connection and multiplayergaming in general.In the original prototype of the game the network communication was woefully simple andeverything was transmitted in a verbose format with no further thought.In hindsight it’s obvious why I was experiencing massive performance issues with thenetwork communication. I was basically sending way too much data back and forth.
  • col to n ro atio e p sag mun ic es tcom M hor ds an ured ct StruOne of the ways that I solved these problems was by implementing a structured protocol forthe messages that are being sent and received.This included assigning each message type a number and using enumeration to representthose types in the code.
  • Enumeration types = { PING: 1, SYNC: 2, SYNC_COMPLETED: 3, NEW_PLAYER: 4, UPDATE_PLAYER: 5, UPDATE_INPUT: 6, REMOVE_PLAYER: 7 };By enumerating the messages types like this I was able to refer to them in a verbose formatwithin the code, but benefit from only sending the one or two digit number whentransmitting a message.This is only possible if both the client and server follow the same protocol in regards to whichnumber refers to which message type.It’s a simple but effective solution and allowed me to cut a large number of characters fromtransmitted messages.
  • Message package MSG_ID PLAYER_ID TIMESTAMP X Y 1 | 1234567890 | 1316763202872 | 5 | 34Put together with the message types, a full message package is put together as a simplestring representation of a JavaScript object.All the other pieces of data are attached to the object with a key that is as short as possible.The MSG_ID that you can see above is a reserved key that is used solely for the message type.The other items in this example are the player id, timestamp, and the player position.
  • io n s es ible pr ss om po C uch as asm ata gd cin du ReData in WebSockets is normally transmitted as verbose plain text, so it’s important to cutdown and compress it as much as possible.Some of the ways that I’ve done this include rounding numerical values, reducing the lengthof words if they’re only used for reference, and generally removing any data that isn’tnecessary.
  • ge s essa ion m icat ary mun Bin ste rcom , fa er rt sho en EvI never got around to implementing this but there is now binary message support inWebSockets.By switching to binary you can reduce the size of your messages by a noticeable amountwhile also increasing the amount of data that you can transmit at a single point in time.http://hobbycoding.posterous.com/websockt-binary-data-transfer-benchmark-rsulthttp://hobbycoding.posterous.com/the-fastest-websocket-module-for-nodejs
  • in g it lim ation ate un ic R om m c n on ow gd uttin CAside from the message protocol, one of the biggest issues with networking has been dealingwith the sheer number of messages being sent back and forth during the lifetime of a game.
  • MESSAGES IN MESSAGES OUT 1 1 1 1Having only one player in the game is easy, you have one message coming in to the server,saying the player has moved, for example, and one message coming back out, updating theplayer with details from the server.
  • MESSAGES IN MESSAGES OUT 2 4 1 2 2 1So say we now have two players, there is still only 1 message in from each player, but noweach player receives 2 messages back from the server; one for them, and one for the otherplayer.This isn’t too bad, but notice how the server is having to send 4 messages – 2 for eachplayer.
  • MESSAGES IN MESSAGES OUT 4 16 1 4 4 1 1 4 4 14 players now, look how the server is having to send 16 messages, yet it only receives 4.If you haven’t already noticed, the messages out from the server are the square of thenumber of players.But 16 messages out is alright, it’s hardly going to tax the server.
  • MESSAGES IN MESSAGES OUT 30 900 1 30 30 1 1 30 30 1So imagine if we now move into properly multiplayer territory.30 players in the game would mean 30 messages coming in to the server, and 900 – NINEHUNDRED – messages going out, every update. That’s a silly amount of data for just 30people.But let’s go further still…
  • MESSAGES IN MESSAGES OUT 100 10000 1 100 100 1 1 100 100 1Say we go massively multiplayer and have 100 players in the game at one time.It’s not so bad for each individual player, they send one message in and get 100 back – that’sbearable.But check out the server, it’s getting 100 messages in and is having to send out 10,000 back,every update. That’s just a mentally stupid number that’s going to cause a lot of grief.
  • nce lige es tel essag In se m iti prior e am theg tting LeFortunately there is a way around this that cuts down the amount of messages sent; you justneed to send data only for players visible to another player, in essence filtering out gamedata that doesnt affect the current player.Another trick I used is to only send updates when a player is active and moving. If theyhaven’t moved since the last frame and nothing else has changed then why bother sendingan update and wasting bandwidth?These are such simple solutions, but ones that I never even considered at first.
  • TC P ing ect lw ith it esp .D ea R sesT CP etsu ck So WebSomething else that I discovered is important to be aware of when making a game withWebSockets is that you’re using TCP.This is a problem as such, but it means that you need to play by a certain set of rules, and toexpect a certain set of issues.By the way, I should point out that that you could argue that the icon that I’ve used couldrepresent WebSockets, but that’s not why I used it. It’s the US plug symbol and I just thoughtit was funny because it looks like a surprised face. The UK plug symbol is boring incomparison.
  • e r ord th e ou t it ey ab Ob om uch ’t d can YouOne issue with TCP is that packets will come through in order and get queued up if there areany significant connection issues.This can be a problem with a real-time game as it can cause hang-ups in the transmissionand subsequently a hang-up in the graphic display.In short, the ordering issue can result in jumpy gameplay. Not fun.With UDP this wouldn’t be so much of a problem, but we don’t have that luxury yet. Althoughsimilar protocols are in the pipeline and may make their way into our lives relatively soon,things like Media Streaming APIs and WebRTC.
  • ters ea Ch urse ac and ssing ble AThere’s no denying it, your code is going to be visible to anyone who wants to look at thesource.I experienced this early on in the development of the game with players adding in their ownfeatures, like invincibility, epic speed, rapid-fire, and even creating completely new weaponslike cluster bombs!Now don’t get me wrong, I actually appreciate the cheaters because they highlighted all theerrors of my ways, for free. One of the benefits of the open nature of JavaScript is that it canbe looked at and poked very easily by others, which means that I can fix bugs quicker than ifI was testing on my own.
  • a d b a re pen als ide o lob ew G pc od ee ’y k DonThere are two reasons why cheating was so prevalent and so easy to do.The first is that by keeping all the game code in the global namespace and not usinganything like closures I was practically inviting people to come in and edit the game code. Itwas too easy to do!It was so easy in fact that after a few hours of releasing the first prototype, players werealready sharing code snippets that others could paste into their browser console to get newfeatures. Annoying, but actually pretty cool.
  • rity o th hing a u nt oo dt Clie ys ag a alw ’t isn er PowI’m not going to lie, the first version of Rawkets was way too trusting.I used what is referred to as the authoritative client model, which basically means that theclient, the player, made all the decisions regarding its position and then sent those positionsto the server.The server than trusted those positions and transmitted them to all the other players, whichis fine until the client edits their position and increments it by 100 pixel per frame, ratherthan 5. Bad times.This can be referred to as the “Here I am” approach.
  • ri ty o th wer a u r ve ish th at po er S elinqu RThe solution is to make the server authoritative, which means that you prevent manipulationof the client’s code from doing any damage.All the movement logic is now performed on the server, meaning that when a client moves itsimply lets the server know which direction it wants to move. From there the server calculatesthe new position and sends it back to the client.This can be referred to as the “Where am I?” approach, and if done right it can completelyremove the ability to cheat.
  • Inherent latency 40ms 40ms Client Server Client +0 +40 +80 80ms total round-tripHowever, the problem with the authoritative server model is that there is some inherentlatency within the system.What I mean by this is that it obviously takes some time for a movement to be sent from theclient to the server, then for the server to move the client, and then for the server to send thenew position back again.In the example here imagine that there is a 40ms latency between the client and server,which means that a message sent to the server will take a total of 80ms to make the round-trip.The problem here is what happens during that 80ms period that you’re waiting for theupdated position? If you do nothing then there’s going to be an 80ms delay between youpressing the up arrow and your rawket moving forward. Not good.
  • io n dict h pre no ug nt ’t e Clie hority isn ut vera SerTo solve the latency issues with the authoritative server you need to implement some elementof prediction on the client.What I mean by prediction is an ability for the client to guess, quite accurately, where itshould move the player before the message comes back from the server detailing the newposition.
  • Instant movement 40ms 40ms Client Server Client +0 +40 +80 Prediction happens hereThe prediction happens as soon as the client performs some sort of movement (a key-press,etc), before the server has received the input.All the prediction does is run the same physics as the server, based on the new input.This is exactly as if were using the authoritative client model, apart from one importantdifference.
  • ion ct re rong or C oesw ng tio redic p hen WWhereas the authoritative client model would be in control, with the authoritative servermodel and client prediction, the server is in control.The whole point of using the authoritative server is because the client can’t be trusted. So itmakes sense that prediction can’t be trusted either.To get around this you use periodically check the client position against the server andperform a correction if necessary.This may sound simple in concept, but it’s one of the hardest aspect of multiplayer gaming toget right. Simply because it’s obvious when you get it wrong.
  • ility b ta ning S un er am theg ping KeeKeeping the game running is massively important, especially while it’s in rapid developmentand is prone to crashing (through errors of my own I must add).I needed a way to automatically restart the game server if it crashed or something wenthorribly wrong.I also needed a way to scale the game and keep it running as fast as possible.
  • ForeverI use a little Node module called Forever. It’s amazing!https://github.com/nodejitsu/forever
  • Forever forever start game.jsAll I have to do now is make sure the game process quits on a catastrophic error and Foreverwill automatically restart it for me.Using Forever is as simple as installing the module with NPM and then starting your Nodescript using the Forever demon. The rest is taken care of for you.
  • Hook.ioSome of you may also be interested in hook.io, which can help create more stable Nodeapplications.The concept is to decouple your application logic by breaking it into individual processes sothat if one process goes down the rest can continue to run and your entire game doesn’tcrash.You use hook.io through its event system that lets you communicate between these separateprocesses, regardless of whether they’re on the same server or not. It’s a pretty cool concept.https://github.com/hookio/hook.io
  • Foundation HTML5 Canvas Out now Paperback and digital formats Become a canvas master Learn how to animate Make two cool space games RAWKES.COM/FOUNDATIONCANVASFoundation HTML5 Canvas is out now on Amazon and other reputable book stores.http://rawkes.com/foundationcanvas
  • Rob Hawkes @robhawkes Rawkes.com Personal website and blog RECENT PROJECTS MORE COOL STUFF Twitter sentiment analysis Rawket Scientist Delving into your soul Technical Evangelist at Mozilla Rawkets.com HTML5 & WebSockets gameGet in touch with me on Twitter: @robhawkesFollow my blog (Rawkes) to keep up to date with stuff that I’m working on: http://rawkes.comI’ve recently worked on a project that analyses sentiment on Twitter: http://rawkes.com/blog/2011/05/05/people-love-a-good-smooch-on-a-balconyRawkets is my multiplayer HTML5 and JavaScript game. Play it, it’s fun: http://rawkets.com
  • U O r Y te K e la N m A rab TH ?G es wk es Ha wk ob ha R b ion @ro est QuThank you.If you have any questions feel free to grab me here, on Twitter (@robhawkes)