HTML5 Games with CreateJS [EN], Ebooki, HTML
[ Pobierz całość w formacie PDF ]
//-->For your convenience Apress has placed some of the frontmatter material after the index. Please use the Bookmarksand Contents at a Glance links to access them.Contents at a GlanceAbout the Author �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½xviiAbout the Technical Reviewer �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½xixAcknowledgments �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½xxiIntroduction �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½xxiii■Chapter 1: Getting to Know CreateJS �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½1■Chapter 2: Making and Animating Graphics �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½15■Chapter 3: Capturing User Input �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½31■Chapter 4: Game Project: Progressive Break-it �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½55■Chapter 5: Using and Managing Bitmap Images �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½77■Chapter 6: Sprites and Sprite Sheet Animations �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½109■Chapter 7: Game Project: Fakezee�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½137■Chapter 8: Extending EaselJS Display Objects �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½177■Chapter 9: Sounds and Asset Management �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½203■Chapter 10: The State Machine and Scenes �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½221■Chapter 11: Game Project: Space Hero �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½239■Chapter 12: Building for Mobile Browsers �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½279■Chapter 13: Packaging and Compiling with PhoneGap Build �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½291■Chapter 14: Game Project: The Villager RPG �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½305Index �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½381vIntroductionCreateJS is not a game engine. It was written to create rich, interactive experiences of all kinds by providing tools forHTML5 applications. EaselJS, the library in the suite upon which all games in this book are based, helps manage andcontrol graphics in HTML5 Canvas. Because the very nature of Canvas lends itself nicely to both performance and thetechnical procedures of classic game development, EaselJS very much feels like it’smeantfor games in many ways.Although this is not entirely true, EaselJS, along with the other tools in the CreateJS suite, are a perfect combinationof tools to do just that. The low level, heavy lifting of drawing and management of your game graphics are taken careof, which gives you more freedom to concentrate on the game logic itself. Tools for preloading assets, playing andmanaging audio, and creating complicated tweens are also included in CreateJS, and can also be used extensively tobuild engaging games.A large advantage of using CreateJS for games, as opposed to the othergame-specificHTML5 libraries out there,is the freedom to create and fine-tune your own game framework. In many popular markets, primarily casual, board,and turn-based games, the overhead of a framework built for tiling, heavy collision, and physics is not necessary.Simply utilizing a tool to draw and sort graphics on the canvas is all that is needed. That’s where this book comes in.It puts you right in the middle between complicated native canvas management and being tied down to a specificframework to build your games. This is not to say these other frameworks are bad. In fact they are quite good,especially Phaser and ImpactJS. Depending on the type of game you are building, they can often be the better choice.The purpose of this book is to not only teach you to write these game development techniques yourself, but to give youthe skills to mold your own workflow and frameworks using the CreateJS tools. What’s more, the skills learned in thisbook will fully prepare you to create endless, rich HTML5 applications that extend far beyond games.The book itself is split up into two parts. The first half of the book concentrates on learning the APIs of the suite.Game development techniques will be introduced, focusing on how they can be used with EaselJS and TweenJS.The second half of the book will take your new CreateJS skills to the next level by learning more advanced,objected-oriented JavaScript, asset loading and management, and code organization. More advanced gamedevelopment techniques will also be learned, which will result in performance gains; mobile optimization will beintroduced as well.You’ll find that the libraries in CreateJS are powerful and extremely easy to use. You’ll also learn the best tools andapplications used to create the graphical assets needed for your games, and how to best use them in conjunction withEaselJS. There are several small exercises, including four full game project chapters. I hope you find this book both funand educational, and that it will encourage you to create new and exciting applications using CreateJS.For support, updates on code APIS, and general discussion on this book, please visit the public forum athttps://plus.google.com/u/0/communities/109922548905806388011.xxiiiChapter 1Getting to Know CreateJSBefore you can start building your games, you need to get familiar with the CreateJS suite. I’ll take a look at eachlibrary in the suite and give a brief overview on how to use them. A few JavaScript techniques will also be examined ineffort to learn best practices when working with CreateJS, and the final code example will show the harmony that caneasily be achieved with the entire suite at work.Getting StartedThe best place to get started is to head over to the official web site,shown in Figure1-1.Figure 1-1.The CreateJS official web site1 [ Pobierz całość w formacie PDF ]
zanotowane.pl doc.pisz.pl pdf.pisz.pl chiara76.opx.pl
//-->For your convenience Apress has placed some of the frontmatter material after the index. Please use the Bookmarksand Contents at a Glance links to access them.Contents at a GlanceAbout the Author �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½xviiAbout the Technical Reviewer �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½xixAcknowledgments �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½xxiIntroduction �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½xxiii■Chapter 1: Getting to Know CreateJS �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½1■Chapter 2: Making and Animating Graphics �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½15■Chapter 3: Capturing User Input �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½31■Chapter 4: Game Project: Progressive Break-it �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½55■Chapter 5: Using and Managing Bitmap Images �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½77■Chapter 6: Sprites and Sprite Sheet Animations �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½109■Chapter 7: Game Project: Fakezee�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½137■Chapter 8: Extending EaselJS Display Objects �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½177■Chapter 9: Sounds and Asset Management �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½203■Chapter 10: The State Machine and Scenes �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½221■Chapter 11: Game Project: Space Hero �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½239■Chapter 12: Building for Mobile Browsers �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½279■Chapter 13: Packaging and Compiling with PhoneGap Build �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½291■Chapter 14: Game Project: The Villager RPG �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½305Index �½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½�½381vIntroductionCreateJS is not a game engine. It was written to create rich, interactive experiences of all kinds by providing tools forHTML5 applications. EaselJS, the library in the suite upon which all games in this book are based, helps manage andcontrol graphics in HTML5 Canvas. Because the very nature of Canvas lends itself nicely to both performance and thetechnical procedures of classic game development, EaselJS very much feels like it’smeantfor games in many ways.Although this is not entirely true, EaselJS, along with the other tools in the CreateJS suite, are a perfect combinationof tools to do just that. The low level, heavy lifting of drawing and management of your game graphics are taken careof, which gives you more freedom to concentrate on the game logic itself. Tools for preloading assets, playing andmanaging audio, and creating complicated tweens are also included in CreateJS, and can also be used extensively tobuild engaging games.A large advantage of using CreateJS for games, as opposed to the othergame-specificHTML5 libraries out there,is the freedom to create and fine-tune your own game framework. In many popular markets, primarily casual, board,and turn-based games, the overhead of a framework built for tiling, heavy collision, and physics is not necessary.Simply utilizing a tool to draw and sort graphics on the canvas is all that is needed. That’s where this book comes in.It puts you right in the middle between complicated native canvas management and being tied down to a specificframework to build your games. This is not to say these other frameworks are bad. In fact they are quite good,especially Phaser and ImpactJS. Depending on the type of game you are building, they can often be the better choice.The purpose of this book is to not only teach you to write these game development techniques yourself, but to give youthe skills to mold your own workflow and frameworks using the CreateJS tools. What’s more, the skills learned in thisbook will fully prepare you to create endless, rich HTML5 applications that extend far beyond games.The book itself is split up into two parts. The first half of the book concentrates on learning the APIs of the suite.Game development techniques will be introduced, focusing on how they can be used with EaselJS and TweenJS.The second half of the book will take your new CreateJS skills to the next level by learning more advanced,objected-oriented JavaScript, asset loading and management, and code organization. More advanced gamedevelopment techniques will also be learned, which will result in performance gains; mobile optimization will beintroduced as well.You’ll find that the libraries in CreateJS are powerful and extremely easy to use. You’ll also learn the best tools andapplications used to create the graphical assets needed for your games, and how to best use them in conjunction withEaselJS. There are several small exercises, including four full game project chapters. I hope you find this book both funand educational, and that it will encourage you to create new and exciting applications using CreateJS.For support, updates on code APIS, and general discussion on this book, please visit the public forum athttps://plus.google.com/u/0/communities/109922548905806388011.xxiiiChapter 1Getting to Know CreateJSBefore you can start building your games, you need to get familiar with the CreateJS suite. I’ll take a look at eachlibrary in the suite and give a brief overview on how to use them. A few JavaScript techniques will also be examined ineffort to learn best practices when working with CreateJS, and the final code example will show the harmony that caneasily be achieved with the entire suite at work.Getting StartedThe best place to get started is to head over to the official web site,shown in Figure1-1.Figure 1-1.The CreateJS official web site1 [ Pobierz całość w formacie PDF ]