.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 Back Cover ISBN:1590590511 by Alexandre Santos Lobão and Ellen Presented in easy-to-understand language, .NET Game Programming with DirectX 9.0 is a must-have title for those Hatton who want to create out-of-the-ordinary but simple games, but have never had the time to expend reading hardApress © 2003 (696 pages) core game developers books. Lobao and Hatton show how easy it can be to produce interesting multimedia games The 9.0 authors of this text show easy it can be on to produce using Managed DirectX and programming withhow Visual Basic .NET Everett, the latest version of Microsoft's interesting multimedia games using Managed DirectX and all basic concepts within Visual Studio. Although their focus is on simplicity, the authors are able to9.0 explore programming with Visual Basic .NET on(using Everett, latest Managed DirectX 9.0: Direct3D, DirectSound, DirectMusic thethe COM interface), DirectInput (including forceof Microsoft's Visual Studio. feedback joysticks),version DirectShow, and DirectPlay. There are also chapters covering other technologies that can be used for game programming: the Speech API to generate game characters' voices, multithreading, and GDI+ for simple games. A bonus chapter shows how to port a simple game to Pocket PC. Sample games are presented over two chapters throughout the book. The first chapter presents the game with simple features, and the second Table of Contents chapter extends the game while presenting new concepts. A library of game programming helper classes is also .NET Game Programming with DirectX 9.0 created, step-by-step, in each chapter. Foreword Preface
About the Authors
Introduction Alexandre Santos Lobão has been a non-professional game developer since 1981, when he got his first computer at Chapter 1 - .Nettrix: GDI+ and Collision Detection 12 years of age. He received a bachelor's degree in Computer Science in 1991, from the University of Braslia. When Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites he was attending the University, he helped to develop a graphics program and a computer graphics language (LAFITH Language Three-dimensional Figures), Chapter -3Hierarchical - ManagedAnimation DirectX First Steps: for Direct3D Basics and DirectX vs. which GDI+ organizes objects in a hierarchical way and calculates the results of forces over the objects, giving them velocity and acceleration. This Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio language was presented in many Brazilian conferences, and at the international conference, Compugraphics, in Chapter 5 in -1991.In River Pla.Net and Writing to Screen Sesimbra, 2000, II: he DirectInput published his first book, Text The Box of Pandora and Other Stories , with short stories. Although he has written many technical articles, this is his first technical book. Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Ellen Hatton is currently completing a computer science degree at Edinburgh University. She was exposed to Chapter 8 at- a.Netterpillars II: and Multiplayer Games and Directplay computers very early age has been fascinated with them ever since. Her first experience of computer D-iNfEcT: Multithreading, Nonrectangular Windows, and Access games was playing Dread Dragon Doom, at which she quickly excelled, at the to age of 5. She's been hooked on Chapter 9 Nonmanaged Code games ever since. Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 .NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton LOBÃO AND ALEXANDRE SANTOS Apress © 2003 (696 pages)
ELLEN HATTON
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Copyright © 2003 by Alexandre Santos Lobão and Ellen Hatton Table of Contents .NET Gamereserved. Programming withof DirectX 9.0 may be reproduced or transmitted in any form or by any means, All rights No part this work Foreword electronic or mechanical, including photocopying, recording, or by any information storage or retrieval Preface system, without the prior written permission of the copyright owner and the publisher. Introduction ISBN (pbk): 1-59059-051-1 Chapter 1
- .Nettrix: GDI+ and Collision Detection
Printed2and bound in the United of America 12345678910 Chapter - .Netterpillars: ArtificialStates Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Trademarked names may appear in this book. Rather than use a trademark symbol with every occurrence
Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, DirectAudio of a trademarked name, we use the names only in anand editorial fashion and to the benefit of the trademark Chapter 5 River Pla.Net II: DirectInput and Writing Text to owner, with no intention of infringement of the trademark. Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Technical David Jung Chapter 7 -Reviewer: Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Editorial Directors: Dan Appleman, Gary Cornell, Simon Hayes, Karen Watterson, John Zukowski D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Managing Editor: Grace Wong
Bonus Chapter Porting .Nettrix to Pocket PC Appendix - The State of PC Gaming Project AManager: Sofia Marchant Appendix B - Motivations in Games
Copy Editor: Ami Appendix C - How DoKnox I Make Games? Appendix D - Guidelines for Developing Successful Games
Production Manager: Kari Brooks
Index
List Compositor: of Figures Diana Van Winkle, Van Winkle Design Group List of Tables
Artist and Cover Designer: Kurt Krames Indexer: Lynn Armstrong Manufacturing Manager: Tom Debolski Distributed to the book trade in the United States by Springer-Verlag New York, Inc., 175 Fifth Avenue, New York, NY, 10010 and outside the United States by Springer-Verlag GmbH & Co. KG, Tiergartenstr. 17, 69112 Heidelberg, Germany. In the United States, phone 1-800-SPRINGER, email
, or visit http://www.springer-ny.com. Outside the United States, fax +49 6221 345229, email , or visit http://www.springer.de. For information on translations, please contact Apress directly at 2560 9th Street, Suite 219, Berkeley, CA 94710. Phone 510-549-5930, fax: 510-549-5939, email , or visit http://www.apress.com. The information in this book is distributed on an "as is" basis, without warranty. Although every precaution has been taken in the preparation of this work, neither the author nor Apress shall have any liability to any person or entity with respect to any loss or damage caused or alleged to be caused directly or indirectly by
the information contained in this work.
.NET Game Programming with DirectX 9.0
ISBN:1590590511 by Alexandre Santos Ellen and Omnipotent To the funniest game of all: Real Life Lobão And toand its Great Designer
Hatton
About the Authors Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce
Alexandre Santos Lobão got his first computer in 1981, when he was interesting multimedia games using Managed DirectX 9.012, andand immediately started to create simple games programming in Basic. with Since Visual then,Basic computers .NET onhave Everett, evolved the latest massively, and so has he. Graduating Visual Studio. with a bachelor's version degreeof in Microsoft's computer science in 1991, he founded that same year with six friends a company that came to be known as a synonym for high-quality services in Brasilia, Brazil: Hepta Informática.
Table of Contents
.NET Gamehis Programming withinDirectX 9.0 Besides excellent work many software development areas, from financial to telecommunication, he Foreword never forgot his first passion, and has always worked as a nonprofessional game programmer. From 1997 Preface to 1999 he also worked at Virtually Real (http://www.vrealware.com), a virtual Australian amateur Introduction game programming company founded by Craig Jardine. Chapter 1
- .Nettrix: GDI+ and Collision Detection At the end 2000, Alexandre started searching new horizons and, leaving the company he helped to Chapter 2 -of .Netterpillars: Artificial Intelligence andfor Sprites
create, entered Microsoft as a consultant. Looking at the new and extremely interesting possibilities offered - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ by the .NET Framework, he decided to take everything he's learned over the last decade and apply it to Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio this new development platform. Chapter 3 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 - Magic Adventure Games, ADO.NET, and DirectShow Ellen Hatton is a KindergarteN.: computer science undergraduate at Edinburgh University. She was exposed to Chapter 7 - at Magic KindergarteN. II: Animation Techniques with and them Speech APIsince. Her first experience of computers a very early age and has been fascinated ever Chapter 8 games - .Netterpillars II: Multiplayer GamesDoom, and Directplay computer was playing Dread Dragon at which she quickly excelled at the age of 5. She's
been hooked D-iNfEcT: on games Multithreading, ever since. Nonrectangular Windows, and Access to -
Chapter 9
Nonmanaged Code Ellen Chapter is not only interested computers. Bonus Porting .Nettrixinto Pocket PC She skis frequently, amongst other sports, and enjoys general
student life theState bustling Appendix A - in The of PCScottish Gaming capital, Edinburgh. Appendix B - Motivations in Games
As her choice of degree suggests, Ellen still finds computers very interesting and is constantly looking for new challenges. This book is the latest.
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index About the Technical Reviewer List of Figures
David Jung has over ten years' programming experience with leading organizations such as Mullin List of Tables
Consulting, Johnson & Johnson, City of Hope National Medical Center, Moss Software, ARCO Products, and Ernst & Young. He has specialized in distributed application and data warehousing solutions over the Internet and intranets using Visual Basic, C#, and other Internet technology. Mr. Jung has coauthored an extensive array of books and articles on programming and debugging Visual Basic, Microsoft Outlook, Java, and other Internet solutions that have been published internationally. He frequently is a speaker at seminars and user groups discussing how Visual Basic, Java, C#, and Internet technology can be integrated into business solutions. He has published several Microsoft Windows utility programs that help track down and eliminate system crashes as well as help prevent script-based viruses from spreading on Windows-based computers. Two of his programs, DLL Checker and VBS Defender, were reviewed by PC World and were given an Editor's Choice award, and have been sold to users all over the world. Acknowledgments Alexandre Lobão To Kentaro Takahashi, the guy who helped me take my first steps in the computer graphics world, back at university about 15 years ago, and helped me with all my previously published works in this area. I think this is a late acknowledgement, but better late than never! To Homero Picollo, the best teacher at my university, who guided me through these first steps. To Craig Jardine, Jonty Bell, and all the guys from Virtually Real, who believed in my work even before
they had seen it!
.NET Game Programming with DirectX 9.0
ISBN:1590590511 Alexandre Santos Lobão and To Evali Gamarrabyand Keniston Rodrigues, whoEllen helped me take my first steps with DirectX.
Hatton
To Peter Blackburn, Apress who© believed 2003 (696 pages) in my dream, and to all the Apress guys who helped me to make it come true. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
To Tom Miller, the programming development with leader Visualfrom Basic the .NET Microsoft's on Everett, Managed the latest DirectX team, who always had the version Microsoft's Visual Studio. right answer for me, and of great patience. To Phillip Taylor, the managed DirectX program manager, and to all members of the Managed DirectX
Table Contents SIG,of who always supported me when I needed. .NET Game Programming with DirectX 9.0
To Igor Ripoll, who gave me invaluable logistics help, which made this book possible. Foreword Preface
To Igor Sinkovec and Waldivar Cesar, who helped me with their great graphics skills.
Introduction
Chapter 1 Shelley, - .Nettrix: GDI+ and Collision To Bruce Paul Sullivan, Geoff Detection Howland, and Sarbasst Hassanpour, who kindly gave me Chapter 2 - to .Netterpillars: Intelligence and Sprites permission publish theirArtificial own vision about game creation as appendices in the book. Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ To Ellen helped by translating my barely legible drafts to real chapters, and to David Chapter 4 Hatton, - River who Pla.Net: Tiledme Game Fields, Scrolling, and DirectAudio
Jung, who all the and increased theText book's quality as much as possible. Chapter 5 -reviewed River Pla.Net II: code DirectInput and Writing to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
To everyone who helped me in any way to create this book (so if you are not mentioned before, feel free to - Magic KindergarteN. II: Animation Techniques and Speech API include your name here!).
Chapter 7 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
And, most ofD-iNfEcT: all, to myMultithreading, family, who supported Nonrectangular me even Windows, when Iand wasAccess stealing to time from them to write this Chapter 9 Nonmanaged Code book. Bonus Chapter Porting .Nettrix to Pocket PC
Thanks A to -all of State you. of PC Gaming Appendix The Appendix B - Motivations in Games
Or, in good and loud Portuguese, "Muito Obrigado!! "
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Ellen Hatton Index
I also have a few acknowledgements to make: List of Figures List of Tables
To Alexandre for being the most understanding and talented person I've ever had the pleasure to work with. It was your ideas that made this book—not anyone else's. It's been fun working with you. To Peter Blackburn, you've been a constant source of support. You were the person who introduced me to this project, for which I am eternally grateful. There are too many people to thank you all individually, but you know who you are so thanks for everything. From a cup of tea to a friendly chat—it all helped. Also thanks to my family for getting me here in the first place and always encouraging me and my crazy ideas. Thanks again. Credits Figure 4-5, page 217: Sid Meier's Civilization®, Civilization®, and Civ® are U.S. registered trademarks. Sid Meier's Civilization® courtesy of Infogrames Interactive © 2002 Infogrames Interactive, Inc. All Rights Reserved. Used With Permission. Figure 6-2, page 350: Leisure Suit Larry is a trademark of Sierra Entertainment, Inc., and is used with permission. Figures 6-3,6-4, and 6-5, pages 351–352: Sam & Max Hit the Road® and The Secret of Monkey Island® © 2003 LucasArts Entertainment Company LLC & ™ or ® as indicated. All rights reserved. Used under
authorization. LucasArts and the LucasArts logo are registered trademarks of Lucasfilm Ltd. .NET Game Programming with DirectX 9.0
ISBN:1590590511 by Alexandre Santos LobãoMcGee's and EllenAlice™ Software Figures A-1 and A-2, page 597: American © 2000 Electronic Arts Inc. All rights Hatton reserved. Portions © 2000 Rogue Entertainment, Inc. All rights reserved. This product contains software Apress © 2003 (696 pages)Inc. Id Technology © 2000 Id Software, Inc. All rights reserved. technology licensed from Id Software, TheElectronic authors ofArts thislogo text and showAmerican how easy McGee's it can be to produce Electronic Arts, the Alice are trademarks or registered interesting multimedia using Managed DirectX 9.0 trademarks of Electronic Arts Inc. in thegames U.S. and/or other countries. Theand Rogue Entertainment logo is a programming with Visual Basic .NET on Everett, the latest trademark of Rogue Entertainment, Inc. version of Microsoft's Visual Studio.
Figure A-3, page 600: Quake® is a trademark of Id Software. Table of Contents
Figure A-4, page 600: Unreal Tournament ©1999–2001 Epic Games Inc. Created by Epic Games, Inc. in collaboration with Digital Extremes. Unreal and the Unreal logos are trademarks of Epic Games, Inc. All Foreword rights reserved. All other trademarks are the property of their respective companies. .NET Game Programming with DirectX 9.0 Preface
Introduction Figures A-5 and A-6, pages 602–603: Clive Barker's Undying™ © 2000 Electronic Arts Inc. Undying, EA Chapter GAMES 1 and - .Nettrix: the EA GDI+ GAMES andlogo Collision are trademarks Detection or registered of Electronic Arts Inc. in the U.S. and/or
other countries. All rights Artificial reserved. EA GAMES is Sprites an Electronic Arts™ brand. Chapter 2 - .Netterpillars: Intelligence and Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Figure C-1, page 617: Quake® is a trademark of Id Software.
Chapter - River II: DirectInput andNamco Writing Ltd., Text to Figure 5C-3, page Pla.Net 621: PAC-MAN® ©1980 AllScreen Rights Reserved. Courtesy of Namco Holding Chapter Corp. 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API Figure 8C-4, page 623: GALAGA® ©1980 Namco All Rights Reserved. Courtesy of Namco Holding Chapter - .Netterpillars II: Multiplayer Games and Ltd., Directplay
Corp.
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Figure C-5, page 624: GAUNTLET® DARK LEGACY™ © 1998–2000 Midway Games West Inc. GAUNTLET DARK LEGACY is a trademark of Midway Games West Inc.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Foreword.NET ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton
Ever since I built my first S100 Z80 PC kit, I was hooked. That was 1975. Twenty-eight years later, I still Apress © 2003 (696 pages) have very little life away from my "babies"—my array of systems. I use them to work, to write, to explore this text show how easy it can be to produce the outside world,The andauthors to play.ofI've written games and reviewed games, but mostly I've played games of all interesting multimedia games using Managed DirectX 9.0 and kinds. I've playedprogramming Adventure, Hammurabi, and .NET air traffic control the simulators with Visual Basic on Everett, latest on the Z80—with 48KB of RAM. More recently, I've had toofattend 12-step meetings version Microsoft's Visual Studio.to get over my addiction to Ages. Age of Mythology is my latest obsession. I only wish I had the source. It seems to have a pretty nasty memory/resource leak. Table of IContents When heard that Alexandre and Ellen were writing a book on gaming, I jumped at the chance to take an .NET earlyGame look.Programming When I heardwith thatDirectX the book 9.0 focused on Visual Basic, I was convinced that I wanted to read it
(and got cajoled into writing this foreword). It's been a long road for BASIC. I used (the other) Bill's BASIC Foreword on my Z80 system and even wrote CP/M systems software using the BASIC-80 compiler in the early Preface 1980s. BASIC has always been seen as a fun little language to write simple "toy" applications—something Introduction like the1"Easy-Bake language with a small lightbulb for heat. Visual Basic 1.0 changed a lot of Chapter - .Nettrix: Oven" GDI+ and Collision Detection minds, 2but-Visual Basic 5.0 and itsIntelligence "real" compiler changed a lot more. Visual Basic .NET (which I fondly Chapter .Netterpillars: Artificial and Sprites
call "Visual- Fred" due to its lack of similarity to any previous version of Visual Basic) is a deadly serious Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ full-featured development tool. It's suitable for authoring virtually anything. No, I would not write a device Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio driver with Visual Basic .NET, but I'll bet you could. It's a great choice for serious developers because it's Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen so easy to learn and use. For MBASIC-80 developers, it will be somewhat of a challenge to learn, but for Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Visual Basic folks, it will take no time at all to come back up to speed (so to speak). Chapter 3
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter .Netterpillars Games and Directplay DirectX8(in-my opinion) isII: theMultiplayer new de facto "Windows" interface of the gaming industry. In the early days, no computer D-iNfEcT: would sell Multithreading, (no matter how Nonrectangular technically superior Windows,it and was)Access if it didn't to run Lotus 1-2-3. That's Chapter 9 Code because theNonmanaged application software was so closely tied to the hardware. When an application shipped in the Bonus .Nettrix to Pocket PC printer or you couldn't print and drivers for your video card or you DOS Chapter world, it Porting had to have drivers for your Appendix - The of PC Gaming couldn't Arun the State application at all. In those days, game companies got in bed with the video card Appendix companies B - and Motivations wrote straight in Games to their newest hardware. There was only a slim chance a game would work
with some card. Windows changed some of that. It standardized video management, printing, Appendix C -other How Do I Make Games? memoryDmanagement, and more to help application Appendix - Guidelines for Developing Successful Gamesdevelopers write just applications and leave all of the hardware worries to Microsoft and device driver developers. The game folks found that Windows simply Index gotofinFigures the way; it wasn't nearly fast enough for anything except solitaire—and that was sluggish. When List DirectX arrived, a new dawn appeared for the game developers. Now they had a much faster and generic List of Tables way to write to the hardware and not worry (so much) about performance. Now (nine versions later) DirectX games are pervasive. They're fast, fun, easy to install (and uninstall), and easy to write, maintain, and support.
As far as the technical content of the book, in case you're wondering, I took an extra close look at Chapter 6 where Alexandre and Ellen touch on ADO.NET. I think their approach to data access is fine. It's not that tough when you don't have to worry about more than a single user and more than a few thousand rows, but they don't lead you astray. Okay. I don't make a living writing games. I'm not that smart, and I couldn't talk my spouse into doing something that's challenging and fun but would not return me enough to buy groceries. My focus is Visual Basic, data access, and SQL Server. I like playing games, but I would like so much more to be able to write my own. I expect the easy-to-read tutorial style that Alexandre and Ellen use will make that very easy for both of us—amateur and pro alike. Enjoy. William R. Vaughn Microsoft MVP and author of ADO.NET and ADO Examples and Best Practices for VB Programmers, Second Edition President, Beta V Corporation (http://www.betav.com) Redmond, Washington
Preface
.NET Game Programming with DirectX 9.0
ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton This book is intended to fill a gap that exists in books about game programming: Some are too basic, and Apress © 2003 (696 pages)
some are too advanced, so intermediate programmers who want to create something new can't find anything to meet The theirauthors needs.of this text show how easy it can be to produce
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest The main idea of version this book is this: If you can Studio. do it the easy way, do it the easy way. Of course, we explore of Microsoft's Visual
some very advanced concepts, like voice generation and recognition, multiplayer games, and the basics of 3-D game creation. However, we always look for the simplest way to do something. And if there's no easy Table Contents way,of then we just create some basic classes that do the dirty work, and create everything else over these .NET classes. Game Programming with DirectX 9.0 Foreword
The whole book is designed to be read in a continuous way. In Chapter 1, we start by creating a very simple game while presenting the basics of collision detection. Chapter 2 shows how to build a new game, Introduction using the concepts presented in Chapter 1 and adding new explanations and examples about artificial Chapter 1 - .Nettrix: GDI+ and Collision Detection intelligence in games. Preface
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 - Managed DirectX Steps: Basics andand DirectX vs. GDI+ In the following chapters, weFirst continue toDirect3D build new games explore new topics relating to game Chapter 4 - River Pla.Net: Game Fields,creation, Scrolling,scrolling and DirectAudio programming, such as theTiled basics of sprite games, adventure games, multiplayer Chapter features, 5 voice - River generation, Pla.Net II:porting DirectInput a game and to Writing Pocket Text PC, toand Screen much more. We start with the basics and
increase complexity as we goAdventure along, soGames, that by ADO.NET, the time you to the advanced topics, you have all Chapter 6 the - Magic KindergarteN.: andcome DirectShow the background need to gain most from them. and Speech API Chapter 7 - Magicyou KindergarteN. II:the Animation Techniques Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
But there's one more thing that makes this book unique: our discussion about several nonprogramming D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 topics related to game creation—for example, how to design good character movement, the history of Nonmanaged Code adventure games, and how to create an adventure game from a basic storyline. Bonus Chapter Porting .Nettrix to Pocket PC Appendix - The State of PC Gaming We don'tA restrict ourselves to showing only advanced game programming techniques, like DirectX and the Appendix B Motivations Games Speech API. We teach in you some simple tricks that don't require a lot of expertise, like how to control Appendix C - How Do I Make Games? simple dialog in adventure games, using data from a Microsoft Access database, or how to create a Appendix D - Guidelines fortoDeveloping nonrectangular window add some Successful extra spiceGames to a game's screens. Index
Although we don't explore all the details about managed DirectX 9.0, this book is a very good starting point List of Figures for of Managed List Tables DirectX 9.0 programming because we delve into the basics of every DirectX
component—Direct3D, DirectSound, DirectMusic, DirectPlay, DirectInput, and DirectShow—creating reusable classes that will make it easier to use each of these components. We also discuss other programming topics apart from DirectX, including ADO.NET, Speech API for voice generation, GDI+ for creating simple games, programming for Pocket PCs with the .NET Compact Framework, and creating multithreading games. Since we show you how to create a set of reusable classes throughout the book, after finishing the book you'll be able to create your own games much more easily by simply sticking these classes together. This book is also a good starting point for those who want to understand the basics of .NET programming, but it is NOT intended to teach .NET programming on its own. Of course, we talk about many important .NET concepts, and every new concept in Visual Basic .NET programming is explained, but it's not our aim to write an exhaustive explanation of all that VB .NET has to offer. Nor is this book intended to provide a route to the professional game programming world, since we do not go deep enough into some essential aspects professional game developers need to know. However, you can think of this book as a first step into this world, since we do provide insights into important concepts such as the need to create a good game project and organizing the game's team, as well as appendixes written by professionals from the game industry that serve as guides to game creation.
.NET Game Programming with DirectX 9.0 Introduction ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
.NET—A Whole New Game Horizon The authors of this text show how easy it can be to produce
For those who have interesting been inside multimedia a cavegames for theusing last 2Managed years, .NET DirectX is Microsoft's 9.0 and new paradigm for creating programming Visual Basic .NETany on site Everett, theWeb latestto offer and use services, and the next generation of Internet with programs, allowing on the of Microsoft's Visual Studio. joining the effortsversion from programmers around the world to make things better. But .NET is much more. You can create stand-alone programs with it (as we'll see in this book), and you can create programs targeted at many different platforms. For example, if your program runs in a browser, .NET Game Programming with DirectX 9.0 it'll appear using the full functionality offered by the browser. If instead it is running on a mobile device, Foreword such as a handheld computer, it'll use only the functionality offered by that device. We can expect to see Preface .NET support for many new devices using different user interfaces (like voice recognition) to show up in Introduction the next few years.
Table of Contents
Chapter 1
- .Nettrix: GDI+ and Collision Detection In short, can say that .NET is the next big step in home computing. First, the PC became a standard for Chapter 2 we - .Netterpillars: Artificial Intelligence and Sprites
home and computers. ThenSteps: we saw Windows offering the new for programmers and Chapter 3 -office Managed DirectX First Direct3D Basics and DirectX vs.standard GDI+ users, with graphical interface and Fields, the mouse as a and newDirectAudio input device. Now, we have an open door to Chapter 4 - aRiver Pla.Net: Tiled Game Scrolling, many new and user interfaces, and and,Writing most importantly, interaction between programs, allowing Chapter 5 -devices River Pla.Net II: DirectInput Text to Screen
programmers to build over previously created services and give the end user more sophisticated services - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow every time, with less programming and higher quality.
Chapter 6 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 -the .Netterpillars II: Multiplayer and Directplay Of course, .NET Framework is still Games taking its first steps, but it's already worth a closer look for anyone D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to seriously in programming in general, particularly game programming. Chapter 9 interested Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
Why Use .NET?
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Certainly there are many good reasons to use .NET besides the fact that it's a new programming paradigm that will probably take on the world in the next few years. Let's just review some of them:
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index
is multiplatform: Although Java had promised this before, and sadly didn't make it, .NET had a List of.NET Figures bigger industrial commitment, not only by Microsoft and its partners, even before the launch of the final version of Visual Studio. One example: There are many initiatives to make a .NET JIT (just-intime) compiler in Linux and other operating systems. Oh, yes, and there's another advantage over Java when running on a Web site: The .NET programs are just-in-time compiled before they run, and that means that they run in machine-native code (not interpreted), which makes for better performance. Another interesting point is that the compiled program is stored in memory, so the next executions don't have to pass to the compiler unless the computer is turned off or needs to free the memory used by the program.
List of Tables
.NET is NOT just a new programming environment: It's a whole new framework of applications and services, many of them already released by Microsoft, and many others to come from Microsoft and other companies. .NET is service based: There are many servers that expose special features that we can use, and there are a huge collection of services coming from Microsoft and many other companies. What does this mean for game developers? For example, do you want to make your game speak, or understand what the player says? Do you need to add multiplayer features? Do you want to create a 3-D texturemapped environment? Well, some services already do all of this and more. Why code again and again if someone has already done it? .NET is multilingual: You can write your .NET program in any language supported by the Visual Studio environment—right now, that means Visual Basic, Visual C#, Visual C++, FORTRAN, Visual
J#, and COBOL, among others. Microsoft created a single and open environment to run it all, so you .NET Game Programming with DirectX 9.0 can write your programs in any language in the same programming console. Other languages are ISBN:1590590511 Alexandre by Santos and Ellen already beingbydeveloped otherLobão companies: APL, Pascal, Eiffel, Haskell, ML, Oberon, Perl, Python, Hatton Scheme, Smalltalk. Just choose the one you like best, or create your own! Apress © 2003 (696 pages)
authors of this easy canextensive be to produce Of course, many The other reasons existtext for show usinghow .NET, likeit the XML support or the enhanced data using Managed DirectX and access features. interesting When you multimedia start codinggames with Visual Studio, you'll see9.0 a lot more: The environment is even programming with Visual Basic .NET on Everett, the latest cleverer than previous versions, and helps the programmer a lot. It makes game creation a real pleasure, version of Microsoft's Visual Studio. because you can concentrate on what you want your game to do, not how to make it. Table of Contents
Why Use Visual Basic?
.NET Game Programming with DirectX 9.0 Foreword Until Visual Basic 4.0, the code generated by the compiler was in fact a pseudocode, interpreted by a Preface special DLL at execution time. The performance for some tasks was very poor, but we could already make Introduction some simple games on it, if the graphics weren't very demanding. Chapter 1 - .Nettrix: GDI+ and Collision Detection
In Visual 5.0, Microsoft brought in part of theSprites Visual C++ development team to create a native-code Chapter 2 Basic - .Netterpillars: Artificial Intelligence and
compiler. The performance increase was astonishing: We could see some benchmarks for floating-point - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ calculations where the VB code performance was almost the same as VC++, but the graphical operations Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio were still much slower than in C++. Chapter 3 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 Basic - Magic KindergarteN.: Adventure ADO.NET, andon DirectShow In Visual 6.0, all the internal routines Games, for drawing controls screen and many of the features were Chapter 7 -to Magic KindergarteN. II: Animation Techniques andwe Speech refactored aim for better performance. With this version, couldAPI already create somewhat Chapter 8 - .Netterpillars II:COM Multiplayer Games Directplay sophisticated games using interfaces to and access DirectX features. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Now, we have Visual Studio .NET. As we saw before, Visual Studio .NET is a multilanguage environment, Nonmanaged Code
whichChapter means,Porting besides other to things, that Bonus .Nettrix Pocket PCall languages share the same compiler. Therefore, there'll be a little difference, any of at PC all,Gaming in the performance of this compiler for each language. Appendix A - The if State Appendix B - Motivations in Games
It's interesting to consider an interview with one of the Doom creators that appeared in a games magazine some years ago. When it was released, Doom was simply the best game ever from the technical point of Appendix D - Guidelines for Developing Successful Games view of creating a 3-D texture-mapped environment. And this guy basically said that Doom was proof to all Index assembly "pin-heads" that everything didn't have to be coded in assembly in order to achieve the best List of Figures because the game had just two assembly routines: one that drew a point on screen, and performance, List of Tables one that drew a line. Everything else was written in C. Appendix C - How Do I Make Games?
Time has passed. When the first reviewers looked at this book, they told me, "Game programming in Visual Basic? Using .NET Framework? Are you sure?" They thought Visual Basic performance could be a real problem, and that .NET Framework was designed only to create Web services. But they were wrong. Just look at games like the X-COM series, or the SIMCity series. We don't see anything that we can't do in Visual Basic. They aren't graphically intensive games. For fast-action shooters like Quake, we confess that Visual Basic won't be the best choice for programming for a while. But for other sophisticated games, if you can do them with a simple language like VB, why use assembly or C? Just think about the simplicity of coding and debugging, and you'll see there's no other choice. Even some hardcore C++ programmers gave us very good feedback about this book, telling us how they were astonished with the ease of creating games in Visual Basic that still have acceptable performance. But you don't have to just take our word for it. Just read the rest of the book, and you'll see for yourself.
A Game Starts with a Good Idea Although the games released nowadays are more and more graphics intensive, the main point in a game is sometimes forgotten: the playability. We see games with breathtaking graphics, amazing cut-scenes, and 3-D worlds to make your eyes pop out, but many of them are really annoying to play. Even when a game's responsiveness is okay, sometimes the gameplay isn't clear or isn't fair.
What about playing anGame old Pac-Man? With allwith these gorgeous .NET Programming DirectX 9.0 games around, Pac-Man and the earlier versions of Marioby Brothers on Nintendo are still successes withISBN:1590590511 kids. Alexandre Santos Lobão and Ellen Hatton
We aren't here toApress tell you to forget everything and get back to basics. Instead, remember that a good © 2003 (696 pages) game always starts with a good idea, and sometimes that's enough.
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and One of the most cloned gameswith ever, Tetris, was designed by a the single man, a Russian programmer. It's programming Visual Basic .NET on Everett, latest still interesting to version play after all these years, of course, we have a Tetris clone here too—our version of of Microsoft's Visualand, Studio.
a "Hello World" program in the first chapter. Table You of could Contents say that Tetris is one in a million, and we'd agree. But if you were to say that creating a good
game by yourself is onlywith possible if it's .NET Game Programming DirectX 9.0as simple as Tetris, then we'd have to disagree. Older guys will remember Another World, a game that has a sequel called FlashBack. The game had very good graphics Foreword and sound for its time, with very nice character animation and various cut-scenes that completed the game Preface story by showing the characters and a fantastic world from many different points of view. Well, a single Introduction person,1a French programmer, designed this game. Chapter - .Nettrix: GDI+ and Collision Detection Chapter 2
.Netterpillars: Artificial Intelligence and Sprites Today we -can see many sites on the Web with games from amateur game programmers. Some of them
Chapter 3 good, - Managed DirectX First graphics Steps: Direct3D Basicsand, andmost DirectX vs. GDI+ are really with high-quality and sound; important of all, almost all are very Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio playable too, maybe because they were designed by people who love to create and play games but don't Chapter 5 urge - River Pla.Netmoney. II: DirectInput and Writing Text to Screen have the to make Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow In this book, we'll see many tips II: and tricks that will help anyone to design Chapter 7 - Magic KindergarteN. Animation Techniques and Speech API his or her own games alone.
However, you can count someoneGames to helpand you, do. Chapter 8 if - .Netterpillars II:on Multiplayer Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 there's After all, more to a game than just a good idea. ... Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
A Game Is More Than Just a Good Idea
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Although a game must start with a good idea, there is a lot more to the game programming world than our humble minds can imagine. Let's look at some points we must keep in mind when we start our game Appendix D - Guidelines for Developing Successful Games project: Appendix C - How Do I Make Games? Index
List of Figures List ofMusic: Tables Although we can always make a game using only bleeps and bloops, good background music
and nice sound effects for game actions (shooting, dying, earning bonus points, etc.) do make our games better. Even if we don't plan to have a music expert on our staff, we can't forget that it'll take a lot of time to look for music with the correct ambiance and the best sound effects among the millions we'll find on the Internet or in CD libraries. Drawing: It's not good practice to use graphics ripped off from someone else's game, because our game will lack originality and we can also be prosecuted. Since not everyone can draw anything better than a square house and a smiley sun, we'll want a good artist (or several of them) on our game team. Colors: Coloring things on the computer is very different from coloring it on paper. If our artists can't color using a graphics tool, we'll need someone who can. Animation: Creating animated graphics is slightly different from creating static ones. Almost everyone can draw a nice tree, for example, but to draw a walking man or a flying bird demands someone with animation experience. Even when our games don't use animated sprites, don't forget that we may need an animated introduction or cut-scenes. Code: Well, without this one we would be reading a board game book.
Level design: The level designers are the ones who'll always be working to ensure optimum .NET Game Programming with DirectX 9.0 gameplay and the most enjoyable playing experience for players.
ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Quality assurance: Apress © If 2003 we(696 can't pages) afford to have a very good quality assurance team, we're better off not
bothering to make games. buggy gamehow is byeasy far the worst thing that can happen in a game The authors of A this text show it can be to produce interesting multimedia games using Managed DirectX 9.0 and company's profile. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Project management: Working with many people with different skills and personalities requires an organized way to get the best from each of them. Even when we are working alone, we mustn't Table of Contents underestimate the importance of a good project: If we don't set some milestones to control our .NET Game Programming with 9.0and never see any good results. It's far beyond the scope of this project, we may work onDirectX it forever Foreword book to teach you how to manage a project, but we strongly suggest you take a look at some stuff on Preface this topic, if you've never had the opportunity of working with an organized team. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Etc.: There'll be lots more too, but in general we must be ready to deal with any new and unexpected - .Netterpillars: Artificial Intelligence and Sprites problems.
Chapter 2 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 of - River Pla.Net: Tiled Game Fields, Scrolling,isand DirectAudio The task creating a commercial game nowadays anything but simple. The time when the "lone wolf" Chapter programmer 5 - River could Pla.Net create II:aDirectInput new hit andand even Writing get rich Textwith to Screen it is most certainly over. Nevertheless, let's keep
one thing mind:KindergarteN.: This book is for those who love game design, will be happy with making games just Chapter 6 in - Magic Adventure Games, ADO.NET, and who DirectShow to have7the- Magic pleasure of seeing people enjoy their ideas. Ifand youSpeech want to make professional games, or if you Chapter KindergarteN. II: Animation Techniques API want to8learn DirectX or .NET, this bookGames is a really good starting point, but there's a lot more you need to Chapter - .Netterpillars II: Multiplayer and Directplay study beforeD-iNfEcT: entering Multithreading, the game industry. Nonrectangular Windows, and Access to -
Chapter 9
Nonmanaged Code
As we have seen, it takes a lot of hard work and coordinated effort to make a blockbuster game nowadays, but don't be scared off by the size of the mountain we are about to climb. Remember: Maybe Appendix A - The State of PC Gaming your game will be the next Pac-Man, Tetris, or Flight Simulator. Bonus Chapter Porting .Nettrix to Pocket PC Appendix B - Motivations in Games
Appendix C -inHow I Make Games? Just keep mindDoone thing: A game starts with a good idea! Appendix D - Guidelines for Developing Successful Games Index
How to Read This Book
List of Figures
List of book Tablesaims to be a practical guide for game programming, and to get the most out of it, we suggest This
that you start each chapter by running the chapter's sample game from the CD-ROM that comes with this book. Open the project in Visual Studio .NET, and compile and run it. Play for a while, looking at the details of the game, so that when you start reading each chapter you'll know what the chapter is about. To make it easier to understand the main concepts in each chapter, we have divided the chapters into five main sections. Next we'll describe the parts of each chapter.
Introduction and Technical Background At the beginning of each chapter, we have a little introduction that presents the chapter's sample game and the ideas we'll explore in the chapter, and one or more sections presenting specific information about the technical background needed for the chapter's sample game. For example, in Chapter 4, we introduce DirectInput and create a scrolling game, so we have sections describing what DirectInput is and how to create reusable classes to include DirectInput features, plus sections describing the ideas behind creating a scrolling game, and technical tips to follow when creating such a game.
The Game Proposal In a commercial game, the game proposal is the document we'll show to everyone, even discuss with our kids, to achieve a clear understanding about what the game will really be. If everyone agrees that it'll be a great game, then we advance to the next step. If not, then we'll improve it until we reach the desired result.
In this book, we are working with very simplified game proposals that deal with the minimum amount of .NET Game Programming with DirectX 9.0 information needed for a clear understanding of the sample game. A real game proposal follows the basic ISBN:1590590511 by Alexandre Santos Lobão and Ellen rules of creating ordinary Hatton projects, showing the details gathered in the early analysis and user interviews. Apress © 2003 (696 pages)
The Game Project The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
While the game proposal tells with us how theBasic game.NET will on work, including artificial intelligence, user interaction, programming Visual Everett, the latest and graphical styling, in aoflanguage that anyone can understand (especially the sponsor who is paying the version Microsoft's Visual Studio. game development team), the game project document includes the technical mumbo-jumbo that will guide the developing team through the code phase. Again, in this book we'll deal with very simplified game Table of Contents projects, because even with the simplest games we must have a project. .NET Game Programming with DirectX 9.0 Foreword The Coding
Phase
Preface
This is where we'll show the main parts of the code, including highlights of what is new in the .NET world. Introduction Instead1of -showing pages ofDetection code, we'll show only the essential parts that are instrumental in Chapter .Nettrix:pages GDI+ and and Collision
the understanding of the game mechanics, along with explanations about each code listing. The full code - .Netterpillars: Artificial Intelligence and Sprites is on the accompanying CD-ROM.
Chapter 2 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Final Touches
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter - Magic KindergarteN.: Adventure Games,have ADO.NET, DirectShow When a6 game is being developed, lots of people ideas.and Some of these ideas are very practical and Chapter - Magic KindergarteN. II: Animation Techniques and Speech APIidea will be implemented in a future easy to7implement, and others are not so. The team must decide if an Chapter version8of -the .Netterpillars game or if II: implementation Multiplayer Games of that and idea Directplay is worth a delay in the schedule in order to achieve a
better game. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to -
Chapter 9
Nonmanaged Code In each chapter, we have included some Bonus Chapter Porting .Nettrix to Pocket PC of these ideas in the "Adding the Final Touches" section; and like
in real-life some of Gaming the ideas are implemented, and others are just suggestions for you to try and Appendix A -games, The State of PC further improve the game on your own. Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Summary
Appendix D - Guidelines for Developing Successful Games Index In the last part of each chapter, we'll look back at what we have discussed to help you check if you have List of Figuresthe chapter's main concepts, or if you need to go back and reread something. understood List of Tables
In the next section, we'll preview the sample games and the main ideas covered in each of the chapters.
Book and CD-ROM Contents In this book, we'll create five different games spanning nine chapters and a bonus chapter at the end. Each game will have two versions, developed in two different chapters. For example, the first version of our little adventure game, Magic KindergarteN., will be created in Chapter 6, which will explore DirectShow and ADO.NET. A second version of this game is featured in Chapter 7, where we'll include voice generation by using the Speech API. There are a couple exceptions. In Chapter 9, we'll create a very simple game without including a second version in this book. Chapter 3 is dedicated to introducing DirectX and Direct3D, presenting some uncomplicated samples to make the explanations clearer. As for the book's CD-ROM, it is organized in a manner that matches the book's organization: It has one directory per chapter that contains the chapter sample game. In the Chapter 8 directory we have two samples, so there is a separate sub-directory for each of them. The CD-ROM programs were created and tested with DirectX 9.0 and Visual Studio 2003 (code-named Everett) Beta 1. There are some known issues when running the games with Everett on reference rasterizers of laptops that will probably be fixed in the final versions. Any updates on the code will be available for download at the Apress site (http://www.apress.com). The complete DirectX 9.0 is also available in the CD-ROM, under the DirectX directory.
In the next sections, weGame give aProgramming brief description of the contents .NET with DirectX 9.0 of each chapter. by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Chapter 1—.Nettrix: GDI+ and Collision Detection Hatton Apress © 2003 (696 pages)
In the first chapter, we introduce the concept of collision detection in games, present simple algorithms to The authors of this text show how easy it can be to produce manage the detection of collision between objects a game,DirectX and introduce interesting multimedia games usingin Managed 9.0 and basic concepts about the GDI+, the new graphical librarywith used by the .NET Framework perform programming Visual Basic .NET on Everett,tothe latest simple graphical operations. version of Microsoft's Visual Studio.
In this chapter, we create a Tetris clone called .Nettrix to illustrate the use of these concepts. Table of Contents Chapter 2—.Netterpillars:
Artificial Intelligence and Sprites
.NET Game Programming with DirectX 9.0
Here we examine the concept of object-oriented programming, along with a glossary of related terms. We Foreword also explain the idea of creating a library of game classes, which can be used in further game Preface developments to improve the game quality and the game project schedule. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection In this chapter, we also provide a brief introduction to artificial intelligence in games, presenting some
Chapter 2 problems - .Netterpillars: Artificial Intelligence Sprites classical we need to deal with in ourand games along with some suggestions about how to solve Chapter 3 Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ them. Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio The chapter's sample game, .Netterpillars, is a Snakes clone that explores the concepts presented in the Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen
chapter. we KindergarteN.: create the first Adventure reusable class of this book—a Chapter 6 Here - Magic Games, ADO.NET, andGDI+-based DirectShow sprite. Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter- 3—Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ .Netterpillars II: Multiplayer Games and Directplay
Chapter 8
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter Chapter 9 3 -presents Managed DirectX 9.0, exploring the Direct3D basics such as the use of matrix Nonmanaged Code
transformations, transparent texturing, and colored lights. Here we also discuss how to decide which graphics library (DirectX or GDI+) to use depending on the game type.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Appendix B - Motivations Games In this chapter, we haveinno game, just a simple application in which we'll exercise each of this chapter's Appendix C How Do I Make Games? concepts. Appendix D - Guidelines for Developing Successful Games
Chapter Index
4—River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
List of Figures
In Chapter 4, we discuss the creation of scrolling games, exploring the possibilities of scrolling effects and presenting some technical tips on how to create such games. We also discuss the use of tiled game fields in games and demonstrate some tricks to help you create better tiles.
List of Tables
Using the Direct3D concepts presented in Chapter 3, we create two new classes for our game library that will be used in almost all of the later chapters: a Direct3D-based Sprite class and a Direct3D-based GameEngine class. We also explore the basics of DirectSound and DirectMusic, creating two extra classes that will help us to add sound effects and background music to our games. Using the classes and concepts discussed in this chapter, we create a River Raid clone called River Pla.Net.
Chapter 5—River Pla.Net II: DirectInput and Writing Text to Screen Here we look at the basics of DirectInput, the DirectX library used to manage input devices, including how to use joystick force-feedback features and creating three simple classes for our library that control mice, keyboards, and joysticks. We also introduce the use of fonts in our games by creating a new class that will help us to write on screen. With the newly created game classes, we improve the River Pla.Net game to include a status line and joystick control and add new river obstacles that trigger the force-feedback features.
Chapter 6—Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
In Chapter 6 we briefly trace the evolution of with adventure games .NET Game Programming DirectX 9.0 and provide tips for you to follow when creating games of this genre. ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton
We present the managed libraries that give us access to basic DirectShow features, which allow us to play Apress © 2003 (696 pages) streaming media, like videos and MP3 files, and we create a class to help us play videos in our games. The authors of this text show how easy it can be to produce
interesting multimedia games using Managed DirectX 9.0 and We also give a very simple introduction to data access using ADO.NET—just enough to help you read the programming with Visual Basic .NET on Everett, the latest chapter's sampleversion game data. of Microsoft's Visual Studio.
In this chapter, we illustrate the concepts learned by creating a very simple adventure game with five screens, some action verbs, and a basic inventory control. Table of Contents .NET Game Programming with DirectX 9.0
Chapter Foreword
7—Magic KindergarteN. II: Animation Techniques and Speech API
Preface
Here we discuss animation techniques while presenting some samples and simple tricks that can help improve a game's animation.
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter We also 2 introduce - .Netterpillars: the Speech Artificial API, Intelligence the application and Sprites programming interface used for speech recognition
and generation, and create simple game class Basics that will allow us tovs. include Chapter 3 - Managed DirectX aFirst Steps: Direct3D and DirectX GDI+ voice generation in our games.4 Chapter
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Using the concepts presented in this chapter, we create a second version of the Magic KindergarteN. Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow game, including dialogs between game characters and voice generation, with associated mouth Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API animations that are dynamically generated according to the sounds of speech. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter Chapter 9 - 8—.Netterpillars II: Multiplayer Games and DirectPlay Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PCassociated with creating a multiplayer game, and present a list of In Chapter 8, we discuss the challenges Appendix A - The State of PC game Gaming tips compiled from various development teams. We look at DirectPlay, the DirectX library used to Appendix B - Motivations Games add network support to in our games, and include a new class in our library that can be used to add Appendix multiplayer C - features How Do Ito Make our Games? games in an easy way. Appendix D - Guidelines for Developing Successful Games
Using the class we just created, we implement a second version of .Netterpillars, the game created in Chapter 2.
Index
List of Figures List of Tables
Chapter 9—D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code Chapter 9 explores various concepts that can help add some extra spice to our games: the use of multithreading, the creation of nonrectangular windows, and access to nonmanaged code, like the old Windows' APIs. With these concepts, we create a very simple multithreaded game, called D-iNfEcT, which generates lots of germs on your screen that must be caught before time is up. This chapter illustrates how to create addictive games that can be easy and fun.
Bonus Chapter: Porting .Nettrix to Pocket PC In this bonus chapter, we discuss the problems we face when porting games to different devices, and present the .NET Compact Framework. Using these concepts, we create a second version of our Tetris clone by porting the sample game created inChapter 1 to run on a Pocket PC.
Appendixes In order to give you a sense of what professional gamers think about game creation, we have included as appendixes articles from four professionals who already work in the game industry:
"The State of PC Gaming," by Paul Sullivan
.NET Game Programming with DirectX 9.0
Alexandreby Santos Lobão and Ellen "Motivations by in Games," Sarbasst Hassanpour
ISBN:1590590511
Hatton "How Do I Make Apress Games?—A © 2003 (696 pages) Path to Game Development," by Geoff Howland The authors of this text show how easy it can be to produce
"Guidelines for Developing Successful Games," by Bruce Shelley interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
These guys kindlyversion let us of republish theirVisual articles, and we hope you enjoy them as much as we did. Microsoft's Studio. Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Chapter .NET 1: .Nettrix: GDI+ and Collision Detection ISBN:1590590511 by Alexandre Santos Lobão and Ellen
Overview
Hatton Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce
In this chapter weinteresting examine the multimedia basic concepts games using of GDI+, Managed the extended DirectX 9.0 library and for native graphic operations programming with one Visual .NETimportant on Everett, the latest on Windows systems, and discuss ofBasic the most aspects of game development: the collision version of Microsoft's Visual Studio. detection algorithms. Although game developers use GDI+ functions to draw images on screen, collision detection algorithms are responsible for making the drawings interact with each other, allowing a program to know when an image is over another one and to take the appropriate action, such as bouncing a ball Table of Contents when it hits a wall. .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 1-1: .Nettrix, this chapter's sample game To accomplish these goals and illustrate these concepts, we'll be creating a game called .Nettrix. "Hello World" is always the first program that's written when learning a new programming language. When learning to program games, Tetris is considered to be the best game to try first. In this simple game we can see many basic concepts at work—for example, basic graphic routines, collision detection, and handling user input. To begin, we'll look at the basic GDI+ concepts and examine the idea of collision detection algorithms, so you'll have the necessary technical background to code the sample game for this chapter.
Game Programming with DirectX 9.0 Basic GDI+.NET Concepts by Alexandre Santos Lobão and Ellen
ISBN:1590590511
HattonSDK class-based application programming interface (API) for 2-D graphics, GDI+ is the new .NET Apress © 2003 (696 pages) imaging, and typography. The authors of this text show how easy it can be to produce
With some substantial improvements theusing old GDI, including better and the capacity to interesting multimediaover games Managed DirectX 9.0 performance and programming with is Visual Basic .NETThe on Everett, the latest run even on a 64-bit system, GDI+ worth a look. new features in GDI+ are discussed in the following version of Microsoft's Visual Studio. sections.
Path Gradients
Table of Contents
.NET Game Programming with DirectX 9.0
Path gradients allow programs to fill 2-D shapes with gradients, with great flexibility, as shown in Figure 1Foreword 2. Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Figure path gradients Chapter 7 - 1-2: MagicUsing KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Alpha Blending Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
GDI+ works withState ARGB colors, which means that each color is defined by a combination of red, green, Appendix A - The of PC Gaming
and blue values, plus an alpha value relating to its degree of transparency. We can assign a transparency value from 0 (totally transparent) to 255 (opaque). Values between these two make the colors partially Appendix C - How Do I Make Games? transparent to different degrees, showing the background graphics, if any are present. Appendix B - Motivations in Games
Appendix D - Guidelines for Developing Successful Games
Index In Figure 1-3 we have a rectangle with different degrees of transparency; if we had an image below it, we List of Figures could see it, just like looking though glass. List of Tables
Figure 1-3: Changing the alpha from 0 to 255 in a solid color bitmap
Cardinal Splines Cardinal splines allow the creation of smooth lines joining a given set of points, as shown in Figure 1-4.
Figure 1-4: Creating a smooth curve that joins points with a spline As we can see, the spline curve has fixed starting and ending points (in Figure 1-4, the points marked 1 and 4), and two extra points that will "attract" the curve, but won't pass through them (points 2 and 3).
Applying Transformations towith Objects a 3×3 Matrix .NET Game Programming DirectX Using 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Applying transformations Hatton (rotation, translation, or scale) is especially useful when dealing with a sequence of transformations, as they speed up performance. A sample of some transformations is shown in Figure Apress © 2003 (696 pages) 1-5. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Figure 1-5: Applying a rotation and scale transformation over a figure Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
- .Netterpillars: Artificial Intelligence and Sprites Antialiasing
Chapter 2 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Antialiasing is thePla.Net: smoothing graphics, avoiding a stepped look when, for example, a bitmap is enlarged. Chapter 4 - River TiledofGame Fields, Scrolling, and DirectAudio
An image shown in Figure 1-6. Text to Screen Chapter 5 exemplifying - River Pla.Netthis II: is DirectInput and Writing Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Figure 1-6: Applying antialiasing to an image
Appendix D - Guidelines for Developing Successful Games IndexNote In this book, we'll show examples of the first two new GDI+ features: path gradients in this List of Figures chapter and alpha blending in the next. There are many code examples for the other GDI+ List of Tables features in the .NET Framework SDK.
Game Programming with with DirectXa9.0 Performing.NET Graphic Operations Graphics Object by Alexandre Santos Lobão and Ellen
ISBN:1590590511
When using GDI+, Hatton the very first step always is to create a Graphics object, which will help us to perform graphics operations. Apress The© 2003 Graphics (696 pages) class provides methods for drawing in a specific device context. The authors of this text show how easy it can be to produce
There are four ways to attainmultimedia the correct graphics withDirectX the e parameter received in the Paint interesting games usingobject: Managed 9.0 and programming with Visual Basic .NET on Everett, the latest event, from a window handle, from an image, or from a specified handle to a device context. There's no version of Microsoft's Studio. we'll use each one depending on our program needs. real difference among these different Visual approaches; For example, if we are coding our drawing functions on the Paint event of the form, we'll use the e parameter; but if we are coding a class to draw on a form, we'll probably want to use a window handle to Table of Contents create the graphics object. We discuss each method in the sections that follow. .NET Game Programming with DirectX 9.0 Foreword
Creating a Graphics Object with the e Parameter
Preface
Introduction
In this case, all drawing code must be associated with the Paint event of the destination image object. - .Nettrix: GDI+ and Collision Detection The following code shows how to draw a simple red rectangle at the 10, 20 position (in pixels) on the Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites screen, 7 pixels high and 13 pixels long: Chapter 1 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Private Sub PicSource_Paint(sender As Object, e As PaintEventArgs)_ - River Pla.Net II: DirectInput and Writing Text to Screen Handles PicSource.Paint Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow e.Graphics.FillRectangle(New SolidBrush(color.red), 10, 20, 13, 7) Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API End Sub Chapter 5
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
BonusNEW Chapter Portingfirst .Nettrix to Pocket PC we can see many new features of .NET, as described here: In these few lines of code Appendix A The State of PC Gaming IN
event in handler Appendix B -Every Motivations Gamesin Visual Basic .NET receives at least one parameter, the sender object, .NET is the object that generates the event. Appendix C -which How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
The event handler procedure is now associated with the object by the keyword Handles. There's no more implicit association using the procedure name, as occurred in the later List of Figures versions of Visual Basic. Index
List of Tables
Thee parameter is of the type Windows.Forms.PaintEventArgs. Those with Visual Basic experience will understand that we are dealing with an object hierarchy. In fact, everything in .NET languages is organized into managed units of code, called namespaces. In this case, we are using the System.Windows.Forms namespace, which contains classes for creating Windows-based applications using the features of the Windows operating system. Inside this namespace, we are using the PaintEventArgs class, which basically gives the Paint event access to the rectangle structure that needs to be updated (ClipRectangle property), and theGraphics object used to update it. TheGraphics and SolidBrush classes are defined in the System.Drawing namespace. This namespace has several classes that provide all the functionality we need to work with 2-D drawings, imaging control, and typography. In the code sample, we create a SolidBrush object with red color (using the color structure), to draw a filled rectangle using the FillRectangle method of the Graphics object. In the .NET architecture, all objects are organized into hierarchies called namespaces.
Creating Graphics Objects from a Window Handle In the code shown here, Graphics.FromHwnd is a shortcut for the System.Drawing. Graphics.FromHwnd method, which creates a Graphics object used to draw in a specific window or control, given its handle. This code references a pictureBox control named picSource:
Game Programming with DirectX 9.0 Dim graph as .NET Graphics ISBN:1590590511 by Alexandre Santos Lobão and Ellen graph = Graphics.FromHwnd(picSource.Handle) Hatton graph.FillRectangle(New SolidBrush(color.red), 10, 20, 13, 7) Apress © 2003 (696 pages)
NEW IN .NET
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Inversion .NET, there's no need to use the Set keyword when setting an object variable. If we of Microsoft's Visual Studio.
write the second line as
Table of Contents
Set
graph = Graphics.FromHwnd(picSource.Handle)
.NET Game Programming with DirectX 9.0 Foreword Preface
the Visual Studio environment just erases the Set part for us. Pretty smart!
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection Creating Graphics Objects from an Image
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 - Managed DirectX Firsthere Steps: Direct3D Basics and DirectX GDI+ TheFromImage method shown creates a graphics object fromvs.the specified image: Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5 - River II: DirectInput and Writing Text to Screen Dim graph as Pla.Net Graphics Chapter Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow graph6 = -Graphics.FromImage(picSource.image) Chapter 7 - Magic KindergarteN. II:SolidBrush(color.red), Animation Techniques and Speech graph.FillRectangle(New 10,API20, 13, 7) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Note that the Nonmanaged previous code Code sample will work only if we have a valid bitmap image loaded on the pictureBox control. If we try execute Bonus Chapter Porting .Nettrix to to Pocket PC it against an empty picture box or using a picture box with an indexed Apixel format loaded (such as a JPEG image), we'll get an error and the graphics object Appendix - The Stateimage of PC Gaming won't beBcreated. Appendix - Motivations in Games Appendix C - How Do I Make Games?
Creating a Graphics Object from a Specified Handle to a Device Context List of Figures Appendix D - Guidelines for Developing Successful Games Index
List of Tables Similar to the previously mentioned methods, the Graphics.FromHDC method creates a Graphics
object that allows the program to draw over a specific device context, given its handle. We can acquire the device handle from another Graphicsobject, using the GetHdc method, as shown in the next code snippet: Public Sub FromHdc(e As PaintEventArgs) ' Get handle to device context. Dim hdc As IntPtr = e.Graphics.GetHdc() ' Create new graphics object using handle to device context. Dim newGraphics As Graphics = Graphics.FromHdc(hdc) newGraphics. FillRectangle(New SolidBrush(color.red), 10, 20, 13, 7) ' Release handle to device context. e.Graphics.ReleaseHdc(hdc) End Sub
.NET Game Programming with DirectX 9.0 Creating Gradients by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton we saw some code samples used to create solid red rectangles via a In the previous section, SolidBrush object. Apress GDI+ © 2003 allows (696 pages) the programmer to go beyond flat colors and create linear and path gradients, using special gradient brushes that how provide interesting effects. The authors of this text show easyvery it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET Everett,linear the latest GDI+ has features to create horizontal, vertical, and on diagonal gradients. We can create linear version of Microsoft's Visual Studio. gradients in which the colors change uniformly (the default behavior), or in a nonuniform way by using the Blend property of the gradient brush. Table of Contents
The sample code here shows how to create a uniform gradient brush and draw a rectangle with color
.NET Game from Programming withfrom DirectX 9.0 changing red to blue the upper-left to the lower-right vertex: Foreword Preface
Dim graph as Graphics Dim linGrBrush as Drawing2-D.LinearGradientBrush
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter .Netterpillars: Artificial Intelligence and Sprites graph2 = -Graphics.FromHwnd(picSource.Handle) Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 - River Tiled Game Fields, Scrolling, and DirectAudio linGrBrush = Pla.Net: new Drawing2-D.LinearGradientBrush(_ Chapter 5 Point(10, - River Pla.Net20), II: DirectInput and Writing'Text to Screen new start gradient point Chapter new 6 Point(23, - Magic KindergarteN.: 27), Adventure Games,'ADO.NET, end gradient and DirectShow point
Color.FromArgb(255, 255, 0, 0), ' Redand Speech API Chapter 7 - Magic KindergarteN. II: Animation Techniques Color.FromArgb(255, 0, 0,Games 255)) Blue Chapter 8 - .Netterpillars II: Multiplayer and ' Directplay graph.FillRectangle(linGrBrush, 10, 20, 13, 7) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to -
Chapter 9
Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
NET The most important part of this sample code is the color definition using the FromArgb method IN of the Color object. As we can see, each color in GDI+ is always defined by four values: the Appendix D - Guidelines for Developing Successful Games .NET red, green, blue (RGB) values used by the classic GDI functions, plus the alpha (A) value, Index which defines the transparency of the color. In the preceding example, we use an alpha value List of Figures of 255 for both colors, so they will be totally opaque. Using a value of 128, we create a 50 List of Tables percent transparent color, so any graphics below are shown through the rectangle. Setting alpha to zero means that the color will be 100 percent transparent, or totally invisible. The inbetween values allow different degrees of transparency. Appendix C - How Do I Make Games?
Path gradients allow us to fill a shape using a color pattern defined by a specified path. The path can be composed of points, ellipses, and rectangles, and we can specify one color for the center of the path and a different color for each of the points in the path, allowing the creation of many different effects. To draw an image using gradient paths, we must create a PathGradientBrush object, based on a GraphicsPath object that is defined by a sequence of lines, curves, and shapes. The code here shows how to draw the same rectangle from the previous examples, using a gradient that starts with a green color in the center of the rectangle and finishes with a blue color at the edges: Dim Dim Dim Dim
Graph As Graphics rectSquare As Rectangle graphPath As Drawing2-D.GraphicsPath brushSquare As Drawing2-D.PathGradientBrush
Graph = Graphics.FromHwnd(picSource.Handle) ' Create a path consisting of one rectangle graphPath = New Drawing2-D.GraphicsPath() rectSquare = New Rectangle(10, 20, 23, 27)
graphPath.AddRectangle(rectSquare) Programming with DirectX 9.0 brushSquare =.NET NewGame Drawing2-D.PathGradientBrush(graphPath) ISBN:1590590511 by Alexandre Santos Lobão and Ellen brushSquare.CenterColor = Color.FromArgb(255, 0, 255, 0) Hatton brushSquare.SurroundColors = New Color() {Color.FromArgb(255, 0, 0, 255)} Apress © 2003 (696 pages)
authors of this textthe showpath how easy it can be to produce ' Create the The rectangle from interesting multimedia games using Managed DirectX 9.0 and Graph.FillPath(brushSquare, graphPath) programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Note We Programming won't go into withmuch DirectX detail 9.0 here about brushes and paths. Refer to the .NET SDK Foreword Preface
documentation for some extra examples about how to use these features. For a complete overview about this topic, look for "System.Drawing.Drawing2-D Hierarchy" in the online help.
Introduction
In the next section we'll discuss collision detection, after which we'll have an understanding of all the basic - .Nettrix: GDI+ and Collision Detection concepts we need to implement our first game.
Chapter 1 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 Collision Detection by Alexandre Santos Lobão and Ellen
ISBN:1590590511
As we said at theHatton start of the chapter, one of the most important concepts in game development is the © 2003Some (696 pages) collision detectionApress algorithm. commercial games have gathered significant market shares just because their collision detection routines are faster, leaving for the graphics routines and The authors of this text show how easy it canmore be to time produce interestinggame multimedia allowing more responsive play. games using Managed DirectX 9.0 and
programming with Visual Basic .NET on Everett, the latest version Microsoft's Visual Studio. Just try to imagine some of games without collision detection: a pinball game where the ball won't bounce; a
3-D labyrinth where players go through the walls and the bullets don't hit the enemy; an adventure game where the cursor doesn't know if it's over a specific object on screen. No, it's simply not possible! Table of Contents .NET Programming DirectX 9.0 basic concepts, so we can use them within the scope of the book OurGame main goal here is towith examine some Foreword and create a stepping stone to provide us with the basic tools and terms used in collision detection. Preface
Note For those who want to look into this topic in more detail, a simple search on the Internet will Introduction manyGDI+ improved algorithms for advanced collision detection in 2-D and, mostly, in 3-D Chapter 1 show - .Nettrix: and Collision Detection Chapter 2 environments. - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
In the next sections we'll see some common collision detection algorithms.
Bounding Boxes Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow One of the most common collision detection algorithms, the bounding boxes algorithm, uses the idea of - .Netterpillars II: Multiplayer Games and Directplay creating boxes around objects in order to test a collision with minimum overhead and, depending on the D-iNfEcT: Multithreading, Nonrectangular and Access to object,9an -acceptable degree of precision. In FigureWindows, 1-7 we see some objects that we want to test for Chapter Nonmanaged Code collisions, along with their bounding boxes. Chapter 8
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 1-7: Bounding boxes for an archer and a monster In the game code, we must test if there's any overlap between the boxes to test for collision, instead of testing every single pixel of the images. In Figure 1-7, for example, if the box surrounding the arrow touches the box surrounding the monster, it's a hit. Using bounding boxes on the sample in Figure 1-7 will probably lead to good results, although as a rule it's better to use smaller boxes for the player. If a monster blows up when a bullet (or arrow) just misses it by a pixel, the player won't complain; but if the situation is reversed, the player will feel cheated by the game. It's better to create a narrower box for the archer to give the player a little more satisfaction. We can now redefine the boxes as shown in Figure 1-8.
Figure 1-8: Revised bounding boxes for an archer and a monster An easy way to implement the bounding box test is simply to check if the x,y position of the upper bound
corner of the first box is inside the second box. In other words, check whether x and y of the box being .NET Game Programming with DirectX 9.0 tested are less than or equal to the corresponding x and y of the other box, plus the width of the other box.
Calculating
by Alexandre Santos Lobão and Ellen Hatton Collision with Boxes Apress © 2003 (696 pages)
ISBN:1590590511
authorstoofcalculating this text show how easy can be to produce Here's a possibleThe approach collision with itboxes:
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest If rectangle1.x <=ofrectangle2.x + rectangle2.width and _ version Microsoft's Visual Studio.
rectangle1.y <= rectangle2.y + rectangle2.height) or (rectangle2.x <= rectangle1.x + rectangle1.width and _ Table rectangle2.y of Contents <= rectangle1.y + rectangle1.height) then .NET Game with DirectX 9.0 =>Programming The boxes are overlapping Foreword Else Preface => The boxes don't collide!!! Introduction end if Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites Check 3the-code against the graphic example fromBasics Figure 1-9 to be vs. sureGDI+ you understand the algorithm. Chapter Managed DirectX First Steps: Direct3D and DirectX Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Figure 1-9: Two nonoverlapping boxes
Appendix D - Guidelines for Developing Successful Games Index According to the code sample, the two boxes will only overlap if both x and y coordinates of rectangle 2 List Figures areofwithin range (x to x + width, y to y + height) of rectangle 1. Looking at the diagram, we see that the y List of Tables coordinate for rectangle 2 is not greater than the y coordinate plus the height of rectangle 1. This means
that our boxes may be colliding. But when checking the x coordinate of rectangle 2, we see that it's greater than the x coordinate plus the width of rectangle 1, which means that no collision is possible. In Figure 1-10, we do have a collision.
Figure 1-10: Two overlapping boxes
.NET Game Programming with DirectX 9.0
ISBN:1590590511 by Alexandre Ellen of rectangle In this case, we can check thatSantos both xLobão and yand positions 2 are within the range of rectangle 1. In the code sample Hatton we also do the opposite test, checking if the x,y coordinates of rectangle 1 are within the Apress © 2003 (696 range of rectangle 2, because wepages) are checking just one point, and it's possible for rectangle 2's top-left The of authors of this show it can be 1totoproduce corner to be outside rectangle 1, text but the tophow lefteasy of rectangle be inside rectangle 2.
Creating
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Custom versionRectangle of Microsoft's Objects Visual Studio.
A simple improvement we can do in the algorithm is to create a custom rectangle object, which stores two points the box, the upper-left corner and the bottom-right one, so we can do the tests directly on the Table of of Contents variables havingwith to perform sum operation. .NET Game without Programming DirectX a 9.0 Foreword
This method can be easily extended to nonrectangular objects, creating for each object a set of rectangles instead of a single rectangle. For example, for a plane, instead of using a single box (Figure 1-11), we can Introduction achieve much better precision using two overlapping boxes (Figure 1-12). Preface
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 1-11: Approximating a plane shape with one box
Figure 1-12: Approximating a plane shape with two boxes
The drawback of this approach is that if we use too many boxes, the calculations will take longer, so we .NET Game Programming with DirectX 9.0 need to find a balance between precision and speed for each game or object. by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Proximity Algorithms
The authors of this text show how easy it can be to produce
Another type of algorithm commonly used to calculate objectDirectX overlapping is the proximity algorithm. Proxy interesting multimedia games using Managed 9.0 and algorithms are somewhat programming similar with toVisual the bounding Basic .NET boxes on Everett, algorithm, the depending latest on the formula used. version of Microsoft's Visual Studio.
The basic idea behind such algorithms is to calculate the distance between the centers of two objects, and then check the value against a formula that describes approximately the objects' shapes. This method is Table of Contents as precise as the formula used to approximate the object shape—for example, we can have perfect .NET Game Programming with balls, DirectX collision detection between in 9.0 a snooker simulator game, using the right formula. Foreword
Some of the most common formulas calculate the distances between squares, circles, and diamonds. Preface Figure 1-13 shows a graphical representation for a square-based proximity test. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
Figure 1-13: Square proximity
Index
List of Figures List of Tables Calculating
Collision for Square or Circle Objects
To calculate collision for objects with a shape that can be approximated to a square, the basic formula is Distance between centers = Maximum value between the distances in the x axis and the y axis To calculate the distance in a specific axis, all we need to do is to subtract the x values of the center coordinates from each object, picking the absolute value of the result, so we don't need to worry about which object is the furthest to the left or the nearest to the top of the screen. The code for calculating square collisions, considering that we have objects with CenterX and CenterY properties, would be as follows: Distance = math.max(math.abs(Object1.CenterX - Object2.CenterX), _ math.abs(Object1.CenterY - Object2.CenterY)) If Distance < Object1.width + Object2.width then ' => The square objects are overlapping Else ' => The squares don't collide!!! end if
Figure 1-14 illustrates the next proximity algorithm for figures that can be approximated by circles.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface
Figure 1-14: Circle proximity Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
When dealing with circular objects, we achieve a perfect calculation using the Pythagorean theorem, - .Netterpillars: Artificial Intelligence and Sprites which allows us to calculate the distance between the centers (hypotenuse) using the square root of the Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ sum of the squares of the other sides: Chapter 2 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Cathetus1 = math.abs(Object1.CenterX - Object2.CenterX) Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Cathetus2 = math.abs(Object1.CenterY - Object2.CenterY) Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Distance = math.sqrt(Cathetus1^2 + Cathetus2^2) D-iNfEcT: Multithreading, Nonrectangular Windows, then and Access to If Distance < Object1.width + Object2.width Chapter 9 Nonmanaged Code
' => The circle objects are overlapping
Bonus Chapter Porting .Nettrix to Pocket PC
Else
Appendix A - The State of PC Gaming
' => The circles don't collide!!!
Appendix end ifB - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
If we just want to check the distance against a constant value, we don't need to calculate the square root, Index making operations faster. List of Figures List of Tables
Calculating Collision of Diamond-Shaped Objects The next approximation algorithm uses much simpler calculations, and gives a good degree of precision when dealing with objects of a diamond shape, as depicted in Figure 1-15.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5 - 1-15: River Pla.Net II: proximity DirectInput and Writing Text to Screen Figure Diamond Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
To use7this- approach, all we need do is calculate the sum of the distances: Chapter Magic KindergarteN. II: to Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Distance D-iNfEcT: = math.abs(Object1.CenterX - Windows, Object2.CenterX) Multithreading, Nonrectangular and Access to + _ Chapter 9 Nonmanaged Code math.abs(Object1.CenterY - Object2.CenterY) Bonus Chapter Porting .Nettrix to Pocket PC Appendix If Distance A - The State < Object1.width of PC Gaming + Object2.width then
' -=> The diamond Appendix B Motivations in Gamesobjects are overlapping Else C - How Do I Make Games? Appendix ' -=> The diamonds don't collide!!! Appendix D Guidelines for Developing Successful Games end if Index List of Figures List of Tables
Programming with DirectX 9.0 Optimizing.NET theGame Number of Calculations by Alexandre Santos Lobão and Ellen
ISBN:1590590511
As the number ofHatton objects in the game grows, it becomes increasingly difficult to perform all the necessary Apress © 2003 (696 pages) calculations, so we'll need to find a way to speed things up. Because there's a limit to how far we can simplify the calculations, we need keep thehow number calculations low. The authors of thistotext show easy of it can be to produce interesting multimedia games using Managed DirectX 9.0 and Visual Basic .NET on Everett, the objects latest that are currently on screen. If The first method programming to consider is with to only perform calculations for the version of Microsoft's Visual Studio. we really need to do calculations for off-screen objects, we'll perform them less frequently than those for on-screen objects. Table of Contents
The next logical step is to attempt to determine which objects are near, and then to calculate the collisions
.NET Programming DirectX 9.0 a zoning method. If most of our objects are fixed on the screen and onlyGame for those. This can with be done using Foreword have the same size, we can calculate the collisions using tiled game fields; if we have many objects but
Preface need to test only one against all others (such as a bullet that may hit enemies or obstacles), we can simply Introduction divide the screen in zones and control them with single-bit information for each zone; and if we need to Chapter 1 - .Nettrix: and Collision test a limited numberGDI+ of objects againstDetection all others, we'll have to store extra information about each zone, Chapter using arrays 2 - .Netterpillars: of bits. Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
We'll discuss each of these approaches in the following sections. - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Tiled6 Game Field Chapter - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
The tiled game field approach is the zone method taken to the limit; there's only one object per area in the - .Netterpillars II: Multiplayer Games and Directplay zone, and we use a bidimensional array where each position on the array refers to a tile on the screen. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 When moving objects, allCode we have to do is to check the array in the given position to know if there'll be a Nonmanaged collision. In this chapter, we a simple Bonus Chapter Porting .Nettrix do to Pocket PCvariation of this method, using a bit array where each bit maps to a tile on the screen. This approach is possible because we only want to store one piece of informationAppendix A - The State of PC Gaming whether the tile is empty or not. If we need to store any extra data about the object (for example, an Appendix B - Motivations in Games identifier about the object type), we have to create an integer array to store numbers, and create a Appendix C - How Do I Make Games? mapping table in which each number represents a specific type of object (as we do in the next chapter). Appendix D - Guidelines for Developing Successful Games Figure 1-16 shows a tiled game where each screen object is held in an array. Chapter 8
Index
List of Figures List of Tables
Figure 1-16: In a tiled game field, we have an array that maps to screen objects.
Zoning with Bits If we have a game with many objects but infrequent collisions, we can minimize the number of calculations dividing our screen in zones, and only calculate collisions for objects that are on the same zone (this is what's known as zoning). To divide a screen in zones, we'll create an array to store information about each zone's y and x axis. So, if we divide our screen into 64 zones (8 × 8), we'll need one array with 8 elements to store information about the y axis of each zone, and another array with 8 elements to store information about the x axis of each zone. Figure 1-17 shows an example of such zoning.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection Figure DividingArtificial a screen into 64 zones Chapter 2 - 1-17: .Netterpillars: Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
If all we want to know is whether a certain zone contains an object (disregarding which one), we can use - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio bytes (instead of arrays) to store the zone information, where each bit will represent a zone on screen; this Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen is called zoningwith bits. We can divide our screen in zones according to the number of bits on each Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow variable used: 64 (8 × 8) zones with a byte, 256 (16 × 16) zones in an int16, 1024 (32 × 32) zones in an Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API int32, and so on. Chapter 4
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Windows, and to and, for each object, we Using the with Multithreading, bits method, atNonrectangular each game loop we reset theAccess variables Chapter 9 zoning Codethen calculate the zone of each object (multiply the current position of the process anyNonmanaged movement. We Bonus to on Pocket PCaxis and divide by the width or height of the screen), and set the bit objectChapter by the Porting number.Nettrix of zones each Appendix A - Theto State of PC Gaming corresponding the result at the x-axis variable and at the y-axis variable, accordingly. We have to set a Appendix B -ifMotivations Games second bit the sum ofinthe position and the size of the object (width for x axis, height for y axis) lies in Appendix another C zone. - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
If when checking the variables we see that the bit in both variables is already set, then there's an object in our zone, so we check all the objects to find out which one it is. Using this method, if we have 15 objects List of Figures on the screen, and only one collision, we'll have to do only one check against a given number of objects List of Tables (14 in the worst case of this scenario), instead of 15 tests with 14 objects. This method has some drawbacks: Index
We don't know which object set the bit, so we have to test all the objects looking for the collision. Some "ghost objects" are created when crossing the bit set for the x zone by one object with the bit set for the y zones by another object, as depicted by Figure 1-18.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 Figure - .Netterpillars: Artificial and big Sprites 1-18: Using zone Intelligence bits, if we have objects (like the bricks), there'll be lots of "ghost Chapter 3 objects." - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
This method is most useful when we want to test a group of objects against other objects (for example, Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow bullets against enemies on screen); if we need to test all the objects against each of the others, we'd Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API better use zoning with arrays of bits, as described in the next section. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Zoning- Nonmanaged with Arrays Code of Bits
Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC
If we have a limited number of objects on screen, we can use two arrays, instead of variables, to define our zones. Each object will correspond to a specific bit in the array elements, so we'll use byte arrays to Appendix B - Motivations in Games control 8 objects, int16 arrays to control 16 objects, and so on, and create a mapping table linking each Appendix C - How Do I Make Games? bit with a specific object. The size of each array will define the number of pixels in a zone for each Appendix D - Guidelines for Developing Successful Games dimension. For example, creating two arrays each with 10 positions in a 640×480 resolution, we'll have Index zones measuring 64 pixels wide by 48 pixels high. Appendix A - The State of PC Gaming
List of Figures
Weofuse the same idea as the previous method to define the zone (or zones) in which each object may be, List Tables and then check to see if both x and y array elements aren't empty. If they aren't zero, and the bits set in both arrays are the same, then we know for sure that there's another object near us (not a ghost object), and only check for collision with the one that corresponds to the bit set. An example of this is shown in Figure 1-19.
Figure 1-19: Using zone arrays, we can keep track of which objects are in each zone. The legend
shows the bit set in each array element, for each object.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming 9.0 Dimension Extending the Algorithms to with AddDirectX a Third by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton There are many advanced algorithms for 3-D collisions described on game-related sites all over the 2003many (696 pages) Internet. We'll notApress stress©the implications on including a z axis in the collision detection algorithms; instead we'll just The add authors some simple to the preceding of thisextensions text show how easy it can bealgorithms. to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basicstraightforward, .NET on Everett,as the latesthere: Extending the bounding box algorithm is very shown version of Microsoft's Visual Studio.
If object1.x <= object2.x + object2.width and _ Table object1.y of Contents <= object2.y + object2.height and _ object1.z <= object2.z + object2.depth) or .NET Game Programming with DirectX 9.0 (object2.x <= object1.x + object1.width and _ Foreword object2.y <= object1.y + object1.height and_ Preface object2.z <= object1.z + object1.depth) then Introduction ' => The 3-D boxes are overlapping Chapter 1 - .Nettrix: GDI+ and Collision Detection Else Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites ' => The 3-D boxes don't collide!!! Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ end if Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter As for the 7 -proximity Magic KindergarteN. algorithms, the II: Animation extension Techniques is just as easy. and Speech This code APIsample depicts a proximity test with
cube-like Chapter 8 objects: - .Netterpillars II: Multiplayer Games and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Code Distance Nonmanaged = math.max(math.abs(Object1.CenterX - Object2.CenterX), _ Bonus Chapter Porting .Nettrix to Pocket PC math.abs(Object1.CenterY - Object2.CenterY)) Chapter 9
-
Appendix A - The State of PC Gaming Distance = math.max(Distance, Appendix B - Motivationsmath.abs(Object1.CenterX in Games - Object2.CenterX)) Appendix C - How Do I Make Games? Appendix If Distance D - Guidelines < Object1.width for Developing Successful + Object2.width Games then Index
' => The cube objects are overlapping
Else List of Figures ' => The cubes don't collide!!! List of Tables end if
The next proximity algorithm extends the circle proximity test to use spheres in a 3-D space: Cathetus1 = math.abs(Object1.CenterX - Object2.CenterX) Cathetus2 = math.abs(Object1.CenterY - Object2.CenterY) Cathetus3 = math.abs(Object1.CenterZ - Object2.CenterZ) Distance = math.sqrt(Cathetus1^2 + Cathetus2^2 + Cathetus3^2) If Distance < Object1.width + Object2.width then ' => The sphere objects are overlapping Else ' => The spheres don't collide!!! end if
The last proximity test is used for 3-D diamond-shaped objects: Distance = math.abs(Object1.CenterX - Object2.CenterX) + _ math.abs(Object1.CenterY - Object2.CenterY) + _ math.abs(Object1.CenterZ - Object2.CenterZ)
If Distance < Object1.width + Object2.width then .NET Game Programming with DirectX 9.0 => The 3-D diamond objects are overlapping ISBN:1590590511 by Alexandre Santos Lobão and Ellen Else Hatton => TheApress 3-D ©diamonds don't collide!!! 2003 (696 pages) end if
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest In the next sections we'll of see how to apply these theoretical ideas in a real game project. version Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Game Proposal by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton The first step in developing any project is to establish the project's scope and features. Apress © 2003 (696 pages)
Note The main creating a game is to clear objectives stated; and everyone Thepurpose authors for of this text show howproposal easy it can be have to produce involvedinteresting in the game creationgames must agree on everyDirectX point. 9.0 and multimedia using Managed programming with Visual Basic .NET on Everett, the latest
For our project we version can summarize of Microsoft's theVisual scopeStudio. in a list of desired features, as shown here: Our game will be a puzzle game, and it'll be called .Nettrix. Table of Contents
The main objective with of the game9.0 is to control falling blocks and try to create full horizontal lines, while .NET Game Programming DirectX not allowing the block pile to reach the top of the game field. Foreword Preface
The blocks will be made out of four squares (in every possible arrangement) that fall down in the game field, until they reach the bottom of the field or a previously fallen block.
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter When 2 -the .Netterpillars: blocks are Artificial falling, the Intelligence player can andmove Sprites the blocks horizontally and rotate them. Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
When-aRiver blockPla.Net: stops falling, we'll check to see if there are continuous horizontal lines of squares in the Tiled Game Fields, Scrolling, and DirectAudio game field. Every continuous line must be removed.
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 player - Magic KindergarteN.: Adventure Games, ADO.NET, by and DirectShow The gets 100 points per removed line, multiplied the current level. After every couple of Chapter 7 - Magic KindergarteN. II: Animation Techniques APIshould be increased. minutes, the blocks must start falling faster, and the and levelSpeech number Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
If the stack of blocks grows untilNonrectangular it's touching theWindows, top of theand game field, D-iNfEcT: Multithreading, Access to the game ends.
Chapter 9
-
Nonmanaged Code This list contains many definitions that PC are important for any game proposal: Bonus Chapter Porting .Nettrix to Pocket Appendix A - The State of PC Gaming
The game genre (puzzle)
Appendix B - Motivations in Games Appendix TheCmain - How objective Do I Make of the Games? game Appendix D - Guidelines for Developing Successful Games Index
The actions the player can perform (e.g., to shoot and to get objects)
List ofDetails Figuresabout how the player interacts with the game and vice-versa: keyboard, intuitive interface, List offorce-feedback Tables joystick, etc.
How the player is rewarded for his or her efforts (points, extra lives, etc.) How the player gets promoted from one level to the next (in this case, just a time frame) The criteria for ending the game Note In more sophisticated games, there may be other considerations, such as the storyline, the game flow, details about the level design or level of detail for the maps or textured surfaces, the difficulty levels for the game, or even details on how the artificial intelligence (AI) of the game should work.
.NET Game Programming with DirectX 9.0 The Game Project by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hattonproject, the game project starts with a complete game proposal (not just some In a commercial game Apress © 2003 pages) with a project or functional specification. Although the proposal is simple phrases like ours) and (696 continues written in natural The language-so anyone understand approve it (including the Big Boss, who will authors of this textcan show how easy and it can be to produce games using Managed DirectX 9.0 and approve or rejectinteresting the budgetmultimedia for the project)-the project includes programming details that will guide the programming Visual Basic .NET on Everett, the latest development team through thewith coding phase. version of Microsoft's Visual Studio.
It's not our objective here to explain what must appear in the project documents (it depends largely on the development methodology used by the team), and we won't create any complete projects since this isn't Table of Contents the focus of the book. But since it's not advisable to start any coding without a project, we'll take a quick .NET Game Programming with DirectX 9.0 look at projects just to make some implementation details clearer. Foreword
Preface Tip Of course you can start coding without a project, but even when working alone, a project is the Introduction best place to start, since it lets you organize your ideas and discover details that were not clear Chapter 1before - .Nettrix: GDI+ Collision Detection you put penand to paper. Even if the project is just some draft annotations, you'll see that the Chapter 2average - .Netterpillars: quality ofArtificial your code Intelligence will improve and Sprites with its use. The more detailed the project is, the better
code willDirectX be, since help you see the and traps and pitfalls along the way before you fall into Chapter 3your - Managed Firstthey'll Steps: Direct3D Basics DirectX vs. GDI+ Chapter 4them. - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Object-oriented (OO) techniques are the best to use in game projects, because usually games deal with Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow some representation (sometimes a very twisted one) of the real world, as OO techniques do. For example, Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API in Street Fighter, we don't have real fighters on the screen, we have some moving drawings, controlled by Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay the player or the computer, that create the illusion of a fight. Using an OO approach to project creation is D-iNfEcT: Multithreading, Nonrectangular Windows, andfrom Access roughly9the- same thing: We decide the important characteristics thetoreal-world objects that we want Chapter Nonmanaged Code to represent in our program, and write them down. We aren't going to go any deeper into this topic at this Bonus Chapter Porting .Nettrix to Pocket PC stage, but you can find some very good books on this topic. Appendix A - The State of PC Gaming
Appendix B -isMotivations in Games Since this our first program, we'll go through the process of making it step by step, in order to Appendix demonstrate C - How howDoweI Make evolveGames? from the game proposal to the final code; in later chapters we'll take a more
direct approach. In thefor next sections Successful we'll see aGames first version of a class diagram, then pseudo-code for the Appendix D - Guidelines Developing game main program, and after that we'll go back to the class diagram and add some refinements. Index List of Figures
The Class Diagram: First Draft
List of Tables
Let's start with a simple class diagram (shown in Figure 1-20) illustrating the basic structures of the objects for our game, and then we can add the details and go on refining until we have a complete version. Almost all of the object-oriented analysis methodologies suggest this cyclic approach, and it's ideal to show how the game idea evolves from draft to a fully featured project.
Figure 1-20: The class diagram-first draft From our game proposal we can see the first two classes: Block, which will represent each game piece, andSquare, the basic component of the blocks. Reviewing our game proposal, we can think about some methods (functions) and properties (variables) for theBlock class, as described in Table 1-1. Table 1-1: The Block Class Members
TYPE
NAME DESCRIPTION .NET Game Programming with DirectX 9.0
Method
Down Hatton
Method
Apress © 2003 (696 pages) Right Moves the block right
Method
Left Moves the block left Managed DirectX 9.0 and interesting multimedia games using
Method
Rotate RotatesVisual the block clockwise version of Microsoft's Studio.
Property
Square 1
by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Makes the block go down on the screen
The authors of this text show how easy it can be to produce programming with Visual Basic .NET on Everett, the latest
One of the squares that compose the block
Table of Contents Square 2 Property One of the squares that compose the block .NET Game Programming with DirectX 9.0
Property Foreword
Square 3
One of the squares that compose the block
Preface Property
Square 4
One of the squares that compose the block
Introduction Chapter 1 - is .Nettrix: GDI+ofand Collision Detection Each block composed fours objects from the Square class, described in Table 1-2. Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3 - The Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Table 1-2: Square Class Members Chapter 4
TYPE
Chapter 5
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
NAME
DESCRIPTION
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 - Magic KindergarteN.: Adventure Games, and Show Draws the square on ADO.NET, the screen at DirectShow its coordinates (Location Method Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API colored with a specific property) and with its size (Size property), Chapter 8
- .Netterpillars II: Multiplayer Games andproperty) Directplayand filled with BackColor color (ForeColor D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - Hide Method Nonmanaged CodeErases the square from the screen Bonus Chapter Porting .Nettrix toThe Pocket PC border color ForeColor Property square Appendix A - The State of PC Gaming
BackColor Property The square inside color (fill color) Appendix B - Motivations in Games Appendix C - How Do I Make Games? Location Property The x,y position of the square on the screen Appendix D - Guidelines for Developing Successful Games
Property Index
Size
The height and width of the square
List of Figures
Comparing the two tables, we can see that there are methods to show and hide the square. Because the squares will be drawn from the Block object, we must have corresponding methods in the Block class, and the corresponding properties too. We can adjust the first diagram accordingly to produce Figure 1-21.
List of Tables
Figure 1-21: The class diagram-second draft We use SquareSize as the size property for the block, since it's not important to know the block size, but the block must know the size of the squares so that it can create them.
We can return to this diagram later and adjust it if necessary. Let's think now about the game engine, .NET Game Programming with DirectX 9.0 described in the next section. by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The Game Engine
The authors of this text show how easy it can be to produce
Using the Visual Basic events jargon, we can think coding three interesting multimedia games using about Managed DirectX 9.0main and events to implement the behaviors described programming at the game withproposal: Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
1. When the form loads, we can create the first block. 2. At the form KeyPress event, we can handle the keyboard input from the user.
Table of Contents
.NET3. Game Programming withcall DirectX 9.0 method at each clock tick, producing the desired falling effect for With a timer we can the Down Forewordthe blocks. As we'll see later, using a timer isn't a recommended practice when creating games that Preface need to run at full speed, but that's not the case here. Introduction
Writing1pseudo-code is helpful for validating the class diagram, checking whether we use every method Chapter - .Nettrix: GDI+ and Collision Detection and property, and determining whether we can achieve Chapter 2 - .Netterpillars: Artificial Intelligence and Spritesthe results stated in the game proposal with those class members. The DirectX pseudo-code for our game is shown the following code sample: Chapter 3 - Managed First Steps: Direct3D Basics andinDirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Form_Load Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
an object (named currentBlock) of block class -Creates Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay We'll use the currentBlock object in all other events, so it must have the same scope as the form:
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Form_KeyPress Bonus Chapter Porting .Nettrix to Pocket PC If- The Left Arrow was pressed, call Left method of currentBlock Appendix A State of PC Gaming If If Appendix C If
Right Arrow was pressed, call Right method of currentBlock Up Arrow was pressed, call Rotate method of currentBlock How Do I Make Games? Down Arrow was pressed, call Down method of currentBlock
Appendix B - Motivations in Games
Appendix D - Guidelines for Developing Successful Games Index
List of Figures In the previous pseudo-code, we are using the up arrow key to rotate the block and the down arrow key to List of force Tables the block to go down faster, while the right arrow key and left arrow key move the block in the
horizontal direction. The game engine core will be the timer event. Reviewing the game proposal, we see what we must do here: Make the block fall, stop it according to the game rules, check to see if there are any full horizontal lines, and check for the game being over. Possible pseudo-code to do this is shown in the following sample: If there is no block below currentBlock, and the currentBlock didn't reach the bottom of the screen then Call the Down method of currentBlock Else Stop the block If it's at the top of the screen then The game is over If we filled any horizontal lines then Increase the game score Erase the line Create a new block at the top of the screen
Analyzing this code, we can see some features our current class diagram doesn't take into account. For
instance, how can we check if there is no block below the current block? How can we erase the horizontal .NET Game Programming with DirectX 9.0 line we just managed to fill? We'll discuss these points in the next section. by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The Class Diagram: Final Version
The authors of this text show how easy it can be to produce
In order to check interesting the previous block positions to seeManaged if there are any 9.0 blocks multimedia games using DirectX andbelow the current block or if there are any filled programming lines, we must withhave Visuala Basic way to.NET store onand Everett, check theeach latest of the squares of the block, of Microsoft's Visual Studio. independently of version the original blocks (remember, when we erase a line, we can erase just a square or two from a given block). We can do this by creating a new class representing the game field, which will store the information of all squares and have some methods that allow line erasing, among other features. With Table of Contents a quick brainstorm, we can add this class to our model, which will evolve into the diagram shown in Figure .NET Game Programming with DirectX 9.0 1-22. Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
1-22: The.Nettrix final class diagram BonusFigure Chapter Porting to Pocket PC Appendix A - The State of PC Gaming Appendix B -lists Motivations in Games Table 1-3 the methods and properties of the new class, along with a short description for each one. Appendix C - How Do I Make Games? Appendix D - The Guidelines Developing Successful Games Table 1-3: Gamefor Field Class Members Index
TYPE
NAME
DESCRIPTION
Width and Height
Represents the width and height of the game field, measured in squares.
Property
SquareSize
Indicates the size of each square, so we can translate pixels to squares.
Property
ArrGameField
Constitutes an array to store all the squares from all the blocks that stopped falling.
Method
CheckLines
Checks if there are any complete horizontal lines, erasing them if so, and returns the number of erased lines so the main program can increase the player's score.
Method
IsEmpty
Checks if the square at a particular location (a given x and y) is empty, therefore telling us when a block is in motion.
Method
Redraw
Forces the full redraw of the game field. This will be used when a line has been erased or when another window has overlapped ours.
List of Figures ListProperties of Tables
In a real project, we would possibly go beyond this point, refining all methods to include their interfaces (received parameters and return values) and specifying the data types for the properties, which would probably lead to another revision of our class diagram. But we've got the basic idea here, and that's the main point.
.NET Game Programming with DirectX Tip Those interested in looking into project creation in 9.0 more depth can find more detailed explanations ISBN:1590590511 Alexandre Santos Lobãoanalysis. and Ellen in books by covering object-oriented Hatton Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 The Coding.NET Phase by Alexandre Santos Lobão and Ellen
ISBN:1590590511
When coding anyHatton project, it's always useful to create drivers and stubs to allow us to test each component Apress © 2003 (696that pages) separately.Drivers are programs control other lower-level programs, and stubs are programs that mimic low-level programs' behavior, allowing testing higher code. To provide a vision of a real coding The authors of this textthe show how of easy it canlevel be to produce interesting games to using Managed DirectX 9.0 and phase, we'll sometimes usemultimedia such techniques validate the code written, step by step. programming with Visual Basic .NET on Everett, the latest of Microsoft's Studio. We'll go through version three versions, from Visual our first draft to the final code:
1. First draft: Code the Square class. Table of Contents
2. Second draft: Code the Block class.
.NET Game Programming with DirectX 9.0
Foreword 3. Final version: Code the GameField class and the game engine. Preface
We start coding from the lowest level class, Square, in the next section. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
- .Netterpillars: Artificial Sprites First Draft: Coding theIntelligence SquareandClass
Chapter 2 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Reviewing game project, find Fields, the basic structure the class and create the class interface: Chapter 4 -the River Pla.Net: Tiledwe Game Scrolling, andof DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 Class - Magic KindergarteN.: Public ClsSquare Adventure Games, ADO.NET, and DirectShow ChapterPublic 7 - Magic location KindergarteN. As II: Point Animation Techniques and Speech API
size AsII:size ChapterPublic 8 - .Netterpillars Multiplayer Games and Directplay Public forecolor As Color D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged CodeAs Color Public backcolor
Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC
Public As System.IntPtr) Appendix A - TheSub StateShow(WinHandle of PC Gaming Public Sub Hide(WinHandle As System.IntPtr) Appendix B - Motivations in Games End Class Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index
There's nothing here that we couldn't do in the previous version of Visual Basic. In later chapters we'll see some improvements brought about by .NET |concerning object orientation. The class methods are shown in List of Tables thenext section. List of Figures
The New and Hide Methods In the Show method all we need to do is to adapt the code for creating a path gradient rectangle we saw in theprevious section. For the Hide method, we can hide the rectangle in an easier way: Since we'll be working with a one-color background (no textures or bitmaps yet), we can simply draw the rectangle again, this time using a solid color, the same as the background. To create a generic code that can be updated later by any programmer, it's always a good idea to not use fixed values inside our program. In our example, we'd better read the game field background color from some variable, so that if it's updated later to another color, our Hide method will still work. This color value should be a property of the GameField class, but since this property doesn't appear in our game project, we'll need to update it with this new property. In a real project it's common for some details (like this one) to only become visible at the coding phase, since it's not possible for the project to predict all possible details. The code for the Square class is shown here: Public Class ClsSquare Public location As Point Public size As size Public forecolor As Color Public backcolor As Color
' Draws a rectangle with gradient path using the properties above .NET Game Programming with DirectX 9.0 Public Sub Show(WinHandle As System.IntPtr) ISBN:1590590511 by Alexandre Santos Lobão and Ellen Dim rectSquare As Rectangle Hatton Dim graphPath As Drawing2-D.GraphicsPath Apress © 2003 (696 pages) Dim brushSquare As Drawing2-D.PathGradientBrush The authors of this text show how easy it can be to produce Dim surroundColor() Color interesting multimedia As games using Managed DirectX 9.0 and Dim GameGraphics Graphics programming with As Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
' Gets the Graphics object of the background picture GameGraphics = Graphics.FromHwnd(WinHandle) Table of Contents ' Creates a path consisting of one rectangle .NET Game Programming with DirectX 9.0 graphPath = New Drawing2-D.GraphicsPath() Foreword rectSquare = New Rectangle(location.X, location.Y, _ Preface size.Width, size.Height) Introduction graphPath.AddRectangle(rectSquare) Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 Chapter 3
-'.Netterpillars: Artificial Intelligence and Sprites Creates the gradient brush which will draw the square -'Managed Note: DirectX There's First one Steps:center Direct3D color Basics and and DirectX an array vs. GDI+ of border colors
Chapter 4
= New -brushSquare River Pla.Net: Tiled GameDrawing2-D.PathGradientBrush(graphPath) Fields, Scrolling, and DirectAudio
Chapter 5
= forecolor -brushSquare.CenterColor River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
= Adventure New Color() -surroundColor Magic KindergarteN.: Games,{backcolor} ADO.NET, and DirectShow
Chapter 7
= surroundColor -brushSquare.SurroundColors Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to -GameGraphics.FillPath(brushSquare, graphPath) Nonmanaged Code
' Finally draws the square
End Sub Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Public Sub Hide(WinHandle As System.IntPtr) Dim GameGraphics As Graphics Appendix C - How Do I Make Games? Dim rectSquare As Rectangle Appendix B - Motivations in Games
Appendix D - Guidelines for Developing Successful Games Index
' Gets the Graphics object of the background picture GameGraphics = Graphics.FromHwnd(WinHandle)
List of Figures List of Tables
' Draws the square rectSquare = New Rectangle(location.X, location.Y, _ size.Width, size.Height) GameGraphics.FillRectangle(_ New SolidBrush(ClsGameField.BackColor), rectSquare) End Sub End Class
Game Programming DirectX NEW Visual.NET Basic comes fully packed with with new data9.0 types. For example, for integer values we have the by Alexandre Santos Lobão and Ellen plus theISBN:1590590511 IN typeinteger, as in the previous versions, types int16,int32,int64, representing Hatton .NET integers of different sizes, and intPtr, which is a special integer type that will use the size of the Apress © 2003 (696 pages) pointers (such as window handles) specific to the destination machine. The authors of this text show how easy it can be to produce interesting multimedia using Managed DirectX 9.0 and In Visual Basic .NET we cangames set the initial values of variables when defining them. A common programming with Visual Basic .NET on Everett, the latest example is version of Microsoft's Visual Studio.
Dim x as integer = 10 Table of Contents .NET Game Programming with DirectX 9.0
The variable x is created and then the value 10 is assigned to it.When setting initial values to arrays, the values may appear separated with commas and delimited by {}. That's what we see Introduction in the code for the Square class in the line Foreword Preface
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- surroundColor .Netterpillars: Artificial Intelligence and Sprites = New Color() {backcolor}
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
is an array of Writing colors with element. The following code has the same - surroundColor River Pla.Net II: DirectInput and Text atosingle Screen
Chapter 6
the previousAdventure line: - effect Magic as KindergarteN.: Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- Redim .Netterpillars surroundColor(1) II: Multiplayer Games and Directplay
Chapter 9
-
surroundColor(1) D-iNfEcT: Multithreading,= Nonrectangular backcolor Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
new feature becomes more interesting when dealing with larger arrays. Compare the Appendix A - This The State of PC Gaming code samples: Appendix B - following Motivations in Games Appendix C - How Do I Make Games? Appendix D - Dim Guidelines myArray for Developing () as integer Successful Games = {1, 2, 3, 4, 5} Index List of Figures List of Tables
The corresponding code in the previous versions is as follows: Dim myArray() as integer Redim myArray(5) myArray(1) = 1 myArray(1) = 2 myArray(1) = 3 myArray(1) = 4 myArray(1) = 5
In .NET all the arrays must be defined without boundaries, which are later assigned in the code. So we must always use Redim before assigning values to an array. NEW In the Hide method shown previously, we can see an unusual use of the backcolor property:We IN are using the property directly from the class definition, instead of from a previously created object .NET in this class. In this case, we are using a new feature of .NET: the shared properties or methods. Defining a method or a property as Public Shared makes it available for any part of the program directly from the class name, without the need for explicitly creating an object. An important point is that the property or method is shared by all the instances of the objects created from the class. For example, we can have a shared counter property that each object increments when it's created and decrements when it's destroyed, and any object can read this counter at any time in order to see how many objects are available at any given time.
Testing the Square Class .NET Game Programming with DirectX 9.0 bytoAlexandre Santos Lobão and Ellen Now we are ready test our program. To do this, we'll need toISBN:1590590511 create a driver to call the class (a window Hatton with a button and a pictureBox will suffice), and a stub for the GameField class, since our Square class Apress © 2003 (696 pages) uses the backcolor property of this class. The authors of this text show how easy it can be to produce
interesting games using 9.0 and The stub is very simple, justmultimedia a new file composed ofManaged the codeDirectX lines shown in the next sample: programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Public Class ClsGameField Public Shared backcolor As Color Table Contents End ofClass .NET Game Programming with DirectX 9.0 Foreword
The driver will be replaced by the main program in the final version, so we can implement it as code on the Preface form that will be used as the game user interface. In this case, we can create a simple form with a picture Introduction (picBackground) a and button (cmdStart), Chapter 1 - .Nettrix: and GDI+ Collision Detectionwith the code to create the objects and set the properties of theclsSquare class, then call the Draw method: Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Sub CmdStart_Click(sender System.Object, e As System.EventArgs) _ Chapter 4 - River Pla.Net: Tiled GameAs Fields, Scrolling, and DirectAudio
Handles CmdStart.Click - River Pla.Net II: DirectInput and Writing Text to Screen Dim objSquare as clsSquare Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 5 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
objSquare = new clsSquare - .Netterpillars II: Multiplayer Games and Directplay
Chapter 8
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter'9 Set - the Properties Nonmanaged Code
objSquare.location = newPCPoint (40,20) Bonus Chapter Porting .Nettrix to Pocket objSquare.Size = new Size (10,10) objSquare.Forecolor = color.blue Appendix B - Motivations in Games objSquare.BackColor = color.green Appendix C - How Do I Make Games? ' Set the backcolor property of clsGameField class Appendix D - Guidelines for Developing Successful Games clsGameField.backcolor = picBackground.BackColor Appendix A - The State of PC Gaming
Index
List of Figures ' Draws the square List of Tables objSquare.Draw(picBackground.Handle)
End Sub
Running the code, we can see the fruits of our labor: a nice, path gradient-colored square is drawn on screen as shown in Figure 1-23.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Figure first resultsAdventure with GDI+Games, ADO.NET, and DirectShow Chapter 6 - 1-23: Magic Our KindergarteN.: Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Because in our game the squares won't change color or size, we can assign these values when creating the
Chapter - .Netterpillars II: Multiplayer Games Directplay objects,8 creating a New method in the class toand do this, as illustrated in the next code sample: D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Nonmanaged Code
PublicPorting Sub New(InitialSize Bonus Chapter .Nettrix to Pocket PC As size, _ InitialBackcolor As Color, InitialForecolor As Color) size = InitialSize Appendix B - Motivations in Games backcolor = InitialBackcolor Appendix C - How Do I Make Games? forecolor = InitialForecolor Appendix D - Guidelines for Developing Successful Games End Sub Appendix A - The State of PC Gaming
Index
List of Figures List of Tables
So the code for our Start button will be as follows: Sub CmdStart_Click(sender As System.Object, e As System.EventArgs) _ Handles CmdStart.Click Dim objSquare as clsSquare objSquare = new clsSquare (new Size (10,10), color.blue, color.green) ' Set the Location of the square objSquare.location = new Point (40,20) ' Set the backcolor property of clsGameField class clsGameField.backcolor = picBackground.BackColor ' Draws the square objSquare.Draw(picBackground) End Sub
NEW IN In Visual Basic .NET, the New method is called when an object is created, and receives the .NET parameters used in the object's creation. In the previous versions, the corresponding method was called Initialize, and could receive no arguments.
Now that everything is working correctly, let's continue with the coding by looking at the Block class. .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Second Draft: Coding the Block Class Apress © 2003 (696 pages)
We can map the The Block class, the how classeasy diagram for our game project, to the final class authors of defined this textin show it cancreated be to produce interesting multimedia games using and Managed DirectX for 9.0 the andmethods. The proposed class interface including the data types for the properties parameters with Visual interface is shownprogramming in the next code listing:Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Public Class clsBlock Table ofPublic Contents Location as Point .NET Game Public Programming SquareSize with DirectX as integer 9.0 = 10
Private ForeColor As Color Foreword PrefacePrivate BackColor As Color
' The 4 squares that compose the block Introduction square1 As Collision ClsSquare ChapterPublic 1 - .Nettrix: GDI+ and Detection square2 Artificial As ClsSquare ChapterPublic 2 - .Netterpillars: Intelligence and Sprites Public square3 As ClsSquare - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Public square4 As ClsSquare Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Public Function Down() As Boolean Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Public Function Right() As Boolean Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Public Function Left() As Boolean Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Public Sub Rotate() ChapterPublic 8 - .Netterpillars II: Multiplayer Games and Directplay Sub Show(WinHandle As System.IntPtr) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Sub Hide(WinHandle As System.IntPtr) ChapterPublic 9 Nonmanaged Code End Class Chapter 3
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Appendix B - Motivations in Games In the game proposal, we said that the blocks will be composed of four squares (in every possible Appendix arrangement). C - HowWe Do can I Make startGames? the coding by thinking about the possible combinations, and give each of them a
name, as in Figure 1-24. Appendix D shown - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 1-24: The square arrangements to form each block Because each block will have a specific square combination, we can think of three new elements for our class: a BlockType property, an enumeration for the block types, and a New method that creates the squares in the desired positions and the color of each square. To give a visual clue to the player, the colors must be fixed for each block type, so it's a good idea to create arrays to hold the forecolor and backcolor for each type. The extra definitions for the class are shown in the next code listing: Public Enum enBlockType UNDEFINED = 0 SQUARE = 1 LINE = 2 J = 3 L = 4 T = 5 Z = 6 S = 7 End Enum
Public BlockType As enBlockType .NET Game As Programming DirectX 9.0 Private backColors() Color = with _ by Alexandre Santos Lobão and Ellen {Nothing, Color.Red, Color.Blue,ISBN:1590590511 Color.Red, Color.Yellow, _ Hatton Color.Green, Color.White, Color.Black} Apress © 2003 (696 pages) Private foreColors() As Color = _ The authors of this text show how easy it can be to Color.Yellow, produce {Nothing, Color.Purple, Color.LightBlue, _ interesting multimedia games using Managed DirectX 9.0 and Color.Red, Color.LightGreen, Color.Black, Color.White} programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
The New Method Table of Contents
TheGame New method will receive two parameters: the block type and the location where the block will be created. .NET Programming with DirectX 9.0 Since we need random block types, we can make the block type parameter optional, and choose a new Foreword block type inside the New procedure when this isn't given. The default value for the optional parameter must Preface be the UNDEFINED member of the block type enumeration, so we know when the block type isn't given by Introduction the caller Chapter 1 function. - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
We won't use the optional parameter immediately, but it's a good idea to create code following this pattern,
Chapter Managed DirectX First block Steps:type Direct3D Basics and DirectX vs. Rotate GDI+ so we'll3be- able to test a specific easily. For example, if the procedure doesn't work well Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio for the T block type, we can call the New function with the corresponding parameter to allow us to do the Chapter - River Pla.Net DirectInput and Writing Text to Screen testing.5Code to do this isII: shown in the following listing: Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API Public Sub New(location As Point, _
ChapterOptional 8 - .Netterpillars II: Multiplayer and Directplay newBlockType As Games enBlockType = enBlockType.UNDEFINED) Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
' Create the new block, chooses a type if not informed If newBlockType = enBlockType.UNDEFINED Then Appendix A - The State of PC Gaming Randomize() Appendix B - Motivations in Games BlockType = Int(Rnd(7) * 7) + 1 Appendix C -Else How Do I Make Games? Appendix D - Guidelines for Developing Successful Games BlockType = newBlockType Index End If Bonus Chapter Porting .Nettrix to Pocket PC
List of Figures List of Tables' Create each of the squares of the block
' and set the square colors, based on the block type square1 = New ClsSquare(New Size(squareSize, squareSize), backColors(BlockType), foreColors(BlockType)) square2 = New ClsSquare(New Size(squareSize, squareSize), backColors(BlockType), foreColors(BlockType)) square3 = New ClsSquare(New Size(squareSize, squareSize), backColors(BlockType), foreColors(BlockType)) square4 = New ClsSquare(New Size(squareSize, squareSize), backColors(BlockType), foreColors(BlockType)) ' Set the squares' positions based on the block type Select Case BlockType Case enBlockType.SQUARE ' Creates a Square block Case enBlockType.LINE ' Creates a Line block Case enBlockType.J ' Creates a J block Case enBlockType.L ' Creates an L block Case enBlockType.T ' Creates a T block Case enBlockType.Z
_ _ _ _
' Creates a Z block .NET Game Programming with DirectX 9.0 Case enBlockType.S by Alexandre'Santos Lobão an and SEllen Creates block Hatton End Select Apress © 2003 (696 pages) End Sub
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest In this sample, the code inside each case statement must set the square positions, based on each block version of Microsoft's Visual Studio.
type, according to Figure 1-24. For example, let's analyze the Square block type, depicted in Figure 1-25. Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection Figure The squares forIntelligence the Squareand block type Chapter 2 - 1-25: .Netterpillars: Artificial Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
The code for creating the Square block type is shown here:
Case enBlockType.SQUARE Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow square1.location = New Point(location.X, location.Y) Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API square2.location = New Point(location.X + SquareSize, location.Y) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay square3.location = New Point(location.X, location.Y + SquareSize) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter square4.location 9 = New Point(location.X + SquareSize, _ Nonmanaged Code location.Y + SquareSize) Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B -Line Motivations in Games As for the block type, the squares that compose it are shown in Figure 1-26. Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 1-26: The squares for the Line block type The code for the Line block type is as follows: Case enBlockType.LINE square1.location square2.location square3.location square4.location
= = = =
New New New New
Point(location.X, Point(location.X, Point(location.X, Point(location.X,
location.Y) location.Y + SquareSize) location.Y + 2 * SquareSize) location.Y + 3*SquareSize)
The code for the other blocks follows the same idea. For the full code of the New method, check the samples on the accompanying CD-ROM. Once the blocks are created, we can start coding the moving operations over them, as described in the next
section.
.NET Game Programming with DirectX 9.0
by Alexandre Santos Lobão and Ellen The Down, Right, and Left Methods
ISBN:1590590511
Hatton Apress © 2003the (696class pages)diagram order, are Down, Right, and Left. These methods are fairly The next methods, following Theneed authors of is this show how easyposition it can be simple, since all we to do to text update the block in to theproduce defined direction, regardless of the block interesting games could using Managed DirectX 9.0 and type. The basic code for themultimedia Down procedure be as simple as this: programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Public Function Down() As Boolean Down = true Table of' Contents Hide the block (in the previous position) .NET Game Programming with DirectX 9.0 Hide(ClsGameField.WinHandle) Foreword ' Update the block position Prefacesquare1.location=New Point(square1.location.X, _ Introduction square1.location.Y + SquareSize) Chaptersquare2.location=New 1 - .Nettrix: GDI+ and Collision Point(square2.location.X, Detection _ square2.location.Y + SquareSize) Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Point(square3.location.X, Chaptersquare3.location=New 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. _ GDI+ Chapter 4 - River Pla.Net: Tiled Game Fields, square3.location.Y Scrolling, and DirectAudio + SquareSize) Point(square4.location.X, _ Chaptersquare4.location=New 5 - River Pla.Net II: DirectInput and Writing Text to Screen square4.location.Y + SquareSize) Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ' Draw the block in the new position Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Show(ClsGameField.WinHandle) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Function Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
Because we'll need to hide and redraw the block every time these methods are called, we can reduce the
Appendix A - The State of PC Gaming calling overhead by creating a new shared property on the GameField class, the WinHandle used in the Appendix B Motivations in handle Games of the pictureBox used as the game field on the form. With this approach, preceding code, and the Appendix C - this Howproperty Do I Make Games? we can set in the New method and use it for every drawing operation, instead of passing the Appendix D -aGuidelines handle as parameterfor toDeveloping the drawingSuccessful methods Games every time it's called. Index
The List ofRight Figuresand Left methods will be similar to this one, except this time the horizontal block position is changed-incrementing it to move the block to the right and decrementing it to move the block to the left. We List of Tables
are moving the blocks using the default value of the SquareSize property, assigned to 10 in the class definition. This means that the blocks will always move a square down, left, or right, so we don't have to take worry about the squares' alignment. There's one more detail to include in this procedures: the test for collision detection. The block can't move down, left, or right if there are any squares (or screen limits) in the way. Since the block itself can't know if other blocks are in the way, it must ask the GameField class if it can move this way. We already thought about this in the game project: The IsEmpty method of the GameField class will check if a specified square in the game field is empty. In the Down method, we must check if there are any blocks in the way and stop falling if we hit an obstacle. When the block stops falling, we must inform the Game-Field class of this, so it can update its internal controls to allow the proper function of the IsEmpty method. We can do this by creating a new method, namedStopSquare, which will inform the GameField that a specific square is now not empty, and pass the square object and its coordinates as parameters. After that, each square will be treated separately from each other (no more blocks) by the GameField class, because when a line is removed, some squares of the block can be removed while others remain. Since the IsEmpty and StopSquare methods are based on an array of Squares,ArrGameField (as defined in our game project), the logical approach is for these methods to receive the array coordinates to be used. We can translate screen coordinates to array positions by simply dividing the x and y position of each square by the square size. The final code for the down procedure will now be as follows:
.NET Game Programming with DirectX 9.0
Public Function Down() As Boolean ISBN:1590590511 by Alexandre Santos Lobão and Ellen Down = True Hatton ' If there's block below the current one, go down Apress no © 2003 (696 pages) If ClsGameField.IsEmpty(square1.location.X / SquareSize, The authors of this text show how easy it can be to produce square1.location.Y / 9.0 SquareSize + 1) _ interesting multimedia games using Managed DirectX and And ClsGameField.IsEmpty(square2.location.X programming with Visual Basic .NET on Everett, the latest/ SquareSize, _ version of Microsoft's Visual Studio. square2.location.Y / SquareSize + 1) _ And ClsGameField.IsEmpty(square3.location.X / SquareSize, _ square3.location.Y / SquareSize + 1) _ Table of Contents And ClsGameField.IsEmpty(square4.location.X / SquareSize, _ .NET Game Programming with DirectX 9.0 square4.location.Y / SquareSize + 1) Then Foreword ' Hide the block (in the previous position) Preface Hide(ClsGameField.picGameField) Introduction ' Update the block position Chapter 1 -square1.location .Nettrix: GDI+ and Collision Detection = New Point(square1.location.X, _ Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites square1.location.Y + SquareSize) Chapter 3 -square2.location Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ = New Point(square2.location.X, _ Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio square2.location.Y + SquareSize) Chapter 5 -square3.location River Pla.Net II: DirectInput = New and Point(square3.location.X, Writing Text to Screen _ square3.location.Y + SquareSize) Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow square4.location = New Point(square4.location.X, _ Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API square4.location.Y + SquareSize) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay 'D-iNfEcT: Draw the block in the new position Multithreading, Nonrectangular Windows, and Access to Chapter 9 Show(ClsGameField.picGameField) Nonmanaged Code Else Porting .Nettrix to Pocket PC Bonus Chapter IfState there's a block below the current one, don't go down Appendix A -'The of PC Gaming ' -> put it on Appendix B - Motivations in Gamesthe array that controls the game and return FALSE = I False Appendix C -Down How Do Make Games? ClsGameField.StopSquare(square1, _ square1.location.X / SquareSize, Appendix D - Guidelines for Developing Successful Games square1.location.Y / SquareSize) Index ClsGameField.StopSquare(square2, _ List of Figures square2.location.X / SquareSize, square2.location.Y / SquareSize) List of Tables ClsGameField.StopSquare(square3, _ square3.location.X / SquareSize, square3.location.Y / SquareSize) ClsGameField.StopSquare(square4, _ square4.location.X / SquareSize, square4.location.Y / SquareSize) End If End Function
In this code sample, we are using the GameField class again with shared methods (no objects created). The concepts of shared properties and methods were explained earlier in this chapter. TheRight and Left methods are very similar to this one, with the slight difference that we don't stop the block if it can't go right or left. The code for the Right method is shown next. The Left method is built upon the same basic structure. Public Function Right() As Boolean Right = True ' If there's no block to the right of the current one, go right If ClsGameField.IsEmpty(square1.location.X / SquareSize + 1, _ square1.location.Y / SquareSize) _ And ClsGameField.IsEmpty(square2.location.X / SquareSize + 1, _ square2.location.Y / SquareSize) _
And ClsGameField.IsEmpty(square3.location.X / SquareSize + 1, .NET Game Programming with DirectX / 9.0SquareSize) _ square3.location.Y ISBN:1590590511 by Alexandre Santos Lobão and Ellen And ClsGameField.IsEmpty(square4.location.X / SquareSize + 1, Hatton square4.location.Y / SquareSize) Then Apress © 2003 (696 pages) ' Hide the block (in the previous position) The authors of this text show how easy it can be to produce Hide(ClsGameField.picGameField) interesting multimedia games using Managed DirectX 9.0 and ' Update the block position programming with Visual Basic .NET on Everett, the latest square1.location = New + SquareSize, version of Microsoft's VisualPoint(square1.location.X Studio. square1.location.Y) square2.location = New Point(square2.location.X + SquareSize, Table of Contents square2.location.Y) .NET Game Programming with DirectX=9.0 square3.location New Point(square3.location.X + SquareSize, Foreword square3.location.Y) Preface square4.location = New Point(square4.location.X + SquareSize, Introduction square4.location.Y) Draw GDI+ the block in the new position Chapter 1 -'.Nettrix: and Collision Detection Chapter 2 -Show(ClsGameField.picGameField) .Netterpillars: Artificial Intelligence and Sprites ChapterElse 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ there's a Tiled block toFields, the Scrolling, right of current one, Chapter'4 If- River Pla.Net: Game and the DirectAudio go right and return FALSE Chapter'5 doesn't - River Pla.Net II: DirectInput and Writing Text to Screen Right = False Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow End If Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API End Function Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
_ _
_ _ _ _
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
The next method for the Block class, Rotate, is a little more complicated, so we'll take a closer look at it in thenext section.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games The Rotate Method Appendix C - How Do I Make Games?
While in Dthe previouslyfor discussed methods all we needed to do was to change a single coordinate for all the Appendix - Guidelines Developing Successful Games squares of the block (incrementing y to go down, and modifying x to go right or left), in this case we need to Index change the squares' positions, one by one, to achieve the effect of rotation. The rotation movement must be List of Figures based on the block type and on the current orientation of the block. List of Tables To track the current rotation applied to the block, we'll need a new property. Creating a new enumeration for the possible rotation status will make our code more readable: Public Enum enStatusRotation NORTH = 1 EAST = 2 SOUTH = 3 WEST = 4 End Enum Public StatusRotation As enStatusRotation = enStatusRotation.NORTH
In order to make the method simpler, and to avoid calculating the rotation twice-once to test for empty squares and again to rotate the block-we'll store the current position, rotate the block, and then test to see if the squares of the new block position are empty. If so, we just draw the block in the new position. If not, we restore the previous position. The basic structure for the method (without the rotation code for each block type) is shown next: Public Sub Rotate() ' Store the current block position
Dim OldPosition1 As Point =square1.location .NET Game As Programming with DirectX 9.0 Dim OldPosition2 Point =square2.location ISBN:1590590511 by Alexandre Santos Lobão and Ellen Dim OldPosition3 As Point = square3.location Hatton Dim OldPosition4 As Point = square4.location Apress © 2003 (696 pages) Dim OldStatusRotation as enStatusRotation = StatusRotation The authors of this text show how easy it can be to produce Hide(ClsGameField.picGameField)
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest ' Rotate version the blocks of Microsoft's Visual Studio.
Select Case BlockType Case enBlockType.SQUARE Table of Contents ' Here will go the code for rotate this block .NET Game Programming with DirectX 9.0 Case enBlockType.LINE Foreword ' Here will go the code for rotate this block Preface Case enBlockType.J Introduction ' Here will go the code for rotate this block enBlockType.L Chapter 1 -Case .Nettrix: GDI+ and Collision Detection ' Here Artificial will go the code for rotate this block Chapter 2 - .Netterpillars: Intelligence and Sprites enBlockType.T Chapter 3 -Case Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Here Tiled will go Fields, the code for rotate this block Chapter 4 - River'Pla.Net: Game Scrolling, and DirectAudio enBlockType.Z Chapter 5 -Case River Pla.Net II: DirectInput and Writing Text to Screen ' Here will go the code for rotate this block Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Case enBlockType.S Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API ' Here will go the code for rotate this block Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Select Chapter 9
-
type type type type type type type
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
' After rotating the squares, test if they overlap other squares. ' If so, return to original position Appendix A - The State of PC Gaming If Not (ClsGameField.IsEmpty(square1.location.X / SquareSize, _ Appendix B - Motivations in Games square1.location.Y / SquareSize) _ Appendix C - How Do I Make Games? And ClsGameField.IsEmpty(square2.location.X / SquareSize, _ Appendix D - Guidelines for Developing Successful Games square2.location.Y / SquareSize) _ Index And ClsGameField.IsEmpty(square3.location.X / SquareSize, _ List of Figures square3.location.Y / SquareSize) _ List of TablesAnd ClsGameField.IsEmpty(square4.location.X / SquareSize, _ square4.location.Y / SquareSize)) Then StatusRotation = OldStatusRotation square1.location = OldPosition1 square2.location = OldPosition2 square3.location = OldPosition3 square4.location = OldPosition4 End If ' Draws the square at the correct position Show(ClsGameField.picGameField) End Sub Bonus Chapter Porting .Nettrix to Pocket PC
Based on each block type and its current status, we can calculate the rotations. There will be three types of rotation: Square blocks: These do nothing. Squares don't need to rotate since they look the same when rotated. Line, S, and Z blocks: These will have only two possible directions for rotation, north and east. T, J, and L blocks: These will have four different positions, north, east, south, and west.
In any case, we must choose a specific square to stay fixed while the others rotate around it. In the examples .NETwhat Game Programming with statement DirectX 9.0 that follow, we show must be in each case of the Rotate method, starting with the rotation ISBN:1590590511 by Alexandre Santos Lobão and Ellen for a Line block type, represented in Figure 1-27. Hatton Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Figure 1-27: Line block- rotation around the second square Preface
The code to implement the rotation of the Line block is shown in the next code listing: Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection Select StatusRotation Chapter 2 Case - .Netterpillars: Artificial Intelligence and Sprites
Case Chapter 3 -enStatusRotation.NORTH Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ enStatusRotation.EAST Chapter 4 StatusRotation - River Pla.Net: Tiled = Game Fields, Scrolling, and DirectAudio = Newand Point(_ Chapter 5 square1.location - River Pla.Net II: DirectInput Writing Text to Screen square2.location.X - ADO.NET, SquareSize, square2.location.Y) - Magic KindergarteN.: Adventure Games, and DirectShow square3.location = New Point(_ Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API square2.location.X + SquareSize, square2.location.Y) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay square4.location = New Point(_ D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 square2.location.X + 2 * SquareSize, square2.location.Y) Nonmanaged Code Case enStatusRotation.EAST Bonus Chapter Porting .Nettrix to Pocket PC StatusRotation = enStatusRotation.NORTH Appendix A - The State of PC Gaming square1.location = New Point(_ Appendix B - Motivations in Games square2.location.X, square2.location.Y - SquareSize) Appendix C - How Do I Make Games? square3.location = New Point(_ Appendix D - Guidelines for Developing Successful Games square2.location.X, square2.location.Y + SquareSize) Index square4.location = New Point(_ List of Figures square2.location.X, square2.location.Y + 2 * SquareSize) List of Tables End Select Chapter 6
Notice that the new square positions are all based on the position of the second square of the block; we just add or subtract the square sizes to move the square up and down (y coordinate) or right and left (x coordinate). In each case, we set the new status of the rotation. Figure 1-28 illustrates the rotation for the Z block type. The S and Z block types rotate in a very similar way.
Figure 1-28: The Z block rotation Following is the code for the Z block type; the S block follows the same logic. Select Case StatusRotation Case enStatusRotation.NORTH StatusRotation = enStatusRotation.EAST square1.location = New Point(square2.location.X, _
square2.location.Y - SquareSize) .NET Game Programming with DirectX 9.0 square3.location = New Point(square2.location.X - SquareSize, _ ISBN:1590590511 by Alexandre Santos Lobão and Ellen square2.location.Y) Hatton square4.location = New Point(square2.location.X - SquareSize, _ Apress © 2003 (696 pages) square2.location.Y + SquareSize) The authors of this text show how easy it can be to produce Case enStatusRotation.EAST interesting multimedia games using Managed DirectX 9.0 and StatusRotation = enStatusRotation.NORTH programming with Visual Basic .NET on Everett, the latest square1.location = New - SquareSize, _ version of Microsoft's VisualPoint(square2.location.X Studio. square2.location.Y) square3.location = New Point(square2.location.X, _ Table of Contents square2.location.Y + SquareSize) .NET Game Programming with DirectX=9.0 square4.location New Point(square2.location.X + SquareSize, _ Foreword square2.location.Y + SquareSize) Preface End Select Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection As for the J, and L block types,Intelligence the procedure be a little longer, since we have four directions, but the Chapter 2 -T,.Netterpillars: Artificial and will Sprites
basic idea -remains the same: All squares run around a fixed one. Let's see some examples, starting with the Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ T block type rotation, portrayed in Figure 1-29.
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
1-29: Rotation ofto the T block BonusFigure Chapter Porting .Nettrix Pocket PC Appendix A - The State of PC Gaming Appendix - Motivations in Games the rotation illustrated in Figure 1-29: The nextBcode listing implements Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
Select Case StatusRotation
Index Case enStatusRotation.NORTH List of Figures StatusRotation = enStatusRotation.EAST List of Tables square1.location = New Point(square2.location.X, _
square2.location.Y - SquareSize) square3.location = New Point(square2.location.X, _ square2.location.Y + SquareSize) square4.location = New Point(square2.location.X - SquareSize, _ square2.location.Y) Case enStatusRotation.EAST StatusRotation = enStatusRotation.SOUTH square1.location = New Point(square2.location.X + SquareSize, _ square2.location.Y) square3.location = New Point(square2.location.X - SquareSize, _ square2.location.Y) square4.location = New Point(square2.location.X, _ square2.location.Y - SquareSize) Case enStatusRotation.SOUTH StatusRotation = enStatusRotation.WEST square1.location = New Point(square2.location.X, _ square2.location.Y + SquareSize) square3.location = New Point(square2.location.X, _ square2.location.Y - SquareSize) square4.location = New Point(square2.location.X + SquareSize, _ square2.location.Y) Case enStatusRotation.WEST
StatusRotation = enStatusRotation.NORTH .NET Game = Programming with DirectX 9.0 square1.location New Point(square2.location.X - SquareSize, _ ISBN:1590590511 by Alexandre Santos Lobão and square2.location.Y) Ellen Hatton square3.location = New Point(square2.location.X + SquareSize, _ Apress © 2003 (696 pages) square2.location.Y) The authors = of this show how easy it can be to produce_ square4.location Newtext Point(square2.location.X, interesting multimedia games using Managed DirectX 9.0 and square2.location.Y programming with Visual Basic .NET on Everett, the latest + SquareSize) End Select version of Microsoft's Visual Studio. Table Contents The of code for rotating the J and L blocks is pretty much like the preceding code sample. The main difference .NET is that Game these Programming blocks will rotate with DirectX around 9.0 the third square, as shown in the rotation for the J block illustrated in
Figure 1-30. Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Figure 1-30: Rotation for the J block
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to The last Chapter 9 two - methods for the Block class are discussed in the next section. Nonmanaged Code Bonus .Nettrix to Pocket PC The Chapter Show Porting and Hide Methods Appendix A - The State of PC Gaming
The implementation of in theGames Show and Hide methods is very straightforward: the Show and Hide methods are Appendix B - Motivations called for the blockGames? squares, as shown here: Appendix C each - Howof Do I Make Appendix D - Guidelines for Developing Successful Games Index Public Sub Show(WinHandle As System.IntPtr)
Draws each square of the block on the game field List of'Figures List ofsquare1.Show(WinHandle) Tables
square2.Show(WinHandle) square3.Show(WinHandle) square4.Show(WinHandle) End Sub Public Sub Hide(WinHandle As System.IntPtr) ' Hides each square of the block on the game field square1.Hide(WinHandle) square2.Hide(WinHandle) square3.Hide(WinHandle) square4.Hide(WinHandle) End Sub
To see the full code for the Block class, refer to the samples on the accompanying CD-ROM. To test our new class, we'll have to create a new stub for the GameField class and update our main program, as shown in the next section.
Testing the Block Class The new stub for the GameField class must include the properties and methods accessed by the Block
class, as shown in the next code listing:
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Public Class Hatton ClsGameField Public Shared backcolor As Color Apress © 2003 (696 pages) Public Shared WinHandle As System.IntPtr The authors of this text show how easy it can be to produce
interesting multimedia games using Managed DirectX 9.0 and
Public Shared programming Function with IsEmpty(x Visual Basic .NET As on Integer, Everett, the y latest As Integer) As Boolean version of Microsoft's IsEmpty = True Visual Studio. End Function Public Shared Function StopSquare(Square As ClsSquare, _ Table of Contents x As Integer, y As Integer) As Boolean .NET Game Programming with DirectX 9.0 StopSquare = True Foreword End Function Preface End Class Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection TheIsEmpty and StopSquare always return True; we'll add code for these methods in the final Chapter 2 - .Netterpillars: Artificial methods Intelligence and Sprites
version3of -the program. Chapter Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
The next code listing shows the logic for testing the Block class, and must be included in the game field - River Pla.Net II: DirectInput and Writing Text to Screen form:
Chapter 5 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Private -CurrentBlock as clsBlock .Netterpillars II: Multiplayer Games and Directplay
Chapter 8
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Sub Form_Load(sender Nonmanaged CodeAs System.Object, e As System.EventArgs) _
Handles MyBase.Load Bonus Chapter Porting .Nettrix to Pocket PC ' Set the properties of clsGameField class clsGameField.backcolor = picBackground.BackColor Appendix B - Motivations in Games clsGameField.picGameField = PicBackground Appendix C - How Do I Make Games? End Sub Appendix A - The State of PC Gaming
Appendix D - Guidelines for Developing Successful Games Index
Sub CmdStart_Click( sender As System.Object, e As System.EventArgs) _ Handles CmdStart.Click List of Tables CurrentBlock = new clsBlock(new Point (40,20)) CurrentBlock.Show(PicBackground) End Sub Private Sub Form1_KeyDown(sender As Object, _ e As System.Windows.Forms.KeyEventArgs) Handles MyBase.KeyDown Select Case e.KeyCode Case Keys.Right CurrentBlock.Right() Case Keys.Left CurrentBlock.Left() Case Keys.Up CurrentBlock.Rotate() Case Keys.Down CurrentBlock.Down() End Select End Sub List of Figures
Game in Programming with DirectX 9.0 NEW All the.NET constants the .NET Framework are organized within enumerations. This approach Santos Lobão and Ellen IN allowsbya Alexandre more intuitive organization, so it's easier toISBN:1590590511 find exactly what you need in the help feature. Hatton .NET The intelligence of Visual Studio was also improved, giving more hints and softening the learning 2003 (696 pages) curve.Apress In the ©preceding sample code, we are using the Keys enumeration to get the key code authors of this text show can be totoproduce (Left, The Down, Up, and Right). Therehow are easy also itmodifiers test if Shift, Ctrl, and Alt keys are interesting multimedia games using Managed DirectX 9.0 and pressed. The namespace for the Keys enumeration is SYSTEM.Windows.Forms. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
To test the program, just run it, click the Start button, and press the various keys to move the blocks: the down arrow key makes the block go down, the up arrow key rotates the block, and the right arrow and left arrow move the block horizontally. Clicking the Start button again will create a new block, so we can Table ofkeys Contents test Game the random creationwith of different block types. A sample screen is shown in Figure 1-31. .NET Programming DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 1-31: Testing the Block class
In the next section we'll implement the collision detection and the main program logic, finishing our game.
Final Version: Coding the GameField Class and the Game Engine To finish our program, we'll have to complete the code for the game engine and the GameField class, as shown in the next sections.
GameField Class Let's examine the code to implement the interface for the GameField class, as defined in our game project. Public Class ClsGameField Public Const Width As Integer = 16 Public Const Height As Integer = 30 Public Const SquareSize As Integer = 10 Public Shared WinHandle As System.IntPtr Public Shared backcolor As Color Private Shared arrGameField(Width, Height) As ClsSquare Public Shared Function IsEmpty(x As Integer, y As Integer) As Boolean
Public Shared Function CheckLines() As Int16 .NET Game Programming with DirectX 9.0 As ClsSquare, _ Public Shared Function StopSquare(Square ISBN:1590590511 by AlexandrexSantos Lobão and As Integer, Ellen y As Integer) As Boolean Hatton Public Shared Function Redraw() As Boolean Apress © 2003 (696 pages) End Class The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest TheGameField version interface shown in the preceding code has its members (properties and methods) defined of Microsoft's Visual Studio.
in the class diagram proposed in the game project, plus the new properties and methods defined in the stubs we created previously. Then again, although it isn't unusual that such changes really happen in a real-life Table of Contents project, it's one of our goals to define a clear and comprehensive project before starting to code. Remember, .NET changing Game a Programming project is farwith easier DirectX (and9.0 cheaper) than changing and adapting code; and that if there are many unpredictable changes to code, the project tends to be more prone to errors and more difficult to maintain. Foreword (We refer to this as the "Frankenstein syndrome": the project will be no longer a single and organized piece Preface of code, but many not so well-sewed-on parts.) Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
One interesting point about this class is that every member is declared as shared! In other words, we can - .Netterpillars: Artificial Intelligence and Sprites access any method or property of the class without creating any objects. This isn't the suggested use of Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ shared properties or methods; we usually create shared class members when we need to create many Chapter - River Pla.Net: Tiled some Game information-such Fields, Scrolling, and objects4in the class, and have as DirectAudio a counter for the number of objects created, or Chapter 5 River Pla.Net II: DirectInput and Writing Text properties that, once set, affect all the objects created. to Screen Chapter 2
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow The next discuss the GameField class methods, Chapter 7 sections - Magic KindergarteN. II: Animation Techniques andstarting Speechwith API the IsEmpty method. Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
The IsEmpty Method D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
The first class method, IsEmpty, must check if a given x,y position of the game array (arrGameField) is empty. The next method, CheckLines, has to check each of the lines of the array to see if any one of them Appendix A - The State of PC Gaming is full of squares, and remove any such lines. Bonus Chapter Porting .Nettrix to Pocket PC Appendix B - Motivations in Games
Appendix C arrGameField - How Do I Make Games? Since the is an array of Square objects, we can check if any position is assigned to a Appendix D - Guidelines for Developing Successful Games square with a simple test: Index List of Figures Public Shared Function IsEmpty(x As Integer, y As Integer) _ List of Tables As Boolean
If arrGameField(x,y) is nothing IsEmpty = True Else IsEmpty = False End if End Function
Some extra tests should be done to see if the x or the y position is above (or below) the array boundaries. Although in this game we don't need high-speed calculations, we can use an improved algorithm for collision detection, so that we can see a practical example of using these algorithms. We can improve the performance of the IsEmpty and CheckLines functions using an array of bits to calculate the collisions. Since our game field is 16 squares wide, we can create a new array of integers, where each bit must be set if there's a square associated with it. We still must maintain the arrGameField array, because it will be used to redraw the squares when a line is erased or the entire game field must be redrawn (for example, when the window gets the focus after being belowother window). The array that holds the bits for each line must have the same Height as the arrGameField, and will have just one dimension, since the Width will be given for the bits in each integer (16 bits per element). The array definition is shown in the next code line:
Private Shared arrBitGameField(Height) As Integer .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton And the IsEmpty function is as follows: Apress © 2003 (696 pages) authors of this text show how easy it can be to produce Public SharedThe Function IsEmpty(x As Integer, y As Integer) _ interesting multimedia games using Managed DirectX 9.0 and As Visual Boolean programming with Basic .NET on Everett, the latest IsEmpty =version Trueof Microsoft's Visual Studio. ' If the Y or X is beyond the game field, return false If (y < 0 Or y >= Height) Or (x < 0 Or x >= Width) Then Table of Contents IsEmpty = False .NET Game Programming with bit DirectX ' Test the Xth of9.0 the Yth line of the game field Foreword ElseIf arrBitGameField(y) And (2 ^ x) Then Preface IsEmpty = False Introduction End If Chapter End Function 1 - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
In this sample code, the first if statement checks whether the x and y parameters are inside the game field - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio range. The second if deserves a closer look: What is arrBitGameField(y) And (2 ^ x) supposed Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen to test? In simple words, it just checks the xth bit of the arrBitGameField(y) byte. Chapter 4 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 -of Magic II: Animation Techniquesoperators and Speech This piece codeKindergarteN. works well because the comparison of API Visual Basic, since earlier versions, work Chapter 8 -way. .Netterpillars Multiplayer andaDirectplay in a binary The ANDII: operator thenGames performs bit-to-bit comparison, and returns a combination of both D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to operands. Chapter 9 -If the same bit is set in both operands, this bit will be set in the result; if only one or none of the Nonmanaged Code operators have the bit set, the result won't have the bit set. In Table 1-4 we show the operands' bits for some Bonus Chapter Porting .Nettrix to Pocket PC AND comparisons. Appendix A - The State of PC Gaming Appendix B - Bits Motivations in Games Table 1-4: and Results for Some AND Operations Appendix C - How Do I Make Games?
NUMBERS
BITS
Appendix D - Guidelines for Developing Successful Games Index 1 AND 2 = 0 List of Figures
01 AND 10 = 0 (false)
3 AND 12 = 0
0011 AND 1100 = 0000 (false)
3 AND 11 = 3
0011 AND 1011 = 0011 (true)
List of Tables
In our code, if we want to check, for example, the 7th bit, the first operand must be the array element we want to check, arrBitGameField(Y), and the second operand must have the bits 00000000 01000000 (16 bits total, with the 7th one checked). If we did our binary homework well, we'd remember that setting the bits one by one results in powers of 2: 1, 2, 4, 8, 16, and so on, for 00001, 00010, 00100, 01000, 10000, etc. The easiest way to calculate powers of 2 is just to shift the bits to the left; but since we have no bit shift operators in Visual Basic, we need to use the power operator (^). Looking again at the second if statement, everything should make sense now: arrBitGameField(y): The 16 bits of the yth line of the game field. 2^x: Calculates a number with only one bit set-the xth one. arrBitGameField(y) And (2 ^ x): If the xth bit of the array element is set, then the test will return a nonzero number; any other bit set won't affect the result, since the second operand has only the xth bit set. TheCheckLines method will use this same bit array to more easily check if a line is filled with squares, as we'll discuss next.
The CheckLines method .NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen In the next GameField method, CheckLines, we need to check if a line is totally filled (all bits set) and, if Hatton so, erase this line and move down all the lines above it. We don't need to copy the empty lines (all bits reset) Apress © 2003 (696 pages) one on top of another, but we must return the number of cleared lines. To improve the readability of our authors of this text show how easy it can be to produce code, we'll defineThe some private constants for the class:
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest of Microsoft's Visual Studio. Private Constversion bitEmpty As Integer = &H0& '00000000 0000000
Private Const bitFull As Integer = &HFFFF&
'11111111 1111111
Table of Contents .NET Programming with DirectX SeeGame the comments in the code and 9.0 the following explanation to understand the function: Foreword Preface
Public Shared Function CheckLines() As Integer Dim y As Integer, x As Integer ChapterDim 1 -i.Nettrix: GDI+ and Collision Detection As Integer ChapterCheckLines 2 - .Netterpillars: = 0 Artificial Intelligence and Sprites Chaptery3 = -Height Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ 1 ChapterDo 4 While - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio y >= 0 Chapter 5 -'River Pla.Net II: DirectInput Writing Text lines to Screen stops the loop whenand the blank are reached Chapter 6 -If Magic arrBitGameField(y) KindergarteN.: Adventure= Games, bitEmpty ADO.NET, Then andyDirectShow = 0 If KindergarteN. all the bits of the Techniques line areand set, then Chapter 7 -'Magic II: Animation Speech API increment the counter to clear the and line and move all above lines down Chapter 8 -'.Netterpillars II: Multiplayer Games Directplay If arrBitGameField(y) = bitFull Then and Access to D-iNfEcT: Multithreading, Nonrectangular Windows, Chapter 9 Nonmanaged ' SameCode as: If (arrBitGameField(y) Xor bitFull) = 0 Then CheckLines += 1 PC Bonus Chapter Porting .Nettrix to Pocket Introduction
Appendix A - The State of PC Gaming
' Move all next lines down Appendix B - Motivations in Games ForI Make i = Games? y To 0 Step -1 Appendix C - How Do the current is NOT the first of the game field, Appendix D - Guidelines ' forif Developing Successfulline Games Index List of Figures List of Tables
' copy the line above If i > 0 Then ' Copy the bits from the line above arrBitGameField(i) = arrBitGameField(i - 1) ' Copy each of the squares from the line above For x = 0 To Width - 1 ' Copy the square arrGameField(x, i) = arrGameField(x, i - 1) ' update the Location property of the square Try With arrGameField(x, i) .location = New Point(.location.X, _ .location.Y + SquareSize) End With Catch ' Ignore the error if arrGameField(x, y) is Nothing End Try Next Else ' if the current line is the first of the game field ' just clear the line arrBitGameField(i) = bitEmpty For x = 0 To Width - 1 arrGameField(x, i) = Nothing Next
End If .NET Game Programming with DirectX 9.0 Next Else by Alexandre Santos Lobão and Ellen Hatton y -= 1 Apress © 2003 (696 pages) End If
ISBN:1590590511
The authors of this text show how easy it can be to produce Loop interesting multimedia games using Managed DirectX 9.0 and End Function programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table ofpreceding Contents code sample, two points need more explanation: the structured error handling and the bit In the .NET checking Game logic. Programming with DirectX 9.0 Foreword
NEW .NET introduced in Visual Basic structured error handling, an old item on the wish list of IN programmers. Structured error handling is composed of three blocks-Try,Catch, and FinallyIntroduction .NET as shown in the code sample that follows. The Catch block receives a variable that is filled with Chapter 1 - .Nettrix: GDI+ and Collision Detection information about the exception, and could be used to do proper error handling. Preface
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
Try - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio ' Statements that and could cause anScreen error - River Pla.Net II: DirectInput Writing Text to Catch e As Exception - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ' Code to be II: executed if an occurred in the Try block - Magic KindergarteN. Animation only Techniques and error Speech API Finally - .Netterpillars II: Multiplayer Games and Directplay ' Code to de executed in any situation, the Try block D-iNfEcT: Multithreading, Nonrectangular Windows, and Accessafter to End Nonmanaged Try Code
Chapter 5 Chapter 6 Chapter 7 Chapter 8 Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
In the CheckLines method, we use structured error handling in order to avoid an extra test when copying squares. Since we can copy a square or an empty variable, we should test to see if the Square variable is Appendix C - How Do I Make Games? set before setting the Location property, to avoid errors. Using error handling, the error is just ignored, with Appendix D - Guidelines for Developing Successful Games no collateral effects. The test we avoid is this one: Appendix B - Motivations in Games
Index
List of Figures
If arrBitGameField(y - 1) And (2 ^ x) Then ' Same as: If arrGameField(x, y - 1) = Nothing then With arrGameField(x, y) .location = New Point(.location.X,.location.Y + squaresize) end with end if
List of Tables
In the CheckLines method we can see the real benefits of creating arrBitGameFieldfor collision detection: We can check if a line is completely filled or empty with only one test, with the use of bitFull andbitEmpty constants we previously created, avoiding the 16 tests we would have had to create for each of the ArrGameField members in a line. The next code listing highlights these tests: If arrBitGameField(y) = bitFull Then If arrBitGameField(y) = bitEmpty Then
' The line is full ' The line is empty
Thenext section discusses the last two methods for the GameField class.
The StopSquare and Redraw Methods The last two methods, StopSquare (which sets the arrays when a block stops falling) and Redraw (which redraws the entire game field), have no surprises. The code implementing these methods is shown in the next listing:
Game Programming with DirectXAs 9.0ClsSquare, _ Public Shared.NET Function StopSquare(Square ISBN:1590590511 by AlexandrexSantos As Integer, Lobão and Ellen y As Integer) As Boolean Hatton arrBitGameField(y) = arrBitGameField(y) Or (2 ^ x) Apress © 2003 arrGameField(x, y)(696 = pages) Square End Function The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Public Sharedversion Function Redraw() As Boolean of Microsoft's Visual Studio.
Dim x As Integer, y As Integer ' at first, clear the game field Table of picGameField.Invalidate() Contents Application.DoEvents() .NET Game Programming with DirectX 9.0 Foreword
Preface ' Draws all the squares until reaching the empty lines
y = Height - 1 Introduction >= 0 arrBitGameField(y) <> bitEmpty Chapter Do 1 -While .Nettrix:yGDI+ andAnd Collision Detection For x = Width - 1 To 0 Step -1 Try Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ arrGameField(x, y).Show(picGameField) Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Catch Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen ' there's no square do draw... do nothing Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow End Try Chapter 7 - Magic NextKindergarteN. II: Animation Techniques and Speech API Chapter Loop 8 - .Netterpillars II: Multiplayer Games and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to End Function Chapter 9 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
NEW Visual the graphic routines went through a major transformation, making them Appendix C - In How Do I Basic Make .NET, Games? IN D - much closer the underlying graphics API , the DLLs for graphics operations. One example is Appendix Guidelines forto Developing Successful Games Index.NET
shown in the preceding code: The previous CLS method is now called Invalidate, and can be List of Figuresused to invalidate the whole Image object (and then force it to be redrawn) or receive a specific List of Tables rectangular structure, which tells us exactly which part of the image must be redrawn. Those who worked with graphics manipulation in the C language will be comfortable with this new notation as it's the same in both languages. Another interesting point is that many functions from the earlier versions of Visual Basic are organized into objects and methods.We can see the math functions compiled as methods into theMath object, or, in the preceding sample, system functions like DoEvents organized as methods of the Application object. This is another useful group of functions that are organized as methods from the System object. Thenext section shows the code for the final version of the main program, finishing our game code.
The Game Engine Now that all the base classes are coded, let's finish the main procedures. In the first drafts for the game engine, we used the form procedures to call methods in our base classes, so we could see if they were working well. Now, the game engine must be coded to implement the features defined in the game proposal, stated earlier in this chapter. Let's remind ourselves of the pseudo-code defined in the game project: Form_Load Creates an object (named currentBlock) of block class Form_KeyPress
If Left Arrow was pressed, call Left method of currentBlock .NET Game was Programming with DirectX 9.0 method of currentBlock If Right Arrow pressed, call Right ISBN:1590590511 by Alexandre Santos Lobão and Ellen If Up Arrow was pressed, call Rotate method of currentBlock Hatton If Down Arrow was pressed, call Down method of currentBlock Apress © 2003 (696 pages) Timer_Tick The is authors this text show how easy it can be to produce If there no of block below currentBlock, interesting multimedia games using Managed DirectX 9.0 and and the currentBlock didn't reach programming with Visual Basic .NET on Everett, the the latestbottom of the screen then Call Down method of currentBlock versionthe of Microsoft's Visual Studio. Else Stop the block Table of Contents If it's at the top of the screen then .NET Game Programming with DirectX 9.0 The game is over Foreword If we filled any horizontal lines then Preface Increase the game score Introduction Erase the line a GDI+ new block at the top of the screen Chapter 1 Create - .Nettrix: and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Before starting to translate this pseudo-code to actual Visual Basic code, it's important to stress two points:
Chapter River Pla.Net II: timer DirectInput and to Screen It's5not- common to use objects to Writing control Text games. The timer object doesn't have the necessary Chapter 6 - Magic KindergarteN.: Adventure Games, when ADO.NET, and with DirectShow precision or accuracy (we can't trust it entirely dealing time frames less than 10 milliseconds). Chapter Magic KindergarteN. II: Animation Techniques and Speech available API But7 for- games like .Nettrix, the levels of accuracy and precision with the timer are adequate Chapter 8 - .Netterpillars II: Multiplayer Games Directplay (remember that we are trying to make theand production of this game as simple as possible). In the next
chapter, D-iNfEcT: we'll seeMultithreading, a GDI+ application Nonrectangular that runs at Windows, full speed, andwithout Access using to a timer. -
Chapter 9
Nonmanaged Code not common in gametoprogramming to put the game engine code in a form. Usually we create a BonusIt's Chapter Porting .Nettrix Pocket PC
GameEngine class that deals with all the game physics and rules (as we'll see in the next chapter). Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Looking back at the pseudo-code, we see the following instruction:
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index
If it's at the top of the screen then
List of Figures List of tests Tables This if the block is at the top of the screen. Reviewing our Block class, we see that we have no direct
way to retrieve the block Top position, so we would have to test each of the Top positions of the block's composing squares. To solve this, let's make a final adjustment to the Block class, including a new method, as depicted in the next code listing: Public Function Top() As Integer Top = Math.Min(square1.location.Y, _ Math.Min(square2.location.Y, _ Math.Min(square3.location.Y, square4.location.Y))) End Function
Now we are ready to finish our program. Based on the preceding pseudo-code and on some minor changes made in the game coding phase, the code for the form will be as follows: Dim CurrentBlock As clsBlock Dim blnRedraw As Boolean Private Sub tmrGameClock_Tick(sender As System.Object, e As System.EventArgs) Handles tmrGameClock.Tick Static stillProcessing As Boolean = False Dim ErasedLines As Integer
' Prevents the code from running if the previous tick .NET Game Programming ' is still being processedwith DirectX 9.0 ISBN:1590590511 by Alexandre Santos Ellen If stillProcessing ThenLobão Exitand Sub Hatton stillProcessing = True Apress © 2003 (696 pages)
The the authors of thisfalling text show how easy it can be to produce ' Controls block interesting multimedia games using Managed DirectX 9.0 and If Not CurrentBlock.Down() Then programming with Visual Basic .NET on Everett, the latest ' Test forofgame overVisual Studio. version Microsoft's If CurrentBlock.Top = 0 Then tmrGameClock.Enabled = False Table of Contents CmdStart.Enabled = True .NET Game Programming with DirectX 9.0 MessageBox.Show("GAME OVER", ".Nettrix", _ Foreword MessageBoxButtons.OK, MessageBoxIcon.Stop) Preface Exit Sub Introduction End If the score using the number of deleted lines, if any Chapter'1 increase - .Nettrix: GDI+ and Collision Detection = ClsGameField.CheckLines() Chapter 2 -ErasedLines .Netterpillars: Artificial Intelligence and Sprites +=Direct3D 100 * Basics ErasedLines Chapter 3 -lblScoreValue.Text Managed DirectX First Steps: and DirectX vs. GDI+ Clear theTiled game field Chapter 4 -'River Pla.Net: Game Fields, Scrolling, and DirectAudio ErasedLines > 0 Then Chapter 5 -If River Pla.Net II: DirectInput and Writing Text to Screen PicBackground.Invalidate() Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Application.DoEvents() Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API ClsGameField.Redraw() Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End If D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter'9 Releases the current block from memory Nonmanaged Code CurrentBlock = Nothing Bonus Chapter Porting .Nettrix to Pocket PC ' Creates the new current block Appendix A - The State of PC Gaming CurrentBlock = New clsBlock(_ Appendix B - Motivations in Games New Point(ClsGameField.SquareSize * 6, 0)) Appendix C - How Do I Make Games? CurrentBlock.Show(PicBackground) Appendix End IfD - Guidelines for Developing Successful Games Index stillProcessing = False List of Figures End Sub List of Tables
Compare the preceding code listing with the previous pseudo-code to make sure each line of code has been understood. TheLoad event for the form, and the KeyDown event and the code for the Start button remain unchanged. The final version of .Nettrix has now been coded. When the game is run, it looks like the screen shown in Figure 1-32.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Figure final version of .Nettrix Chapter 6 - 1-32: Magic The KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
We can now play our own homemade clone of Tetris, and are ready to improve it, with the changes - .Netterpillars II: Multiplayer Games and Directplay discussed in the next section.
Chapter 8 Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Adding the .NET Final Touches by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton After playing the first version of .Nettrix for a few minutes, every player will miss two important features 2003 (696 present in almostApress every ©Tetris typepages) of game: a feature to show the next block that will appear, and some way to pause theThe game, for emergency authors of this text situations show how (like easy your it canboss be tocrossing producethe office and heading in your interesting games already using Managed DirectX anddone. The next sections discuss direction). Now that we havemultimedia all base classes finished, this is9.0 easily programming Visual Basic .NETgame. on Everett, the latest these and some other featureswith to improve our first version of Microsoft's Visual Studio.
Coding the Next Block Feature
Table of Contents
.NET To show Gamethe Programming next block,with we can DirectX create 9.0 a new pictureBox on the form, to hold the next block image, and
adjust the click of the Start button and the timer_tick event. We can use the optional parameter we Foreword created on the Block constructor (the New method) to create the new blocks following the block type of Preface the next block. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
To implement this feature, we'll create a variable to hold the next block in the general section of the form: Dim NextBlock As clsBlock - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 -of Magic KindergarteN.: Adventure ADO.NET, and At the end the cmdStart_click event,Games, we'll add two lines toDirectShow create the next block: Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
NextBlock = New clsBlock(New Point(20, 10)) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter NextBlock.Show(PicNextBlock.Handle) 9 Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A -we'll The State PC Tick Gaming And finally adjustofthe event of the timer, to create a new block every time the current block stops Appendix B Motivations in Games falling, and to force the CurrentBlock type to be the same as the NextBlock type. Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games ' Releases the current block from memory Index CurrentBlock = Nothing List Figures the new current block ' of Creates List of Tables CurrentBlock = New clsBlock(New Point(ClsGameField.SquareSize * 6, 0),_
NextBlock.BlockType) CurrentBlock.Show(PicBackground.Handle) ' Releases the next block from memory NextBlock.Hide(PicNextBlock.Handle) NextBlock = Nothing ' Creates the new next block NextBlock = New clsBlock(New Point(20, 10)) NextBlock.Show(PicNextBlock.Handle)
We can now run the game, and see the next block being displayed in the picture box we've just created, as shown in Figure 1-33.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Figure the next block Games, ADO.NET, and DirectShow Chapter 6 - 1-33: Magic Showing KindergarteN.: Adventure Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 section - .Netterpillars II: Multiplayer Games and Directplay Thenext shows another improvement, the game pause feature. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Nonmanaged Code
Coding the Game Pause Feature
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
To create a pause function, all we need to do is to stop the timer when a specific key is pressed-usually, the
Appendix Motivations Games A simple adjustment in the KeyDown event, including an extra case Esc key Bis -used for suchinfeatures. Appendix C How Do I Make Games? clause for the Keys.Escape value, will do the trick: Appendix D - Guidelines for Developing Successful Games Index
Private Sub Form1_KeyDown(sender As Object, e As KeyEventArgs) Handles MyBase.KeyDown List of Tables Select Case e.KeyCode Case Keys.Right CurrentBlock.Right() Case Keys.Left CurrentBlock.Left() Case Keys.Up CurrentBlock.Rotate() Case Keys.Down CurrentBlock.Down() Case Keys.Escape tmrGameClock.Enabled = Not tmrGameClock.Enabled If tmrGameClock.Enabled Then Me.Text = ".Nettrix" Else Me.Text = ".Nettrix - Press ESC to continue" End If End Select End Sub List of Figures
In the next section we'll discuss an improvement to the graphical part of our game.
Coding the Window Redraw
A little problem with .NET ourGame gameProgramming is that, when the with .Nettrix DirectX window 9.0 is covered by other windows, the game field isn't redrawn. Weby can adjust this by including a call Redraw method, at the Activate ISBN:1590590511 Alexandre Santos Lobão and Ellento the GameField's event of the formHatton (the Activateevent occurs every time the form gets the focus again, after losing it to another window):Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
Private Sub FrmNetTrix_Activated(sender As Object, e As System.EventArgs) programming with Visual Basic .NET on Everett, the latest Handles MyBase.Activated version of Microsoft's Visual Studio. ' This event occurs when the window receives back the focus after ' losing it to another window Table of ' Contents So, we redraw the whole game field .NET Game Programming with DirectX 9.0 ClsGameField.Redraw() Foreword End Sub Preface Introduction
Even using approach be some situations when the windows won't be redrawn properly. To Chapter 1 - this .Nettrix: GDI+ there'll and Collision Detection
achieve the best results, we should include the call to the Redraw method in the Tick event of the timer, - .Netterpillars: Artificial Intelligence and Sprites but since it could compromise the speed of our game, we'll keep the code as shown.
Chapter 2 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 section - Riverdiscusses Pla.Net: Tiled Game Fields, Scrolling, andenhancements DirectAudio Thenext some suggestions for future to our game. Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
KindergarteN.: Adventure Games, ADO.NET, and DirectShow Further-- Magic Improvements Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 7
Chapter 8 improvements - .Netterpillars we II: could Multiplayer and Directplay Two last makeGames are creating levels for the game and producing a configurations D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to screen,9but- these we'll leave for you to do by yourself. Chapter Nonmanaged Code Bonus Chapter Porting .Nettrix to we Pocket PCuse a basic rule like this one: Every 3 minutes the blocks falling To create levels for the game, could Appendix speed isAincreased - The State byof10PCpercent, Gamingthe game level is incremented by one, and the points earned for each
block gets byinthe level number. We can just adjust the timer tick procedure to include the logic Appendix B -multiplied Motivations Games for this rule. Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
In the case of a configurations screen, we could choose to see or not to see the next block image (setting theVisible property of the picNextBlock accordingly) and adjust the block size on the screen, so the List of Figures visually impaired can play with big blocks, and those who like to play pixel hunt can do so with single-pixel List of Tables square blocks. Index
Since the whole game is based on the GameField.SquareSize constant, implementing this feature is just a matter of creating the configuration window and adjusting the screen size according to the chosen square size. The next code listing is provided to underscore this last point; just add the following code to the procedure to be able to adjust the screen size after the configuration: ' Adjusts the size and controls position based on the class constants ' On the window height, sums the size of the window title bar Me.Height = ClsGameField.Height * ClsGameField.SquareSize + _ (Me.Height - Me.ClientSize.Height) + 3 ' 3=border width Me.Width = ClsGameField.Width * ClsGameField.SquareSize + 92 Me.PicBackground.Height = ClsGameField.Height * ClsGameField.SquareSize + 4 Me.PicBackground.Width = ClsGameField.Width * ClsGameField.SquareSize + 4 Me.PicNextBlock.Left = ClsGameField.Width * ClsGameField.SquareSize + 12 Me.LblNextBlock.Left = ClsGameField.Width * ClsGameField.SquareSize + 12 Me.lblScore.Left = ClsGameField.Width * ClsGameField.SquareSize + 12 Me.lblScoreValue.Left = ClsGameField.Width * ClsGameField.SquareSize + 12 Me.CmdStart.Left = ClsGameField.Width * ClsGameField.SquareSize + 12
We are adjusting neither the font size nor the button sizes, so to work with smaller sizes, some updating of the code will be necessary.
In the samples CD-ROM, the code is on the Load event of the form, so you can play with different sizes by .NET Game Programming with DirectX 9.0 simply adjusting the SquareSize constant and recompiling the code. by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Summary
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
In this chapter weHatton created our first game, .Nettrix, and explored some important concepts that will be used Apress © 2003 including (696 pages) the following: even in sophisticated games, The authors of this text show how easy it can be to produce
Basic concepts about GDI+ and the new graphics objects used on interesting multimedia games using Managed DirectX 9.0Visual and Basic .NET programming with Visual Basic .NET on Everett, the latest
Basic concepts version about ofcollision Microsoft's detection Visual Studio. and some suggestions on how to implement fast collision algorithms in our games Table of Contents Creation of simple classes and structured error handling in Visual Basic .NET .NET Game Programming with DirectX 9.0
Basic game engine creation, based on a game proposal and with the support of a game project Foreword Preface
In the next chapter, we'll look at the concept of artificial intelligence, how to create a game with computercontrolled characters, and how to create faster graphics routines with GDI+. We'll also examine some Chapter 1 -concepts .Nettrix: concerning GDI+ and Collision Detectionprogramming. additional object-oriented Introduction Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Chapter .NET 2: .Netterpillars: Artificial Intelligence and ISBN:1590590511 by Alexandre Santos Lobão and Ellen Sprites Hatton Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio. intelligence (AI) and sprites. We'll also extend our In this chapter we'll explore the concepts of artificial
Overview
knowledge of GDI+ functions, including some tips intended to give us a boost in performance. To accomplish these goals and illustrate these concepts, we'll create a game called .Netterpillars. Table of Contents .NET Game Programming with DirectX 9.0 each player controls a caterpillar (in fact, a "netterpillar") that .Netterpillars is an arcade game in which Foreword takes part in a mushroom-eating race with other netterpillars. The objective of the game is to be the last Preface surviving netterpillar, or the longest one (they grow when they eat) when every mushroom has been eaten. Introduction We'll describe the game in more detail in the section "The Game Proposal" later in this chapter. Chapter 1
- .Nettrix: GDI+ and Collision Detection .Netterpillars is a more complex than the one we saw in the last chapter because it involves the Chapter 2 - .Netterpillars: Artificialgame Intelligence and Sprites
following Chapter 3 components: - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 2-1: .Netterpillars, this chapter's sample game AI: Creating a game with opponents will make us exercise our ability to create a computer-controlled character that challenges players, while giving them a fair chance of winning. Sprites: Using nonblocky game objects will force us to find a way to draw nonrectangular moving objects on screen. Including a background image in our game screen will help us to check if our moving code is working (remember, in the last chapter we simply painted the objects with the flat background color). GDI+: Creating an interface where many objects (one to four caterpillars, wooden branches, and a lot of mushrooms) will be drawn and interact with each other will challenge us to find a faster way to update the screen. While covering these topics, we'll also look at new concepts related to object-oriented programming so we can create easily reuseable classes to improve the productivity when coding our games. For example, a "sprite" class is something that almost any game will need; so we can code it once and use it forever. We'll discuss all these points in the next sections, starting with some object-oriented concepts.
.NET Game Programming with DirectX 9.0 Object-Oriented Programming by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton There are many technical books that explain the academic details of object-oriented analysis (OOA) and Apress © 2003 (OOP). (696 pages) object-oriented programming It's not our goal to enter into such particulars, but instead loosely define a few terms and demonstrate some practical uses of these The authors of this text show how easy it can be to techniques. produce interesting multimedia games using Managed DirectX 9.0 and programming Visual Basic .NET oncode Everett, the latest The main idea behind creatingwith objects is to make our simpler to write and easier to maintain. By version of Microsoft's Visual Studio. creating high-level objects to take care of specific tasks, we can build our games using these objects without needing to remember every tiny detail about a new game. Table of Contents
A good analogy to consider is jigsaw puzzles: How many blue skies have you seen in different puzzles?
.NET Programming with DirectX And,Game for each one, you always have9.0 to put the pieces together one by one, regardless of the skies you Foreword have assembled before. If we could use OO concepts on puzzles, we would assemble the sky once, and Preface for every new puzzle we could use this ready-made sky as a starting point, and build only the different Introduction parts around it. Chapter 1
- .Nettrix: GDI+ and Collision Detection Even considering a singleArtificial puzzle,Intelligence the analogyand is still relevant: It's far easier to assemble the puzzle if we Chapter 2 - .Netterpillars: Sprites
put similar in different groups, assemble groups, and then them together to see the final Chapter 3 -pieces Managed DirectX First Steps: Direct3Dthe Basics and DirectX vs.glue GDI+
picture. That's pure OOP: Group related functions and data inside objects, code and test the objects, and - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio then code the interface between them.
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 -lists Magic KindergarteN.: Adventure Games, ADO.NET, DirectShow programming and analysis, Table 2-1 some common terms used when talking aboutand object-oriented Chapter 7 -aMagic KindergarteN. along with definition of each. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Table 2-1: Chapter 9 - Common Object-Oriented Terminology Nonmanaged Code
TERM DEFINITION Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Class
The code we write that is used as a blueprint to create objects. It can have methods, properties, and events.
Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
ObjectD - Guidelines An instance of Successful a class, or,Games in other words, a variable of a specific class, after Appendix for Developing Index
the object has been created.
ListMethods of Figures
Functions defined inside a class.
List of Tables
Properties or attributes
Variables defined inside a class.
Events
Procedures in the call triggered by the object called. May be associated to a user action (such as clicking a button) or to a system action (such as a specific time slice elapsed).
Constructor
Special method called when creating an object—in Visual Basic .NET, this is any function with the New name.
Destructor
Special method called when the object is being destroyed. In Visual Basic, to code the destructor we have to override (see the Overriding entry) the Dispose method of the base class.
Inheritance
Object-oriented concept which defines that one class can be derived from another class or classes (called base or mother classes), and inherit their interface and code (called the derived or child class).
Overriding
Object-oriented concept which defines that a derived class can create a different implementation of a base class method, to deal with specific needs of the derived class.
Interface
The set of public methods, properties, and events of one class. Public elements are visible to any program that creates an object from a class. When applied to a method, this means its parameters and return values.
Encapsulation .NET Concept related to thewith puzzle analogy: Game Programming DirectX 9.0 All details are embedded in the class, so the program that creates the object doesn't need to care about them. ISBN:1590590511 by Alexandre Santos Lobão and Ellen Overloading
Hatton Object-oriented concept which states that one method can have many Apress © 2003 (696 pages)
different interfaces, while keeping the same name.
The authors of this text show how easy it can be to produce multimedia concept games using Managed DirectX 9.0 objects and Polymorphism interesting Object-oriented which says that different can have different programming with Visual .NET function. on Everett, latest implementations ofBasic the same Anthe Add method, for example, can version of Microsoft's Visual Studio.
sum integers and concatenate strings.
Table of Contents
Note We'll refer to these concepts and terms throughout the rest of the book, reinforcing their meanings as we go along.
.NET Game Programming with DirectX 9.0 Foreword
Preface Continuing with the introductory concepts of this chapter, let's talk about artificial intelligence, giving a realIntroduction life application of this concept born in science fiction books. Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 Artificial Intelligence by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton AI, for our purposes, is the code in a program that determines the behavior of an object—in other words, Apress will © 2003 pages) how each game object act(696 upon and react to the game environment in each specific time frame. The authors of this text show how easy it can be to produce
The game's AI is interesting often confused with the game physics, or the "simulation" multimedia games using Managed DirectX 9.0 andas some gamers prefer to call programming Basic .NET on Everett, the latest it. While the AI decides what towith do, Visual the physics sets the constraints and limits of the AI and your game play. version of this Microsoft's Visual Studio. Some examples will make distinction clearer: Classic pinball games have no AI, only physics.
Table of Contents
.NET Game DirectX 9.0players can't build a new residential block over a river, it's the game In the Programming SimCity gamewith series, when Foreword physics acting. When the Sims start creating their houses, it's the game AI's turn. Preface
In the 3-D maze fever started long ago by Castle Wolfenstein, the game physics tells players that they can't go through walls, and that their bullets will lower the enemy's energy until death. The game AI Chapter 1 - .Nettrix: GDI+ and Collision Detection tells the enemy to turn around and fire at players if they shoot him, or if he "hears" them shooting. Introduction Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter - Managed Direct3D vs. GDI+ A good3game projectDirectX usuallyFirst has Steps: the physics andBasics the AIand veryDirectX well defined and separated, and most times Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio the AI acts just like a player over the game physics. For example, in a multiplayer race game, the players Chapter - River Pla.Net II: AI DirectInput Writing to Screen control5some cars, and the will drive and all cars withText no pilots, ideally with the same difficulties that the Chapter human6players - Magic have. KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
- .Netterpillars II: Multiplayer Games and Directplay AI Categories
Chapter 8 Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Nonmanaged We can divide the AI into Code three categories:
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Environmental AI: The kind of AI found in games like SimCity, where the environment (in this example, the city) acts as a lifelike environment, reacting to the player input and including some Appendix C - How Do I Make Games? unexpected behavior of its own. Appendix B - Motivations in Games
Appendix D - Guidelines for Developing Successful Games Index
player AI: Used in games where the AI will act like a player playing against the human. For List ofOpposing Figures in chess and other board games, we usually have a very sophisticated AI to play the part of List ofexample, Tables an opponent. Nonplayer characters (NPCs): Many games have computer-controlled characters that could be friendly (for example, the warriors that join players in a quest on role-playing games, or RPGs, like Diablo), unfriendly (the monsters and enemies in 3D mazes), or neutral (the characters are there just to add color to the environment, such as the cooker at the Scumm bar in LucasArts' The Secret of Monkey Island). Of course this division exists only for teaching purposes; sometimes there's no distinct barrier between the categories.
General AI Considerations Without entering into specific details, there are some things we have to remember when writing AI code: Don't let users find out that the AI has access to their internal data. For example, in games like Microsoft's Age of Empires, players only see part of the map. Even though the AI can access the full map, the computer-controlled tribes don't act as if they know all the players' characters positions. Create different levels of difficulty. Having a game with different levels lets players decide how tough they want their opponents to be. In some chess games, for example, players can choose how many future moves the computer will analyze, making the game easier or harder.
Let the AI fail sometimes. If there's anything computers do well, it's executing code exactly the same with DirectX 9.0 way over and.NET over.Game If youProgramming are coding a shooter game where the computer can shoot the player, don't ISBN:1590590511 by Alexandre Santos Lobão and Ellenand don't forget forget to make the computer miss sometimes; that an opponent that never misses is Hatton as bad as an opponent that always misses. Players play the game to win, but if they don't find it Apress © 2003 (696 pages) challenging, they'll never play your game again. The authors of this text show how easy it can be to produce
interesting games using Managed DirectX 9.0 and Don't forget to take intomultimedia account the environment variables. If players can't see through the walls, the programming with Visual Basic .NET on Everett, the latest NPCs must act as if they can't either. If the computer-controlled adversary has low energy, but is very version of Microsoft's Visual Studio. well protected by walls, he or she won't run away. If players can hear sounds when someone is approaching or when someone shoots, the NPCs must act like they hear it too. Table of Contents
Always add some random behavior. .NET Game Programming with DirectX 9.0 The correct balance of randomness will challenge players more, without making the game so unpredictable that it becomes unplayable. If the game has no element of Foreword chance, players can find a "golden path" that will allow them to always win when using a specific strategy.
Preface
Introduction
Chapter GDI+ and Collision Let1the- .Nettrix: AI "predict" players' moves.Detection In some games, it's possible to predict players' moves by Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites analyzing the possibilities based on the current situation, like in a checkers game. But in other games Chapter Managed DirectX Steps: Direct3D Basics and the3AI-can "cheat" a little,First pretending that it predicted theDirectX movesvs. of GDI+ a good human player. For Chapter 4 - River Pla.Net: Tiled Game Scrolling, andsoldiers DirectAudio example, if the AI discovers that Fields, a player is sending through a narrow passage in the direction Chapter of its 5 headquarters, - River Pla.Net itII: can DirectInput put a sentinel and Writing in the passage Text to Screen and pretend that it "had considered" that
someone could use that passage. AndGames, never forget to give a chance (they can kill the sentinel, Chapter 6 - Magic KindergarteN.: Adventure ADO.NET, andplayers DirectShow for7example)! Chapter - Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Common AI Techniques -
Chapter 9
Nonmanaged Code
Bonus .Nettrix to Pocket PCabout neural networks, genetic algorithms, fuzzy logic, and other WhenChapter talking Porting about AI, it's usual to hear Appendix - The State of PC Gaming technicalA terms. It's beyond the scope of this book to explain each of these approaches, but those who Appendix want to get B - deeper Motivations on the in Games AI topic can search for these terms on the Internet to discover lots of interesting
sites andCrelevant groups. Appendix - How Dodiscussion I Make Games? Appendix D - Guidelines for Developing Successful Games
These terms, when applied to games, have the main goals of adding unpredictability to the game actions and helping to create a game that seems to learn players' tricks and adapt to them to be more List of Figures challenging. To take a more practical approach, we can obtain these results by applying some simple List of Tables tricks that will require a lot less effort. In the next sections we discuss some of these tricks. Index
Adaptable Percentage Tables A neural network can be simplified as a table with adaptable results, represented by percentages. For example, when coding a war game, we can create a table to help the AI choose the tactics with which to attack the other players. The AI will use each tactic a set percentage of the time depending on the success rate that is represented by the percentage. The greater the success rate, the more often this tactic will be used. The table can be filled with some initial values, as shown in Table 2-2, and can evolve according to the results of each turn in the game. Table 2-2: Starting Values for an Adaptable Percentage Table ATTACK TYPE
PERCENTAGE
Attack with "V" formation
20 percent
Divide the soldiers in small groups and attack in waves
20 percent
Guerrilla attack—surprise attack with a few soldiers, shoot and run away
20 percent
Attack with full force, in a big group
20 percent
Surround the player and attack from every direction
20 percent
After each attack, we'll change the table values according to the results. For example, if the attack is .NET Game Programming with DirectX 9.0 successful, we can add 10 percent to its corresponding percentage column on the table; if not, subtract 10 ISBN:1590590511 by Alexandre Santos andattack Ellen types. After percent, distributing the difference to Lobão the other some attacks, the program will "learn" Hatton which kind of attack is most efficient against the current player. For example, if the AI uses the first kind of Apress © 2003 (696 pages) attack (in "V" formation) and it was successful, the table would be updated to the values shown in Table 2The authors of this text show how easy it can be to produce 3. interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Table 2-3: Adaptable version Percentage of Microsoft's Table Visual Values Studio.After a Successful "V" Formation Attack
ATTACK TYPE Table of Contents
Attack with "V" formation
.NET Game Programming with DirectX 9.0 Foreword Divide the soldiers into small groups and attack in waves Preface
Guerrilla attack—surprise attack with a few soldiers, shoot and run away
Introduction
Chapter Attack1 with - .Nettrix: full force, GDI+ in aand big Collision group Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Surround the player and attack from every direction
PERCENTAGE 30 percent 17.5 percent 17.5 percent 17.5 percent 17.5 percent
Chapter 5 -turn, Riverif Pla.Net II: DirectInput and Writing Text totactic Screen In the next the AI tries an attack using the guerrilla and it fails, the table will be updated again, Chapter 6 - Magic KindergarteN.: to the values shown in Table 2-4.Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter Table 2-4: 8 - Adaptable .Netterpillars Percentage II: Multiplayer Table Games Values and Directplay After a Failed Guerrilla Attack D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - TYPE ATTACK Nonmanaged Code
PERCENTAGE
Bonus Chapter Porting .Nettrix to Pocket PC Attack with "V" formation
32.5 percent
Appendix A - The State of PC Gaming
Divide B the- Motivations soldiers in small groups and attack in waves Appendix in Games
20 percent
Appendix C -attack—surprise How Do I Make Games? Guerrilla attack with a few soldiers, shoot and run away Appendix D - Guidelines for Developing Successful Games
7.75 percent
Attack with full force, in a big group Index
20 percent
ListSurround of Figuresthe player and attack from every direction List of Tables
20 percent
And so on ... Of course in a real game it's better to add many interacting factors. For example, we can choose the best attack for each type of terrain or climatic condition. The more factors we take into account, the better results we'll have. In games like SimCity, there are dozens (sometimes even hundreds) of factors that contribute to generating the desired result.
Line of Sight For games that use NPCs, a classical problem is how to discover if the computer character can see the player or not. There are many different solutions to this problem, but possibly the simplest one is the line of sight algorithm. We can implement this in a few steps: 1. Consider an NPC's eyes as a point just in front of it. It will be "looking" in this direction. 2. Using the techniques for calculating the distance between two points, which we saw in the previous chapter, calculate the distance between the NPC and the player's character. If distance to the player is greater than a certain value (the "seeing distance"), the NPC can't see the player, as shown in Figure 2-2.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce games using Managed DirectX 9.0 and Figureinteresting 2-2: The multimedia player (good guy) is outside the seeing distance of the NPC (devil). programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
3. If the distance is less than the seeing distance of the NPC, create an (invisible) object having the character center and the NPC's "eyes" as vertices. Table of player Contents .NET Game Programming with DirectX 9.0
4. Use one of the collision detection algorithms we saw in the previous chapter to calculate if there's a
Forewordcollision between this object and the NPC's head. If so, it's because the line of sight goes through Preface the NPC's head. The player is NOT in front of the NPC, so the NPC can't see the player. Figure 2-3 Introduction illustrates this situation. Chapter 1 - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index
Figure 2-3: The player is behind the NPC, so it can't see the player.
List of Figures List of Tables
5. If there's no collision with the NPC's head, calculate the collision among the created object and other game objects. If there's no collision, there are no obstacles between the player and the NPC, so the NPC can see the player. See Figure 2-4 for a graphical view of this last calculation.
Figure 2-4: The NPC tries to see the player.
Making NPCs "Hear" the Player There's a simple solution to making NPCs aware of player sounds: Every time the player makes a sound, the program must compute the distance (using the Pythagorean theorem, discussed in Chapter 1) from the player to the NPCs. Any NPC whose distance is less than a constant value (the "hearing distance") would turn to look for the sound origin. After a while, if there are no further sounds and the NPC has not seen the player, the NPC returns to its previous activity (patrol, stand still, walk erratically, etc.).
It's a common practice to have different hearing distances for different kinds of sounds: A gun shooting .NET Game Programming with DirectX 9.0 can be heard from a distance, while the player must be really near to the NPC for it to hear his or her ISBN:1590590511 by Alexandre Santos Lobão and Ellen footsteps.
Path Finding
Hatton Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce
interesting multimedia usingdifferent Managedalgorithms DirectX 9.0to and Like the line of sight problem, there aregames also many solve the problem of path programming with Visual Basic .NET on Everett, the latest finding. If we don't know in advance how the game field will take shape, we could employ some of the version of Microsoft's Visual Studio. following methods:
Mark some "milestones" along the path the character is walking. If it hits an obstacle, return to the last Table of Contents milestone and try another way. This .NET Game Programming with DirectX 9.0 algorithm is useful when we have labyrinths or tiled game fields. Foreword
Use invisible "bumpers" around the game characters: The program checks for any collision with these invisible objects, and chooses a way according to the noncolliding paths. The game can create Introduction bumpers following the NPCs from different distances, in order to allow them to see remote obstacles. Preface
Chapter 1
- .Nettrix: GDI+ and Collision Detection Create line of sight Artificial betweenIntelligence the currentand position and the destination position. If there are obstacles Chapter 2 -a .Netterpillars: Sprites
on 3the- way, moveDirectX the line of sight toDirect3D one sideBasics until there's no obstacle. Chapter Managed First Steps: and DirectX vs. GDI+Mark this point as a way point, and process between this point and the desired destination point. Chapter 4 repeat - Riverthe Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
If we know the game field, such as a fixed screen in an adventure game, some common approaches are Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow as follows: Chapter 8 - fixed .Netterpillars II:the Multiplayer Games and Directplay Define paths, so player and the NPCs always walk over these paths. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Definepath boxes, where Nonmanaged Code each part of the screen is defined as a box with some characteristics,
a list of.Nettrix reachable boxesPC from that area. When walking inside a box, the player and the Bonusincluding Chapter Porting to Pocket NPCs full freedom; when going to a place on screen that's inside another box, have the player Appendix A -have The State of PC Gaming andBNPCs walk to the junction point between the two boxes, and then to the desired point in the next Appendix - Motivations in Games box.CThis method provides a more flexible look and feel for the game, but the boxes must be well Appendix - How Do I Make Games?
planned to avoid strange behaviors (like the NPC running in circles if all the boxes are connected). This is the approach used by LucasArts in the first three games of the Monkey Island series.
Appendix D - Guidelines for Developing Successful Games Index
List of Figures
Use Your Imagination
List of Tables
Although a lot of different techniques exist for solving problems relating to a game's AI, there's always room for new ideas. Learn from other people's experience; see how the games behave and try to figure out how to mimic such behaviors in your game. There are a lot of good game developers' sites where you can learn directly from the masters; a simple Web search using the keywords "artificial intelligence" and "games" will uncover the most interesting ones.
Keep Libraries of Reusable Graphics and Objects Our final piece of advice is to always have your graphical routines and objects well polished and ready to use, so you can spend more time on the game's physics and AI, the most important parts. To this effect, let's start our library with a Sprite class, described in the next section.
Game Programming with DirectX 9.0 Sprites and.NET Performance Boosting Tricks by Alexandre Santos Lobão and Ellen
ISBN:1590590511
We'll now start toHatton create a set of generic classes that can be used in our future game projects, such as the Sprite class. Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce
Sprite is a common term used by gamegames programmers to specify any9.0 active interesting multimedia using Managed DirectX andobject on the screen—for programming Visual Basicobjects, .NET onetc. Everett, the latest example, the player character,with bullets, bonus We can also define sprite as any element on a of Microsoft's Visual game screen thatversion is neither background nor Studio. information (such as menus or tips on the screen). For our purposes in this chapter, we'll create a simple Sprite class, which can be enhanced later to include additional features. With a fast brainstorm, we can list some of the basic attributes we may need, .NET DirectX andGame these Programming are shown in with Table 2-5. 9.0
Table of Contents Foreword
Preface Table 2-5: Suggested Properties for a Simple Sprite Class Introduction
PROPERTY Chapter 1 - .Nettrix: DESCRIPTION GDI+ and Collision Detection NAME
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 - ManagedHolds DirectX First Steps: Direct3D DirectX vs.sprite GDI+objects, we can have Bitmap a simple image for the Basics sprite.and In advanced Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio multiple arrays of images to deal with different animations (such as walking, Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen jumping, dying, etc.).
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Position Scale
Chapter 9
-
The actual x,y position of the sprite. Following the .NET property names, we can call this property Location.
D-iNfEcT:The Multithreading, scale to be used Nonrectangular for the position Windows, coordinates: and Access pixel to or the sprite's size. Nonmanaged Code
Direction the object is moving Bonus Chapter PortingIf.Nettrix to Pocket PC to (or "looking at") a new position, we must have a direction property to hold this information.
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
As for the methods, three basic routines are obviously needed, and these are shown in Table 2-6.
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games
Table 2-6: Suggested Methods for a Simple Sprite Class
Index
ListMETHOD of Figures
DESCRIPTION
ListNAME of Tables
New
We can create overloaded New methods that will receive different parameters: the sprite bitmap, the bitmap and the position, these two plus the direction, and so on. We will use Visual Basic .NET method overloading to implement these different initialization methods.
Draw
This one is a must: All sprites must be drawn.
Undraw
Erases the sprite, restoring the background picture, if it exists. To erase the sprite, this method must have access to the background bitmap, in order to copy the background over the previously drawn sprite.
Figure 2-5 shows a graphical representation of the Sprite class.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface
Figure 2-5: TheSprite class
Introduction
Chapter 1 -we .Nettrix: GDI+up and Collision Of course, can come with many Detection other attributes and methods, such as velocity and acceleration Chapter 2 and - .Netterpillars: Artificial Intelligence anddirection, Sprites velocity, and acceleration, erases the sprite from attributes a move method (which, using the Chapter 3 - Managed FirstitSteps: Basics and DirectX vs. GDI+ the previous position DirectX and draws on theDirect3D new one). But let's keep it simple for now! This kind of Chapter approach—defining 4 - River Pla.Net: the basic Tiledstructure Game Fields, of a Scrolling, class or program, and DirectAudio and then redefining it to produce many
interactions (if needed)—is as aWriting good approach by the latest object-oriented software Chapter 5 - River Pla.Net II: recognized DirectInput and Text to Screen processes, Rational Unified Process (RUP). We'll not enter into any details here, but we'll use Chapter 6 - such Magicas KindergarteN.: Adventure Games, ADO.NET, and DirectShow some simplified from this software development philosophy. Chapter 7 - Magicconcepts KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Sprite:- Fast and Transparent
Chapter 9
Nonmanaged Code
Bonus Before Chapter we start Porting coding .Nettrix the Sprite to Pocket class, PC there are two things we must know: Appendix A - The State of PC Gaming
HowB to- Motivations draw the sprite as fast as possible. Appendix in Games Appendix C - How Do I Make Games?
How to draw nonrectangular sprites: Since most of our game objects won't be rectangles or squares
Appendix Guidelines Developing Games draw rectangular images, we have to learn how to (likeDin- the .Nettrixfor example), andSuccessful all the functions Index draw an image with a transparent color, in order to achieve the illusion of nonrectangular sprites. List of Figures
As of forTables the first point, the GDI+ Graphics object has a method called DrawImage that draws an image at List a given position in our work area. This method is very flexible, but it incurs a lot of overhead since it includes an internal method to scale the image, even when we don't use the scaling parameters. Fortunately, we have a second method, DrawImageUnscaled, that just blits (copies a memory block directly to video memory) the source image, as is, to the destination position, with very low overhead. We'll use this function, since it gives us all the speed we need. There's also a third, even faster function on the Graphics namespace, called DrawCachedBitmap, that maps the bitmap to the current memory video settings, so the drawing is just a matter of copying a memory position to video memory. This approach has only one drawback: If the player changes the monitor resolution when the game is playing, we'll have unpredictable results. Unfortunately, in the first release of Visual Studio, this function is only available to C++ programs; it'll probably be available in Visual Basic's next version. Since we'll learn how to work with high-speed graphics through DirectX in the next chapters, this limitation won't be a problem if we want to create fast-paced action games. As for the transparent color, we have two possible approaches. We can set a so-called color key to be transparent, after loading the image, with the MakeTransparent Graphics method, or we can create a color-mapping array, which is much more flexible because we can set different degrees of transparency to different colors. We'll be using the first approach here, because it's simpler and all we need for now is a single transparent color, but we'll show you how to use a color map array, which can be used in other situations. TheSprite class is the base class for all active game objects, and since it must have access to some of
the properties of the class that will manage the game (such as the background image used in erasing), .NET Game Programming DirectX 9.0 this approach here, deriving the Sprite some programmers like to derive it from thatwith class. We'll use ISBN:1590590511 by Alexandre Santos Lobão and Ellen class from the GameEngine class (discussed later in the section "The Game Proposal"). Hatton Apress © 2003 (696 pages)
Coding theThe Sprite authorsAttributes of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
We'll start codingprogramming the attributes. with Because Visual Basic attributes .NET don't on Everett, requirethe special latest treatment for now, we'll create version of Microsoft's Visualenumerations. Studio. them as public variables and some helper Public Class clsSprite Table of Contents Inherits clsGameEngine .NET Game Programming with DirectX 9.0 Foreword
' Image size, to be used by the child classes Public Const IMAGE_SIZE As Integer = 15
Preface
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Protected BmpSource As Bitmap - .Netterpillars: Artificial Intelligence and Sprites Public Direction As enDirection Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Public Location As Point ChapterPublic 4 - River Pla.Net: Game Fields, Scrolling, and DirectAudio Scale AsTiled enScale = enScale.Sprite ChapterPublic 5 - River Pla.Net II: DirectInput and Writing Text to Screen Enum enScale Chapter 6 -Pixel Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow = 1 Chapter 7 -Sprite Magic KindergarteN. II: Animation Techniques and Speech API = IMAGE_SIZE ChapterEnd 8 -Enum .Netterpillars II: Multiplayer Games and Directplay Chapter 2
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Nonmanaged Code Public Enum enDirection Bonus Chapter Porting= .Nettrix to Pocket PC North 1 Appendix A -NorthEast The State of PC = Gaming 2 Appendix B -East Motivations = 3 in Games = Games? 4 Appendix C -SouthEast How Do I Make South = 5 Appendix D - Guidelines for Developing Successful Games SouthWest = 6 Index West = 7 List of Figures NorthWest = 8 List of Tables End Enum
The Sprite's New Method As for the constructor of the class, we can define many different overloaded functions for it: a method that receives no parameters (to be implemented by the derived classes, if needed), a method that receives the sprite image name, and two others that receive the initial position of the sprite and the color code to be used as a transparent color. If we need more overloads, we can create them as the project evolves. Observe that, in order to simplify the New code, we create a private Load method, which can be called with one or more parameters, according to the constructor used when creating the object. Sub New() ' this empty constructor is to be used by the child classes ' when they want to implement everything from the ground up End Sub Sub New(strImageName As String) BmpSource = Load(strImageName) End Sub Sub New(strImageNamem As String, keycolor As Color)
Load(strImageNamem, keycolor) .NET Game Programming with DirectX 9.0 End Sub ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Sub New(strImageName As String, ponLocation As Point) Apress © 2003 (696 pages)
BmpSource = Load(strImageName) authors of this text show how easy it can be to produce Location The = ponLocation interesting multimedia games using Managed DirectX 9.0 and End Sub programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Function Load(strImageName As String) As Bitmap Dim BackColor As Color Table of Contents .NET Game Try Programming with DirectX 9.0 Foreword
Load = Bitmap.FromFile(strImageName) ' The transparent color (keycolor) was not informed, Introduction ' then we will use the color of the first pixel Load.GetPixel(0, 0) Chapter 1 -BackColor .Nettrix: GDI+=and Collision Detection Chapter 2 -Load.MakeTransparent(BackColor) .Netterpillars: Artificial Intelligence and Sprites ChapterCatch 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ image file and was not found." & Keys.Enter & _ Chapter 4 -MessageBox.Show("An River Pla.Net: Tiled Game Fields, Scrolling, DirectAudio make sure that file strImageName & " exists.", _ Chapter 5 -"Please River Pla.Net II: DirectInput and the Writing Text " to & Screen ".Netterpillars", MessageBoxButtons.OK, MessageBoxIcon.Stop) Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Load = Nothing Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API End Try Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Function Preface
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Function Load(strImageName As String, keycolor As Color) As Bitmap Try Appendix A - The State of PC Gaming Load = Bitmap.FromFile(strImageName) Appendix B - Motivations in Games Load.MakeTransparent(keycolor) Appendix C - How Do I Make Games? Catch Appendix D -MessageBox.Show("An Guidelines for Developing Successful Games was not found." & Keys.Enter & _ image file Index "Please make sure that the file " & strImageName & " exists.", _ List of Figures ".Netterpillars", MessageBoxButtons.OK, MessageBoxIcon.Stop) List of TablesLoad = Nothing End Try End Function Bonus Chapter Porting .Nettrix to Pocket PC
NEW In Visual Basic .NET, we can create methods with the same name and different parameters, IN.NET in order to implement different behaviors. As we saw in the "Object-Oriented Programming" section, this is called method overload, and it's not a new idea; many object-oriented languages already have this feature. In Visual Basic we only have to use the overload keyword when creating an overloaded method on a derived (child) class; to overload methods within a class, as in the previous code listing, we simply create many functions with the same name. The main purpose for creating various methods with the same name and different parameters is to give the programmers that will use our class enough flexibility to use only the parameters they need in a given case. For example, if we are creating a sprite that will be fixed throughout the game, we'll probably want to pass this fixed position when creating the sprite; if the sprite moves every time, it's better to pass only the image name, and so on.
Drawing and Erasing Sprite Code
The last two methods of a basic Sprite class must be, as we said before, the Draw and Erase methods. Game Programming DirectX 9.0 method Undraw. Since Erase is a .NET keyword in Visual Basic, wewith called the erasing by Alexandre Santos Lobão and Ellen Hatton Sub Draw(WinHandle As (696 System.IntPtr) Apress © 2003 pages)
ISBN:1590590511
Dim graphBack As Graphics The authors of this text show how easy it can be to produce graphBack = Graphics.FromHwnd(WinHandle) interesting multimedia games using Managed DirectX 9.0 and graphBack.DrawImageUnscaled(BmpSource, programming with Visual Basic .NET on Everett, the Location.X latest * Scale, _ version of Microsoft's Visual Studio. Location.Y * Scale) graphBack.Dispose() End Sub
Table of Contents .NET Game Programming with DirectX 9.0
Sub UnDraw(WinHandle As System.IntPtr) Dim graphBack As Graphics Preface graphBack = Graphics.FromHwnd(WinHandle) Introduction graphBack.DrawImage(BackgroundImage, New Rectangle_ Chapter 1 -(Location.X .Nettrix: GDI+ and Collision Detection * Scale, _ Chapter 2 - .Netterpillars: Artificial *Intelligence Sprites Location.Y Scale, and IMAGE_SIZE, IMAGE_SIZE), _ Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ New Rectangle(Location.X * Scale, Location.Y * Scale, _ Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, GraphicsUnit.Pixel) and DirectAudio IMAGE_SIZE, IMAGE_SIZE), Chapter 5 - River graphBack.Dispose() Pla.Net II: DirectInput and Writing Text to Screen End Sub Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Foreword
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 In the Undraw method we are using a background image property that will be shared by all the sprites, Nonmanaged Code
and that stores the background imagePC of the game field, which must be drawn over the sprite image to Bonus Chapter Porting .Nettrix to Pocket
create an illusion of erasing it. Since we need a little more flexibility than the DrawImageUnscaled offers, we'll use the DrawImage function to copy a specific rectangle of the background image over the sprite Appendix B - Motivations in Games image. Appendix A - The State of PC Gaming
Appendix C - How Do I Make Games?
Appendix D -toGuidelines forclass Developing Games If we want extend the to dealSuccessful with multiple transparent colors or different degrees of transparency, Index we can adjust the New procedure to use a color map table, as shown in the following code. The color List of Figures alpha values range from 255 (opaque) to 0 (totally transparent). List of Tables
Sub New(strImageName As String, ColorKey as Color) Dim ImgAttributes As System.Drawing.Imaging.ImageAttributes Dim ImgColorMap As System.Drawing.Imaging.ColorMap() Dim BackColor As Color Dim width As Integer Dim height As Integer BmpSource.FromFile(Application.StartupPath & "\" & strImageName) width = BmpSource.Width height = BmpSource.Height ImgColorMap(0).OldColor = ColorKey ImgColorMap(0).NewColor = New Color() ImgColorMap(0).NewColor.FromArgb(0, ColorKey.R, ColorKey.G, _ ColorKey.B) ' Set alpha to 0 = transparent ' Set here all other colors with an alpha value <> 255 ImgAttributes.SetRemapTable(ImgColorMap, _ System.Drawing.Imaging.ColorAdjustType.Bitmap) graph.DrawImage(BmpSource, _ New Rectangle(150, 10, width, height), _ 0, 0, width, height, _
System.Drawing.GraphicsUnit.Pixel, _ .NET Game Programming with DirectX 9.0 ImgAttributes) by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
End Sub
ISBN:1590590511
The authors show how easy it can be that to produce Using the Dispose() methodofofthis thetext Graphics object ensures the memory used by the graphics interesting multimedia gameswhich usingisManaged DirectX since 9.0 and object will be released as soon as possible, very important we'll be calling the Draw and programming with Visual Basic .NET on Everett, the latest Undraw methodsversion many of times a second. Microsoft's Visual Studio.
This completes the explanation of the technical concepts we'll use in our game. We'll define some details of this Table of chapter's Contentssample game, .Netterpillars, in the next section, "The Game Proposal." .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Game Proposal by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton remember that the very first step is to write a clearly defined game proposal. This When creating games, Apressinvolved © 2003 (696 ensures that everyone in pages) the game creation process can understand and agree with the game objectives. Even The veryauthors sophisticated must a simple proposal, so the programmers can of this games text show howstart easywith it can be to produce interesting multimedia games using build the project upon a previously established goal.Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Studio. As mentioned in the introduction to thisVisual chapter, we'll create a fast-action arcade game called
.Netterpillars. Here are some details about the game: Table of Contents
The game objective is to control a caterpillar-like character around the game field, trying not to collide
.NET Game Programming with 9.0 with other caterpillars orDirectX any obstacles. If you collide, you are dead. Foreword
The game field must be filled with mushrooms and every time a netterpillar eats a mushroom, he gets Preface bigger. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
The game is over when all the players die (computer or human ones), or when the last mushroom is - .Netterpillars: Artificial Intelligence and Sprites eaten.
Chapter 2 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 -must Riverbe Pla.Net: Tiled Gamescreen Fields,where Scrolling, DirectAudio There a configuration the and player can choose the field size, how many Chapter 5 River Pla.Net II: DirectInput and Writing Text to mushrooms there'll be in the game, and the number ofScreen computer-controlled opponents (from 0 to 3). Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
The must allow the smooth inclusion of multiplayer routines Chapter 7 game - Magic KindergarteN. II: Animation Techniques and Speech APIin future versions, so all the project and coding must be done with this goal in mind. - .Netterpillars II: Multiplayer Games and Directplay
Chapter 8
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to The basic Chapter 9 -idea in creating different configurations for a game is to add endurance to the game. That Nonmanaged Code
means that the game will interest the player for a longer time. It's a common approach to add many different ways of playing in order to keep the player's attention. A good example of this approach is Appendix A - The State of PC Gaming Microsoft's Age of Empires: Players can start a new game and go on building from the ground up, or Appendix B - Motivations in Games players can choose a quest, where a previously created status quo is presented and they must solve some Appendix C How Do I Make specific problems to win theGames? game. Bonus Chapter Porting .Nettrix to Pocket PC
Appendix D - Guidelines for Developing Successful Games
In our sample, the player can choose, for example, a small and mushroom-crowded game field, and try to Index eatofthem all without getting trapped by his or her own tail; or choose a big field with fewer mushrooms and List Figures more opponents, in order to try to be the longest one, eating as many mushrooms as possible while trying List of Tables to kill the enemies, trapping them with his or her tail. Many intermediary combinations would be possible, making the game more interesting to play. With the basic game plan set, it's time to start thinking about the technical details: creating a project for the game.
.NET Game Programming with DirectX 9.0 The Game Project by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Once all the teamHatton members share the project vision, it's time to create our project. This can be as simple Apress © 2003 (696 pages) as a feature list and a scratch class diagram on paper. And even if you are working solo, as you will see, organizing and planning work before actually doingeasy it isithighly beneficial! The authors of this text show how can be to produce interesting multimedia games using Managed DirectX 9.0 and Visual Basic .NET on showing Everett, the Our game projectprogramming will include awith simple class diagram, the latest class, properties and methods, a main version of Microsoft's Visual Studio. program workflow definition, and the drafts for each game screen (as discussed in the next sections).
Defining the Game Classes and the Game Engine
Table of Contents
.NET Game Programming with DirectX 9.0
The game characters are the first natural candidates for game objects, based on our library's Sprite Foreword class. So we can take the nouns on the list of topics from the game proposal and create a first draft of our Preface class diagram, as shown in Figure 2-6.
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Figure 2-6: The class diagram—first draft
Bonus Chapter Porting .Nettrix to Pocket PC
Appendix A -fine Thefor State of PC Gaming This looks a first draft. We see here an extra class, not mentioned in the game proposal: the Appendix B Motivations in Games Branch class. We include it just for fun, in order to improve the look of the game with branches at the Appendix C - How Do I Make Games? screen limits. Appendix D - Guidelines for Developing Successful Games
Following what we learned in the previous chapter, there must be a class for controlling the game field Index
and physics. Since this class will have more features than the GameField class from Chapter 1, we'll use a more appropriate name for it: GameEngine.
List of Figures List of Tables
Before putting this class in our diagram, it must be clear what the game engine should and should not do. It follows that the game engine is solely responsible for creating and maintaining the entire environment where the game characters will act. Usually, the game engine works according to the physical laws (gravity, action-reaction, etc.) in the real world, with more or less realism depending on the game goals. The game engine doesn't include the AI control. Instead, it just puts constraints over the game's characters, regardless of whether they are computer or human controlled. Hence we'll need another class to control the AI of our computer-controlled netterpillars. Since this class must have a high integration with the game engine (to collect information that will allow it to make decisions—for example choosing the direction to go), we'll create this class as a child of the GameEngine class. Since the sprite must have access to the game field background in order to erase itself, we'll also include theSprite class as a derived class from the game engine in the class diagram. Our final class diagram (without the attributes and methods) is shown in Figure 2-7. Notice that it's not the right diagram, or the only approach. It's just an idea, and if you don't agree with it—great! You understand our subject so well that you already have your own opinion about it.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0
Figure 2-7: The class diagram—second draft Foreword Preface
As for the properties (attributes) and methods, we can use what we learned before as a starting point, and build on it.
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 - brainstorming, .Netterpillars: Artificial Intelligence and Sprites After more we select a set of attributes and methods for each class, as shown in Figure 2Chapter 3 - Managed DirectX First with Steps: andwith DirectX GDI+ 8. We don't expect any surprises theDirect3D classesBasics that deal the vs. game objects, and the other ones, Chapter such as4 the - River AI class, Pla.Net: are created Tiled Game based Fields, on our Scrolling, previous andexperience DirectAudio of similar projects. Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 2-8: The final class diagram We don't need to have a totally finished diagram by now, just a guide for our coding. We can return to this
diagram later, at the game-coding phase, and adjust it if necessary, when new ideas and problems arise. .NET Game Programming with DirectX 9.0 Even the most detailed projects aren't steady; modifications always occur after the coding starts. There is ISBN:1590590511 by Alexandre Santos Lobão and Ellen a quote from a famous general that fits perfectly in this situation: "No battle is won according to the battle Hatton plans, but no battle was ever won without a plan." Apress © 2003 (696 pages)
Thewe authors of each this text show how easy it can be to producefrom Figure 2-8, including brief In the next sections discuss of the classes shown in the diagram interesting multimedia games using Managed DirectX 9.0 and explanations of their properties and methods. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
The Sprite Class
We'llofuse this class, defined in the "Sprites and Performance Boosting Tips" section, as the base class for Table Contents all other objects. with Remember that all the members (properties and methods) of this class become .NET Gamegame Programming DirectX 9.0 members of the derived classes too. Foreword Preface
The Netterpillar Class
Introduction
Chapter 1 - .Nettrix: GDI+ Detection TheNetterpillar classand will Collision control the drawing of the netterpillar characters on screen, both for Chapter 2 - .Netterpillars: Artificial Intelligenceones. and Sprites human-controlled and computer-controlled It'll have some methods for making the netterpillar Chapter 3 - Managed First Steps: Basics and and DirectX vs. GDI+ bigger (when it eats aDirectX mushroom) and toDirect3D store the bitmaps current status for the character. Table 2-7 Chapter - River Pla.Net: for Tiled Game Fields,of Scrolling, andalong DirectAudio lists the4initial suggestion the members this class, with a short description. Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter Table 2-7: 6 - The Magic Members KindergarteN.: of theAdventure Netterpillar Games, Class ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
TYPE
NAME
DESCRIPTION
D-iNfEcT: New Multithreading, Nonrectangular Windows, We'll have andan Access overloaded to New method, which Nonmanaged Code will load with the multiple images of a Bonus Chapter Porting .Nettrix to Pocket PC netterpillar: the head (looking at different
Method Chapter 9 -
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Method
Draw
Appendix C - How Do I Make Games?
directions) and the body parts. The overloaded function that draws all the parts of the netterpillar.
Appendix D - Guidelines for Developing Successful Games
Move
Instead of Undraw,Move is more appropriate here: Move the head and every body part according to the current direction, erasing the field only after the last body part.
Method
EatAndMove
If the netterpillar eats a mushroom, the last part doesn't get erase, because the body length is increased.
Properties
BmpNetterHeadN, BmpNetterHeadS, BmpNetterHeadE, BmpNetterHeadW
We'll need one image for the head for each direction that the netterpillar is looking at/moving to.
Property
NetterBody()
We'll need an array to store all the body parts
Property
NetterBodyLength
The current size of the netterpillar, which will be used to keep track of the body parts array.
Property
IsComputer
We have to have a way of knowing which players are human controlled and which are computer controlled; this will help with the future evolution of a multiplayer game.
Property
IsDead
Instead of actually destroying the netterpillar, we'll just set a flag saying that it's dead, thus avoiding internal tests to see if a given netterpillar object exists.
Index Method List of Figures List of Tables
.NET Game Programming with DirectX 9.0
The Mushroom Class Santos Lobão and Ellen by Alexandre
ISBN:1590590511
Hatton Since a mushroom does© nothing Apress 2003 (696except pages) for standing and waiting to be eaten, all we need is an overloaded
New method that The will authors load theofappropriate image file, so we won't need to pass the filename when creating this text show how easy it can be to produce a new mushroom. The Mushroom class will have all theDirectX members from the Sprite class, plus the interesting multimedia gamesthen using Managed 9.0 and overloadedNew method programming that loads with the Visual mushroom Basic .NET image on Everett, file in athe given latest position version of Microsoft's Visual Studio.
The Branch Class Table of Contents
A branch will be composed of three different images: one for each branch edge, and a middle one that
.NET Programming with DirectX 9.0bigger branches. Since the Sprite base class only stores a single can Game be repeated many times to create Foreword image, we'll have to create three properties to store these images, and create new overloaded functions Preface for the New and Draw methods. Since the branch doesn't move, we won't need to create an Undraw Introduction method. The list of members for the branch class is shown in Table 2-8. Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 - The .Netterpillars: Intelligence and Sprites Table 2-8: MembersArtificial of the Branch Class Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
TYPE
NAME
DESCRIPTION
Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen New This overloaded version of the Newmethod will Method Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, receive the sizeand andDirectShow orientation (north-south or eastChapter 7 - Magic KindergarteN. II: Animation Techniques west) of theand branch. Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Method
Draw
This method draws the branch, according to its size,
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to position, and orientation. Nonmanaged Code
Bonus Chapter Porting Size.Nettrix to Pocket PC Property Appendix A - The State of PC Gaming
Properties
BmpBranchTop, BmpBranchBottom
Appendix B - Motivations in Games
The size of the branch. The images of the branch extremities.
Appendix C - How Do I Make Games?
BmpbranchMiddle Appendix Property D - Guidelines for Developing Successful The Games image for the middle part of the branch that will Index List of Figures
be repeated over and over by the Draw method, until the branch reaches the desired size.
List of Tables
The AINetterpillar Class To define a basic set of members for the class that will handle the netterpillar artificial intelligence requires a little more thinking. The first question that arises is, How smart is our computer-controlled character meant to be? Even in this simple game we can think about some very difficult AI routines. For example, will a computer-controlled netterpillar do any of the following? Chase the player (or one another) and try to surround the player with its tail, in order to kill him or her. Analyze its tail positions on every move, in order to avoid getting trapped by its own tail. Analyze the whole game field to look for places where there are more mushrooms or fewer netterpillars. Since all we need here is a simple example, our netterpillar won't be that smart, at least for the first version of the game. All we want to do is Avoid getting killed by hitting a wall, while eating everything that is near to the head. Add some random behavior to make the movement of the computer-controlled netterpillars more unpredictable to the player. Table 2-9 shows the first suggested methods and properties we'll create to address these goals.
Table 2-9: The Members of the AINetterpillar Class
.NET Game Programming with DirectX 9.0
TYPE
by Alexandre Santos Lobão and Ellen NAME
Method
Hatton ChooseNetterpillarDirection Apress © 2003 (696 pages)
Method
RandomDirection
ISBN:1590590511 DESCRIPTION
This method will analyze the netterpillar direction and choose the best The authors of this text show how easy position it can beand to produce interesting multimedia games using Managed direction DirectX to move 9.0 and to, based on the programming with Visual Basic .NET on immediate Everett, thesurroundings latest of the netterpillar's version of Microsoft's Visual Studio. head.
Table of Contents
.NET Game Programming with DirectX 9.0 Foreword Preface
Property
Introduction
This method will add the random behavior, based on the RandomPercent property, and taking care not to lead the netterpillar straight to collision and death.
RandomPercent
This property will control how random the behavior of our netterpillar will be. .Nettrix: GDI+ and Collision Detection Remember that a new direction will be .Netterpillars: Artificial Intelligence and Sprites chosen many times each second, so any Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ number greater than 10 may make the River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio netterpillar's movements too random to River Pla.Net II: DirectInput and Writing Textseem to Screen intelligent.
Chapter 1
-
Chapter 2
-
Chapter 3
-
Chapter 4
-
Chapter 5
-
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 -these Magic members KindergarteN. II:also Animation and Speech API Of course, could be partTechniques of our Netterpillar class, but we decided to create a Chapter 8 .Netterpillars II: Multiplayer Games and Directplay new class for them in order to have the artificial intelligence code isolated from the drawing code, making D-iNfEcT:and Multithreading, it easier9 to-maintain improve. Nonrectangular Windows, and Access to Chapter Nonmanaged Code Bonus The last Chapter gamePorting class,.Nettrix which deals to Pocket with PC the game engine, is discussed next. Appendix A - The State of PC Gaming
The GameEngine Class Appendix B - Motivations in Games Appendix C - How Do I Make Games?
For the GameEngine class, we can pick some ideas from the .Nettrix sample we saw in the last chapter:
Appendix D - Guidelines for Developing Successful Games
Index It's important to have a method to redraw the game field. List of Figures
also need a direct reference to the game field (such as a handle) to be used in the drawing List ofWe'll Tables operations. Since we'll have a dedicated class to control the game, we'll need a property to control if the game is running or paused, just like the variable on the form in the previous chapter. A property to control whether the game is over is a good idea too. According to the idea of having an array to control collisions (which seems to be the right choice in our case, since our game will be a tile-based one), we'll need a property to store the game field array. Since the game engine will need to do all the physics of the game, it'll need to have access to all game objects. The best way to allow this is to let the GameEngine class create and handle them, so we'll need properties to store the branch objects; the netterpillar objects and the netterpillars quantity; and the mushroom objects and the mushroom quantity. We'll have a configuration screen to set some game properties, and we'll need corresponding properties to store the configurable parameters: width and height properties, since our game field can have different sizes; a property to hold the desired mushroom quantity; and another one to hold how many netterpillars will be present. Since we'll control only one netterpillar, we'll need some property to define, for each netterpillar, if it's computer controlled or human controlled. Having such a property will help in another game objective: to code a game ready to be turned into a multiplayer version in the future. In this case, in the next version we can add information to tell if the netterpillar is a local gamer, a remote gamer, or a computer.
Since the sprites needProgramming to erase themselves, we'll need .NETwill Game with DirectX 9.0 a property to store the initial background image of the by game field. ISBN:1590590511 Alexandre Santos Lobão and Ellen Hatton
Note That's aApress lot of ©things to be thinking about, and we haven't covered the methods yet. But don't 2003 (696 pages) expect The to remember everything in the first brainstorm. It'sproduce usual to create a first draft, and then authors of this text show how easy it can be to refine it.interesting When wemultimedia think aboutgames the game and create pseudo-code for the most usinglogic Managed DirectXsome 9.0 and programming Visual Basic .NET on and Everett, the latest important parts of thewith game, new properties methods arise. When refining the new set, version of Microsoft's Studio. other new details arise. ThisVisual process is repeated over and over until we have a stable set of classes, properties, and methods. In (very) few words, that's the basis of what is suggested in most of the books covering object-oriented analysis currently. Table of Contents .NET with DirectX based 9.0 We Game can listProgramming a basic set of methods on the features coded in the previous chapter—for example, a Foreword method to initialize the game field, a method to redraw it, a method to render (which will basically do the Preface physics, update the object states, and then redraw the game field), and some methods to move the game Introduction objects and to change their states (such as setting a netterpillar as dead, and asking the netterpillar object Chapter 1 -its .Nettrix: to remove drawingGDI+ fromand theCollision screen).Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites Based 3on the previously discussed points, our class willand have the interface shown in Table 2-10. Chapter - Managed DirectX First Steps: Direct3D Basics DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Table 2-10: The Members of the GameEngine Class - River Pla.Net II: DirectInput and Writing Text to Screen Chapter KindergarteN.: Adventure Games, DESCRIPTION ADO.NET, and DirectShow TYPE6 - Magic NAME Chapter 5 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API New Method This method creates the game field and Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay
initializes all properties
Chapter 9
-
Method
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code MoveNetterpillars
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
A method for moving the netterpillars, according to the current direction of each one. Also checks for collisions.
Appendix B - Motivations in Games
MethodC - How Do I Make Games? Appendix
This method removes the netterpillar from the game field, if it collides with some wall or other Appendix D - Guidelines for Developing Successful Games netterpillar. KillNetterpillar
Index
ListMethod of Figures
Redraw
This method redraws the game field.
Method
Render
A method for calling all other methods; in other words, it moves everyone, kills anyone who must be killed, checks for game over, and calls the Redrawmethod.
Property
ScreenWinHandle
The handle of the game field window, used for drawing the game objects.
Properties
Width,Height
The game field dimensions, which will be configured by the user.
Properties
ObjNetterpillars(), NetterpillarNumber
The netterpillar objects array and the total number of netterpillars.
Property
ObjBranches()
The branch objects array.
Properties
ObjMushrooms(), MushroomNumber
The mushroom objects array and its total number.
Property
GameOver
If true, the game is over.
Property
Paused
If true, the Render procedure won't move any netterpillar.
Property
ArrGameField()
The array with the game objects, used for implementing the collision detection.
List of Tables
Property
BackGroundImage The initial .NET Game Programming with DirectX 9.0background image, which will be used by the sprites to erase themselves (drawing a ISBN:1590590511 by Alexandre Santos Lobão and Ellen portion of the background image over them). Hatton Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce
Since our class diagram now is stable, games it's timeusing to define howDirectX the main will call the classes. In the interesting multimedia Managed 9.0program and next topic we discuss programming the structure with of Visual the game's Basic .NET main on program. Everett, the latest version of Microsoft's Visual Studio.
The Main Program Structure Table of Contents
NowGame let's think about how theDirectX game9.0 will work. We need to define a starting place, from which the game .NET Programming with
engine object and the game window will be created, and from which the Render procedure of the game engine will be called repeatedly. Preface Foreword
Introduction Since we'll need a configuration screen, too, it's better to first have an introductory screen, in which players Chapter 1 - .Nettrix: GDI+ Detection can choose if they want to and startCollision the game or to change the game configuration. Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites Although commonDirectX in some OOA techniques suggest creation of new classes for the forms Chapter 3 it's - Managed First Steps: Direct3Dto Basics and the DirectX vs. GDI+
(sometimes called interface classes), it'll beScrolling, easier not toDirectAudio mix user interface with the game logic for now. Chapter 4 - River Pla.Net: Tiled Game Fields, and Instead, use Pla.Net common forms, create simple workflow diagram, as shown in Figure 2-9, Chapter 5 we'll - River II: window DirectInput andand Writing Texta to Screen in order6 to-clarify the game flow will be.Games, ADO.NET, and DirectShow Chapter Magic how KindergarteN.: Adventure Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 2-9: The game main workflow We could give details of the Render procedure, including in the loop shown on the diagram in Figure 2-9 boxes for such processes as gathering user input, updating game objects, redrawing, etc. (and in a real project we strongly suggest that you do). However, the goal for this diagram is only to make it easier to understand the basic game flow across the many screens and the basic game loop, and it does this effectively. In the next topic we'll create a draft of each game screen, thus finishing our game project.
Defining the Game Screens Although the windows implementation will be done in the code phase, it's good practice to create at least a
draft of the screens in the project phase, because when drawing the screen we usually remember more .NET Game Programming with DirectX 9.0 details that can be added to the class diagram. If we can imagine how the previously discussed classes ISBN:1590590511 Alexandre Ellen we haven't will work in each by screen, then Santos there's Lobão a goodand chance missed any important details. Hatton Apress © 2003 pages)screens quickly, the best sketches are the ones done directly in Since Visual Basic allows us to(696 create The authors of screens this text "visual show how easy it can be to produce Visual Basic. Let's call our first prototypes." The next images will show the visual interesting multimedia games Managed DirectX 9.0on and prototypes for each game screen, starting withusing the introductory screen Figure 2-10. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
2-10: The.Nettrix intro screen BonusFigure Chapter Porting to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
The intro screen will only show an intro image (or splash screen) for the game, along with buttons to allow
Appendix C -toHow the player endDo theI Make game,Games? start a new game, or change the game configuration. According to the Appendix - Guidelines Games workflowDshown in thefor lastDeveloping topic, afterSuccessful a game ends, players will be redirected to this screen. Index
Figure 2-11 shows the second draft: the game configuration screen. List of Figures List of Tables
Figure 2-11: The game configuration screen On the configuration screen, we can set the number of netterpillars and mushrooms and the size of the game field. Since it's not up to the user to decide the exact number of pixels in a game or the exact number of mushrooms on screen, we can use domain up-down controls to make the configuration more user friendly: Few/Just Right/Many selections for mushrooms and Small/Medium/Big selections for the game field size. As we said before, as the game project evolves, we uncover new details that may require new properties and methods. Looking at the screen shown in Figure 2-11, we need only two enumerations for the GameEngine class, which will lead to simpler and cleaner code: enMushrooms for the number of mushrooms, and enSize for the possible field sizes. We'll also include two new properties that will receive the values of these enumerations directly from the configuration screen—Mushrooms and Size. In the code phase we'll see how to code property procedures in Visual Basic .NET: a pair of procedures in the class that correspond to an object property, allowing us to do some processing—such as setting the Width and Height properties when the Size property is set, and setting the MushroomNumber property
when the Mushrooms property is set.
.NET Game Programming with DirectX 9.0
Alexandre Santos Lobão and Ellen The draft for nextby game screen is shown in Figure 2-12.
ISBN:1590590511
Hatton Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 - 2-12: .Netterpillars II: Multiplayer Games Directplay Figure The game field screen is justand a form with an image control. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Nonmanaged Code
We can set the Picture property of the Bonus Chapter Porting .Nettrix to Pocket PC image control in the game field window with any bitmap we want to use asA background, we write a generic code in the Sprite class to do the drawing and erasing. Appendix - The State ofsince PC Gaming In this case, we set it to in a Games simple sand pattern. Appendix B - Motivations Appendix C - How Do I Make Games?
Refining the Game Project
Appendix D - Guidelines for Developing Successful Games Index
You've learned about making progressive refinements in the game project, until you reach the point to List of Figures start coding phase. But how do you know when to stop making refinements? List of the Tables If, after you've drawn the class diagram and the workflow diagram, and also created the visual prototypes for all game screens, you still don't have a clear idea about how any part of the game will work, it's important to write pseudo-code for this part and check the workflow, the classes, and the screen drafts again until everything seems to fit. Only start the code phase after you have a clear idea about how things will work, but take care not to get stuck on the project, creating an excessive level of details (except, maybe, for big projects where the lack of detail can cost a lot). Just remember: It's much easier and faster to correct a class diagram or a screen prototype than to redo a lot of code because you forgot something important! With these points in mind, let's get into the next phase: the code.
Game Programming with DirectX 9.0 The Coding.NET Phase by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton chapter, let's start coding the basic objects for the game (simplest first), and then As we did in the previous Apress © 2003 of (696 pages) tackle the more difficult code the game engine and the netterpillar AI classes. The authors of this text show how easy it can be to produce
To allow us to test every new method created, we'll Managed do our code in five interesting multimedia games using DirectX 9.0steps: and with Visual Basic .NET on Everett, the latest 1. First draft:programming Code the static objects. version of Microsoft's Visual Studio.
2. Second draft: Code the player character. Table of Contents
3. Third draft: Code the game engine and collision detection.
.NET Game Programming with DirectX 9.0
Foreword 4. Fourth draft: Code the configuration screen and game over. Preface
5. Final version: Code the netterpillars AI. Introduction Chapter 1
.Nettrix: GDI+ and Collision Detection The details- of each of these versions are shown in the next sections.
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
First Draft: Coding the Static Objects - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4 Chapter 5
River Pla.Net II: DirectInput and Writing Text to Screen In the next-sections we show the code and discuss the details of the classes for the static objects, mushrooms, Chapter 6 - Magic Adventure Games, ADO.NET, andand DirectShow and branches, andKindergarteN.: create an early version of the main program the GameEngine class, so we can test Chapter 7 Magic KindergarteN. II: Animation Techniques and Speech API these classes. Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: The Sprite ClassMultithreading, Nonrectangular Windows, and Access to Chapter 9 -
Nonmanaged Code We'll Chapter only addPorting a new .Nettrix property this class, Bonus toinPocket PC the IMAGE_PATH constant, which will be used by all the child
classes A to -compose fullGaming path from where the images should be loaded. Appendix The Statethe of PC Appendix B - Motivations in Games
The Mushroom Appendix C - How Do IClass Make Games? Appendix D - Guidelines for Developing Successful Games
There's not much to say about the Mushroom class. It just has an overloaded New method that creates a sprite with the mushroom drawing, to be used instead of the original sprite New method with a parameter. This will List of Figures allow cleaner code when creating mushrooms. Index
List of Tables
Public Class clsMushroom Inherits clsSprite Sub New() End Class
NEW IN Visual Basic .NET is a fully object-oriented language, which differs from the previous version. All .NET basic OO concepts are included, such as method overload and inheritance between classes, including multiple inheritances. The inheritance is implemented using the Inherits keyword, as in the preceding sample code. The code for the New method will be as follows: Sub New() MyBase.New(Application.StartupPath & "\" & IMAGE_PATH & "\Mushroom.gif") End Sub
Note that all we did is call the base class New event, passing the appropriate parameters.
.NET Game Programming with DirectX 9.0 exists in the base class, any object created from NEW IN When a child class defines a method that already Alexandre Santos Lobão and .NET the by child class will call the code in Ellen the method of ISBN:1590590511 this class, unless we explicitly call the base class Hatton method, as in the code sample above (using MyBase.<method name>). Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce The Branch Class
interesting multimedia games using Managed DirectX 9.0 and
Visual Basic on Everett, the latest TheBranch classprogramming will also be with derived from the.NET Sprite base class, but since a branch can have different version of Microsoft's Visual Studio. sizes, we'll have to add extra variables to hold the branch bitmaps, and create new Draw and New methods that will do the branch creation and drawing. The next code sample presents the Branch class interface: Table of Contents .NET Game Class Programming with DirectX 9.0 Public clsBranch Foreword Inherits clsSprite PrefacePrivate bmpBranchStart As Bitmap
Private bmpBranchMiddle() As Bitmap Introduction bmpBranchEnd As Bitmap ChapterPrivate 1 - .Nettrix: GDI+ and Collision Detection Size As Artificial Integer ChapterPublic 2 - .Netterpillars: Intelligence and Sprites enDirection, intSize As Integer) ChapterSub 3 -New(branchDirection Managed DirectX First Steps:As Direct3D Basics and DirectX vs. GDI+ Shadows Sub Draw(winHandle As System.IntPtr, x As Integer, y As Integer) - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio End Class
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 - .Netterpillars Multiplayer Games and Directplay NEW The keywordII: Shadows helps the developer to extend base classes in a more flexible way, allowing D-iNfEcT: Multithreading, Nonrectangular and Access to IN 9 - the child class to block any methods withWindows, the same name defined in the base class, even if they Chapter Nonmanaged Code .NET have different parameters. In the preceding sample, if we had defined the method Draw without the Bonus Chapter Porting .Nettrix to Pocket PC two different Draw methods in the Branch class: one that would Shadows keyword, we'll have Appendix A - The State of PC Gaming receive only a window handle (inherited from the base class Sprite), and another (overloaded) one Appendix B - Motivations in Games that would receive the parameters as we need in the branch class. Appendix C - How Do I Make Games?
As notedDbefore, our Branch class will be usedGames to improve the visual interface by placing branches around the Appendix - Guidelines for Developing Successful game field. This class will have only two methods: the New method, which will load the bitmaps from disk, and theDraw method, which will draw the branch on screen. Since the branches don't move or disappear during List of Figures the game, we won't need to code an Undraw method. Index
List of Tables
Each branch will be composed by a set of at least three images: a "branch start," a "branch end," and one or more "branch middles." Since we'll need horizontal and vertical branches, we'll need six different images, created with a specific naming convention to help us, as shown in Figure 2-13.
Figure 2-13: The branch images TheNew method will use the concepts explained in the Load method of the Sprite class, extending the code to store the images in the specific properties of the Branch Class—branchStart,branchMiddle array, and branchEnd: Sub New(branchDirection As enDirection, intSize As Integer) ReDim bmpBranchMiddle(intSize - 3) Dim i As Integer Dim strImagePrefix As String Size = intSize Direction = branchDirection
' Picks the prefix for the branch - horizontal or vertical? .NET Game Programming with DirectX 9.0 strImagePrefix = "Hor" ' Default direction is east-west (Horizontal) ISBN:1590590511 by Alexandre Santos Lobão and Ellen If Direction = clsSprite.enDirection.North Or Direction = _ Hatton clsSprite.enDirection.South Then Apress © 2003 (696 pages) strImagePrefix = "Vert" End If The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest ' Load the top, the middle version of Microsoft's Visualparts Studio. and the end of the branch
' Magenta is the colorkey (which will be transparent) for_ ' the Load Method Table of Contents bmpBranchTop = Load(Application.StartupPath & "\" & IMAGE_PATH & "\" & _ .NET Game Programming with &DirectX 9.0 strImagePrefix "BranchStart.gif", Color.FromArgb(255, 255, 0, 204)) Foreword For i = 0 To Size - 3 Preface bmpBranchMiddle(i) = Load(Application.StartupPath & _ Introduction "\" & IMAGE_PATH & "\" & strImagePrefix &_ "BranchMiddle.gif", Color.FromArgb(255, 255, 0, 204)) Chapter 1 - .Nettrix: GDI+ and Collision Detection ChapterNext 2 - .Netterpillars: Artificial Intelligence and Sprites = Load(Application.StartupPath & "\" ChapterbmpBranchBack 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ & IMAGE_PATH & "\" & _ & "BranchEnd.gif", Color.FromArgb(255, 255, 0, 204)) Chapter 4 -strImagePrefix River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio End Sub Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 some - .Netterpillars Multiplayer and Directplay Here are points to II: note about theGames preceding code: Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Code We useNonmanaged the naming conventions stated before to load the appropriate images, including the prefix "Hor" for Bonusthe Chapter Porting .Nettrix to "Vert" Pocketfor PC the vertical ones. We are using the branchDirection parameter of horizontal images and Appendix theenDirection A - The State ofenumeration PC Gaming (defined in the base class Sprite) to choose if the branch will be vertical Appendix (north B -and Motivations south directions) in Games or horizontal (west and east directions). Appendix C - How Do I Make Games?
The image files were drawn using the magenta color where we need to create transparency, that's why we useColor.fromARGB(255, 255, 0, 204) as the parameter for the keycolor of the Load function Index (defined in the Sprite base class). Appendix D - Guidelines for Developing Successful Games List of Figures
List ofThe Tables dimension of the BranchMiddle array is defined as intSize-3 because the size of the branch will
take into account the start and the end of the branch, so we need an array with the defined size minus two. Since all arrays in Visual Basic .NET are zero based, we have intSize-2 elements when defining an array that goes from 0 to intSize-3. A little tricky, isn't it? TheDraw method will be very similar to the method with the same name on the base class. In fact, we'll be calling the base class method in order to draw each of the parts of the branch, so we won't have any real drawing code in this method. Shadows Sub Draw(winHandle As System.IntPtr, x As Integer, y As Integer) Dim i As Integer ' Sets the location and draws the start of the branch Location = New Point(x, y) MyBase.Draw(bmpBranchTop, winHandle) ' Sets the location and draws each of the branch middle parts If Direction = clsSprite.enDirection.North Or _ Direction = clsSprite.enDirection.South Then ' it's a horizontal branch For i = 0 To Size - 3 y += 1 Location = New Point(x, y) MyBase.Draw(bmpBranchMiddle(i), winHandle) Next
y += 1 Else
.NET Game Programming with DirectX 9.0
ISBN:1590590511 by Alexandre Santosbranch Lobão and Ellen ' it's a vertical Hatton For i = 0 To Size - 3 Apress © 2003 (696 pages) x += 1 The authors of show how y) easy it can be to produce Location = this Newtext Point(x, interesting multimedia games using Managed DirectX 9.0 and MyBase.Draw(bmpBranchMiddle(i), winHandle) programming with Visual Basic .NET on Everett, the latest Next version of Microsoft's Visual Studio. x += 1 End If Table of ' Contents Sets the location and draws the end of the branch
.NET Game Programming with DirectX 9.0 Foreword
Location = New Point(x, y) MyBase.Draw(bmpBranchBack, winHandle)
Preface Introduction End Sub Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Main 3Program and GameEngine ClassBasics and DirectX vs. GDI+ Chapter - Managed DirectX First Steps: Direct3D Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Since we already have two of the base classes, it's time to do some tests to check if everything is okay so far. - River Pla.Net II: DirectInput and Writing Text to Screen Instead of doing a simple test program, let's go one step ahead and start implementing the game Main Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow procedure and the GameEngine class, so we can start to understand the game logic, and add to them when Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API new features become available. Chapter 5
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Looking at the D-iNfEcT: class diagram, Multithreading, we canNonrectangular pick some properties Windows, and andmethods Access to that will help us to create a subset of Chapter 9 Nonmanaged Code the final clsGameEngine class, which will allow us to test the classes we created. We'll need to code the Bonus Chapter Porting .Nettrix to Pocket PC properties associated with mushrooms and branches, the New method (to initialize the objects), the Redraw Appendix method A(to- draw The State the objects), of PC Gaming and a Render object, the method which will do all the game physics (for now, only calling the Redrawinmethod). Appendix B - Motivations Games Our stub class will be as follows: Appendix C - How Do I Make Games? Appendix - Guidelines for Developing Successful Games PublicD Class clsGameEngine Index Public Width As Integer = 25 List of Figures Public Height As Integer = 25
Public Shared BackgroundImage As Image List of Tables Private ScreenWinHandle As System.IntPtr ' Game objects Private objBranchs() As clsBranch Private objMushrooms() As clsMushroom Private MushroomNumber As Integer = 75 ' Controls the game end Public GameOver As Boolean Sub New (WinHandle As System.IntPtr) Sub Render() Sub Redraw() End Class
In the New procedure, all we do is redimension the object arrays and create each of the objects. We'll also store the window handle received in the function to be used by the Redraw procedure: Sub New(WinHandle As System.IntPtr) Dim i As Integer Dim x As Integer, y As Integer
ReDim objBranchs(4) .NET Game Programming with DirectX 9.0 ReDim objMushrooms(MushroomNumber) by Alexandre Santos Lobão and Ellen Hatton ScreenWinHandle = WinHandle Apress © 2003 (696 pages)
ISBN:1590590511
' Initialize the random number generator (for the mushroom positions) The authors of this text show how easy it can be to produce Randomize() interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest ' Create version the branches of Microsoft's Visual Studio.
objBranchs(0) = New clsBranch(clsSprite.enDirection.North, Me.Height) objBranchs(1) = New clsBranch(clsSprite.enDirection.North, Me.Height) Table of Contents objBranchs(2) = New clsBranch(clsSprite.enDirection.East, Me.Width - 2) .NET Game Programming with DirectX 9.0 objBranchs(3) = New clsBranch(clsSprite.enDirection.East, Me.Width - 2) Foreword Preface' Create the mushrooms Introduction For i = 0 To MushroomNumber - 1 Chapter 1
New clsMushroom() -objMushrooms .Nettrix: GDI+ and=Collision Detection
Chapter 2
= Int(Rnd(1) * Intelligence (Me.Width 2)) + 1 -x.Netterpillars: Artificial and-Sprites
Chapter 3
= Int(Rnd(1) (Me.Height - 2)) 1 -yManaged DirectX First*Steps: Direct3D Basics and+ DirectX vs. GDI+
Chapter 4
= new and point (x,y) -objMushrooms(i).location River Pla.Net: Tiled Game Fields, Scrolling, DirectAudio
ChapterNext 5 - River Pla.Net II: DirectInput and Writing Text to Screen
End Sub - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 6 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 the - .Netterpillars II: Multiplayer and Directplay For now, Render method just callsGames the Redraw method; in future versions it will call the functions to D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to implement Chapter 9 - the game physics. Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
Sub Render() Redraw() Appendix B - Motivations in Games End Sub
Appendix A - The State of PC Gaming Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List As of forFigures our Redraw method, all we need is to call the Draw method of each game object. List of Tables
Sub Redraw() Dim i As Integer For i = 0 To MushroomNumber - 1 objMushrooms(i).Draw(ScreenWinHandle) Next objBranchs(0).Draw(ScreenWinHandle, objBranchs(1).Draw(ScreenWinHandle, objBranchs(2).Draw(ScreenWinHandle, objBranchs(3).Draw(ScreenWinHandle, End Sub
0, 0) (Me.Width - 1), 0) 1, 0) 1, (Me.Height - 1))
Now, with the clsGameEngine class stub done, all we need to do is to create a Main procedure that will generate the game engine object and call the Render method until the game is over (in this case when the Esc key is pressed). To do this, add a module to the solution and include the following code: Public objGameEngine As clsGameEngine Sub main() ' Create the game field form (as defined in the game project) Dim WinGameField As frmGameField
' Create the game engine object .NET Game Programming with DirectX 9.0 objGameEngine = New clsGameEngine(WinGameField.PicGameField.Handle) by Alexandre Santos Lobão and Ellen Hatton WinGameField = New frmGameField() Apress © 2003 (696 pages)
ISBN:1590590511
WinGameField.Show()
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and ' Createsprogramming a copy of the background with Visual Basic .NET onimage Everett,to the allow latest ' erasing the sprites Visual Studio. version of Microsoft's
objGameEngine.BackgroundImage=WinGameField.PicGameField.Image.Clone Do While Not objGameEngine.GameOver Table of Contents objGameEngine.Render() .NET Game Programming with DirectX 9.0 Application.DoEvents() Foreword Loop PrefaceMsgBox("Game Over", MsgBoxStyle.Exclamation, ".Netterpillars") Introduction ChapterWinGameField.Dispose() 1 - .Nettrix: GDI+ and Collision Detection
Nothing ChapterobjGameEngine 2 - .Netterpillars: =Artificial Intelligence and Sprites End Sub Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
Magic KindergarteN. II: Animation Techniques and Speech API NEW -As everyone who worked with previous versions of Visual Basic can see in the preceding code, there -are .Netterpillars II: Multiplayer Games Directplay a lot of modifications in the wayand Visual Basic works with forms. Now, every form we create is just D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to .NET Chapter 9 -a class (in the previous versions, we could work with them as classes or as objects); so we always Nonmanaged Code have to create a new object of the form class in order to have a workable window. There's no more Bonus Chapter Porting .Nettrix to Pocket PC Unload command.We now dispose of a window by calling the Dispose method of the object Appendix A - The State of PC Gaming previously created. The members of the form object are also somewhat different: There are new Appendix B -methods, Motivations in Games and events, and some of the old ones have disappeared. The Visual Basic help properties, Appendix C -has Howa Do I Make Games? comprehensive list of all changes, including the Unload/QueryUnload events, which don't Appendix D -exist Guidelines for and Developing Successful anymore are replaced by aGames Closing event; and the changes to each event depending on Index the parameters received. Chapter ON8
List of Figures
All of weTables need to finish this first draft is to capture the Esc key to end the game. This can be done using the List KeyDown event of frmGameField: Private Sub frmGameField_KeyDown(sender As Object, e As KeyEventArgs) _ Handles MyBase.KeyDown ' We are dealing with just one key for now, but all the game ' control will be here in the finished game Select Case e.KeyCode Case Keys.Escape objGameEngine.GameOver = true End Select End Sub
Running our program now, we can see a basic game field filled with mushrooms, as shown in Figure 2-14.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction
Figure- 2-14: Testing the first basic classes .Nettrix: GDI+ and Collision Detection
Chapter 1 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Second Draft: Coding the Player Character - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen The next step in our code phase is to code the Netterpillar class and make all adjustments needed to our Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow first draft for the main program and the game engine to allow the player character to be drawn on screen and Chapter 7 - Magic KindergarteN. II:the Animation Techniques and Speech API The next sections show and discuss the be controlled by the player, using keyboard navigation (arrow) keys. Chapter 8 .Netterpillars II: Multiplayer Games and Directplay code to do this. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code Netterpillar Class
Chapter 9
The
-
Bonus Chapter Porting .Nettrix to Pocket PC
We'll now the Netterpillar class and begin to code it. The main body of this class is shown here. Appendix A -look Theat State of PC Gaming We'll look the methods belonging to it in the subsequent code samples. Appendix B -atMotivations in Games Appendix C - How Do I Make Games? Appendix - Guidelines for Developing Successful Games PublicD Class clsNetterpillar Index Inherits clsSprite
Private bmpNetterHeadN As Bitmap List of Figures Private bmpNetterHeadS As Bitmap List of Tables Private bmpNetterHeadE As Bitmap Private bmpNetterHeadW As Bitmap Public NetterBody() As clsNetterBody Public NetterBodyLength As Integer = 4 Public IsComputer As Boolean = True Public IsDead As Boolean = False Sub New(x As Integer, y As Integer, _ InitialDirection As clsSprite.enDirection, bIsComputer As Boolean) Sub EatAndMove(x As Integer, y As Integer, WinHandle As System.IntPtr) Sub Move(x As Integer, y As Integer, WinHandle As System.IntPtr Public Sub Draw(WinHandle As System.IntPtr) End Class
When deriving the code interface from the class diagram, if we don't have a detailed project we usually start with few or even no parameters in the methods. The rich interface just shown, with many parameters in some methods, was created step by step when coding each of the methods. For example, the parameter bIsComputer in the New method is included later on in the coding process, when we discover that after each call to the New method, we are setting the IsComputer property of the class, a clear indication that we should include this property as a parameter in the New method. Another surprise here is the NetterBody() array. When doing the class diagram, we thought about having an array of "body parts" of the netterpillar. But what exactly is a body part in this case? It might be an array of
Point objects, which would store the position to which the body bitmap must be drawn, for example. But then Game Programming with DirectX 9.0 we would need to.NET create a complex logic in the Netterpillar class to deal with the drawing of body parts. So ISBN:1590590511 by Alexandre Santos Lobão and Ellen we opt to create a new class, NetterBody, that will be as simple as the Mushroom class (except that a Hatton different bitmap is used), so we can use the Location property and Draw method of the Sprite base class. Apress © 2003 (696 pages)
The authors this text show how easy no it can beanswer. to produce Is this the best choice for the of implementation? There's right The best option is the one that will be interesting games using Managed simpler for us to create and,multimedia most importantly, to debug and DirectX update.9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
As for the images of the netterpillar, besides four different bitmaps for the head (each one heading to a different direction) and one for the body, we'll need two different sets of images to allow a visual contrast between the player-controlled Table of Contents netterpillar and the computer-controlled ones. Using the prefix "player" for the player bitmaps, we'll followProgramming the naming conventions shown in the Figure 2-15. .NET Game with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Figure 2-15: The names for the netterpillar images
With these names in mind, we can create the NetterBody and the D-iNfEcT: Multithreading, Nonrectangular Windows,class and Access toNew method of the Netterpillar Chapter 9 Nonmanaged Code class. Bonus Chapter Porting .Nettrix to Pocket PC Appendix - The State of PC Gaming PublicA Class clsNetterBody Appendix B - Motivations in Games Inherits clsSprite Appendix C -New(IsComputer How Do I Make Games? Sub As Boolean) Appendix D -MyBase.new(Application.StartupPath Guidelines for Developing Successful Games & "\" & IMAGE_PATH & "\" _ Index & IIf(IsComputer, "", "Player") & "NetterBody.gif")
End Sub List of Figures End Class List of Tables As we defined in the class properties, the default length of the body of the netterpillar (NetterBodyLength property) is four, so the netterpillar starts with a minimum size. Since the New procedure will receive the initial direction for the netterpillar, we'll use this direction to position the body parts behind the head (for example, if the netterpillar is heading east, the body parts will appear to the west of the head (lower values on the x axis). This code sample works out the position of the body relative to the head: Sub New(x As Integer, y As Integer, InitialDirection _ As clsSprite.enDirection, bIsComputer As Boolean) ' Start with a bigger length so we needn't redim it so soon ReDim NetterBody(25) Dim i As Integer Dim incX as integer = 0, incY as integer = 0 IsComputer = bIsComputer bmpNetterHeadN = Load(Application.StartupPath & "\" & IMAGE_PATH & "\" & _ IIf(IsComputer, "", "Player") & "NetterHeadN.gif") bmpNetterHeadS = Load(Application.StartupPath & "\" & IMAGE_PATH & "\" & _ IIf(IsComputer, "", "Player") & "NetterHeadS.gif") bmpNetterHeadE = Load(Application.StartupPath & "\" & IMAGE_PATH & "\" & _ IIf(IsComputer, "", "Player") & "NetterHeadE.gif")
bmpNetterHeadW = Load(Application.StartupPath & "\" & IMAGE_PATH & "\" & _ .NET Game ProgrammingIIf(IsComputer, with DirectX 9.0 "", "Player") & "NetterHeadW.gif") by Alexandre Santos Lobão and Ellen Hatton For i = 0 To NetterBodyLength - 1 Apress © 2003 (696 pages)
ISBN:1590590511
NetterBody(i) = New clsNetterBody(IsComputer)
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest ' Position theofNetterpillar on the given point version Microsoft's Visual Studio.
Next
Direction = InitialDirection Location.X = x Table of Contents Location.Y = y .NET Game Programming with of DirectX ' Position each the9.0 body parts Foreword Select Case Direction Preface Case clsSprite.enDirection.East Introduction incX = -1 clsSprite.enDirection.South Chapter 1 -Case .Nettrix: GDI+ and Collision Detection = -1 Artificial Intelligence and Sprites Chapter 2 -incY .Netterpillars: Case clsSprite.enDirection.West Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ = Tiled 1 Game Fields, Scrolling, and DirectAudio Chapter 4 - RiverIncX Pla.Net: CasePla.Net clsSprite.enDirection.North Chapter 5 - River II: DirectInput and Writing Text to Screen incY = 1 Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow End Select Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API For i = 0 To NetterBodyLength - 1 Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay x += incX D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - y += incY Nonmanaged Code NetterBody(i).Location.X = x Bonus Chapter Porting .Nettrix to Pocket PC NetterBody(i).Location.Y = y Appendix A - The State of PC Gaming Next Appendix B - Motivations in Games End Sub Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index Observe that we simply set the location of the netterpillar (the head) and the location of each of the body parts, butofthere's no drawing yet. The drawing is done in the Draw procedure (shown in the next code listing), which List Figures
considers List of Tablesthe direction in which the netterpillar is heading in order to choose which bitmap will be used for the head, and then runs through the NetterBody array to draw the body parts. Public Overloads Sub Draw(WinHandle As System.IntPtr) Dim i As Integer Select Case Direction Case clsSprite.enDirection.East MyBase.Draw(bmpNetterHeadE, WinHandle) Case clsSprite.enDirection.South MyBase.Draw(bmpNetterHeadS, WinHandle) Case clsSprite.enDirection.West MyBase.Draw(bmpNetterHeadW, WinHandle) Case clsSprite.enDirection.North MyBase.Draw(bmpNetterHeadN, WinHandle) End Select For i = 0 To NetterBodyLength - 1 NetterBody(i).Draw(WinHandle) Next End Sub
The last two methods of the Netterpillar class are very similar: Move and EatAndMove. The Move method .NET Game Programming will update the head location according to thewith newDirectX X and Y9.0 values passed as parameters from the game ISBN:1590590511 by Alexandre Santos Lobão and Ellen engine, and then update all the body parts to move one step ahead. We could erase and draw everything, but Hatton since all the body parts look the same, we can just erase the last body part, copy the first body part over the Apress © 2003 (696 pages) head, and draw the head in the new position, which will be much quicker than redrawing the whole body. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and Sub Move(x Asprogramming Integer,with y As Visual Integer, Basic .NETWinHandle on Everett, the Aslatest System.IntPtr) of Microsoft's Visual Studio. Dim i As version Integer
' Erase the last part of the body NetterBody(NetterBodyLength - 1).UnDraw(WinHandle)
Table of Contents
.NET Game Programming with DirectX 9.0
' Updates the whole body's position and then the head position For i = NetterBodyLength - 1 To 1 Step -1 Preface NetterBody(i).Location = NetterBody(i - 1).Location Introduction Next ChapterNetterBody(0).Location 1 - .Nettrix: GDI+ and Collision= Detection Location ChapterLocation 2 - .Netterpillars: Intelligence and Sprites = New Artificial Point(x, y) Foreword
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter'4 Redraws - River Pla.Net: Fields, Scrolling, and body DirectAudio only Tiled the Game first part of the and the head ChapterNetterBody(0).Draw(WinHandle) 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow need to erase the netterpillar head,APIsince the body will cover it Chapter'We 7 -don't Magic KindergarteN. II: Animation Techniques and Speech ChapterDraw(WinHandle) 8 - .Netterpillars II: Multiplayer Games and Directplay
End Sub D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to -
Chapter 9
Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
The main difference between the EatAndMove method and the Move method is that in the first method the netterpillar is eating a mushroom and is getting bigger; so we'll need to create a new body part (redimensioning Appendix B - Motivations in Games theNetterBody array), set its position to the position of the last body part, and then reposition all other body Appendix C - How Do I Make Games? parts, redrawing only the first one and the head; while in the second method the netterpillar will only move, Appendix D - Guidelines for Developing Successful Games following a similar approach. Appendix A - The State of PC Gaming
Index
List of Figures
Sub EatAndMove(x As Integer, y As Integer, WinHandle As System.IntPtr) Dim i As Integer
List of Tables
' Try to create a new body after the last body of the Netterpillar, ' if there's an error, then we must extend our body array Try NetterBody(NetterBodyLength) = New clsNetterBody(IsComputer) Catch ReDim Preserve NetterBody(NetterBodyLength + 25) NetterBody(NetterBodyLength) = New clsNetterBody(IsComputer) End Try NetterBody(NetterBodyLength).Location = _ NetterBody(NetterBodyLength - 1).Location ' Updates the whole body's position and then the head position For i = NetterBodyLength - 1 To 1 Step -1 NetterBody(i).Location = NetterBody(i - 1).Location Next NetterBody(0).Location = Location NetterBody(0).Draw(WinHandle) NetterBodyLength += 1 ' Updates the Netterpillar head position
Location = New Point(x, y) .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen 'Clear the mushroom Hatton UnDraw(WinHandle)
ISBN:1590590511
Apress © 2003 (696 pages)
The Netterpillar authors of this texthead show how easy it can be to produce ' Draw the interesting multimedia games using Managed DirectX 9.0 and Draw(WinHandle) programming with Visual Basic .NET on Everett, the latest End Sub version of Microsoft's Visual Studio.
Table Contents Oneof extra detail here is that we need to erase the mushroom as we are eating it. We can do that by simply calling theProgramming Undraw method before we .NET Game with DirectX 9.0call the Draw method of the Netterpillar class. Foreword
Main Preface
Program and GameEngine Class
Introduction
To test our Netterpillar class, we can add the MoveNetterpillars procedure to the clsGameEngine, - .Nettrix: GDI+ and Collision Detection and improve the keypress code of the frmGameField to update the direction of our netterpillar.
Chapter 1 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter Managed DirectX Firstreadable, Steps: Direct3D Basics and DirectX vs. GDI+ In order3 to-make the code more we'll add a Player1 property, which will point to the netterpillar that Chapter the player 4 -controls. River Pla.Net: Our netterpillar Tiled Gamewon't Fields, beScrolling, eating anything and DirectAudio for now; we'll test the EatAndMove method after
we code collision detection in the GameEngine class, in the final version of the game. Chapter 5 the - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
ChapterPublic 7 - Magic KindergarteN. II: Animation and Speech API objNetterpillars(4) AsTechniques clsNetterpillar ChapterPublic 8 - .Netterpillars Multiplayer Games and Directplay Player1II:As clsNetterpillar Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
We can Aupdate the New method of the clsGameEngine class to add four new netterpillars, and point the Appendix - The State of PC Gaming Player1 to the one, adding the following lines of code: Appendix B -property Motivations in first Games Appendix C - How Do I Make Games?
objNetterpillars(0) = New clsNetterpillar(Int(Me.Width / 3),_ Appendix D - Guidelines for Developing Successful Games Int(Me.Height) / 3, clsSprite.enDirection.South, False) objNetterpillars(1) = New clsNetterpillar(Int(Me.Width / 3),_ List of Figures Int(Me.Height) / 3 * 2, clsSprite.enDirection.East, True) List of Tables objNetterpillars(2) = New clsNetterpillar(Int(Me.Width / 3) * 2,_ Int(Me.Height) / 3 * 2, clsSprite.enDirection.North, True) objNetterpillars(3) = New clsNetterpillar(Int(Me.Width / 3) * 2,_ Int(Me.Height) / 3, clsSprite.enDirection.West, True) Player1 = objNetterpillars(0) Index
Note Notice that we have put the netterpillars a distance apart from each other, and set their initial direction to be different, so they won't hit each other just after the game starts. OurMove method is ready to move the netterpillar using the direction dictated by the game engine, so we'll create a simple MoveNetterpillars method in the clsGameEngine class that will update the x or y position of each of the netterpillars, based on their current direction. Sub MoveNetterpillars() Dim i As Integer Dim incX As Integer = 0, incY As Integer = 0 For i = 0 To NetterpillarNumber - 1 ' Moves all the Netterpillars Select Case objNetterpillars(i).Direction Case clsSprite.enDirection.East
incX = 1 .NET GameincY Programming with DirectX 9.0 = 0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen Case clsSprite.enDirection.West Hatton incX = -1 Apress © 2003 (696 pages)
incY = 0
The authors this text show how easy it can be to produce Case of clsSprite.enDirection.North interesting multimedia games using Managed DirectX 9.0 and incX 0 Basic .NET on Everett, the latest programming with =Visual incY = -1 version of Microsoft's Visual Studio.
Case clsSprite.enDirection.South incX = 0 Table of Contents incY = 1 .NET Game Programming with DirectX 9.0 End Select Foreword Preface
objNetterpillars(i).Move(_ objNetterpillars(i).Location.X + incX, _ + incY, ScreenWinHandle) Chapter 1 - .Nettrix: GDI+objNetterpillars(i).Location.Y and Collision Detection ChapterNext 2 - .Netterpillars: Artificial Intelligence and Sprites End Sub Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Introduction
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
To finish the second draft of the GameField class, we need to call the MoveNetterpillars method from Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow theRender procedure, as follows: Sub Render() D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterMoveNetterpillars() 9 Nonmanaged Code Redraw() Bonus Chapter Porting .Nettrix to Pocket PC End Sub Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? and update the Redraw method to include the lines that will draw the netterpillars: Appendix D - Guidelines for Developing Successful Games Index
For i = 0 To 3
List of Figures objNetterpillars(i).Draw(ScreenWinHandle) List of Tables Next
OurMain program won't need any updates, but if we want to test the Move method, we'll have to add some new lines in the keyboard handler, to update the direction of the player's character depending on which key is pressed: Private Sub frmGameField_KeyDown(sender As Object, e As KeyEventArgs) _ Handles MyBase.KeyDown ' Set the next direction for the player. ' We will not let the player go backwards from the current direction, ' because he would die if he does so. Select Case e.KeyCode Case Keys.Right If objGameEngine.Player1.Direction <> clsSprite.enDirection.West Then objGameEngine.Player1.Direction = clsSprite.enDirection.East End If Case Keys.Left If objGameEngine.Player1.Direction <> clsSprite.enDirection.East Then objGameEngine.Player1.Direction = clsSprite.enDirection.West End If Case Keys.Up If objGameEngine.Player1.Direction <> clsSprite.enDirection.South Then
objGameEngine.Player1.Direction = clsSprite.enDirection.North .NET End IfGame Programming with DirectX 9.0 ISBN:1590590511 Alexandre Santos Lobão and Ellen Case by Keys.Down Hatton If objGameEngine.Player1.Direction <> clsSprite.enDirection.North Then Apress © 2003 (696 pages) objGameEngine.Player1.Direction = clsSprite.enDirection.South The If authors of this text show how easy it can be to produce End interesting multimedia games using Managed DirectX 9.0 and Case programming Keys.Escape with Visual Basic .NET on Everett, the latest objGameEngine.GameOver = true version of Microsoft's Visual Studio. End Select End Sub Table of Contents .NET Game Programming with DirectX 9.0
In the keyboard handler in the preceding code, note the conditional statements: These test the current player's Foreword direction and stop it from running backwards, which will lead to the immediate death of the netterpillar when we Preface include collision detection. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Figure 2-16 presents the test of this code draft.
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 2-16: Testing the netterpillars This test will be a really quick one: Since we aren't implementing collision detection yet, nor the AI, the computer-controlled netterpillars will go straight through the field and disappear off the edge of the screen. The game will crash a few seconds after that.
Third Draft: Coding the Game Engine and Collision Detection In this last part of our coding, we'll finish the GameEngine class and code the AI for the computer-controlled netterpillars. We'll also add the code to allow the configuration screen to function properly.
The GameEngine Class To code the interface of the GameEngine class, we must refer to the class diagram we created in the game project phase and include the implementation details. The GameEngine class interface is presented in the following code listing: Public Class clsGameEngine Public Width As Integer = 25 Public Height As Integer = 25
Public Shared BackgroundImage As Image .NET Game Programming with DirectX 9.0 by Alexandre Santoscontrols Lobão and Ellen ' This array and enum the objectISBN:1590590511 collision Hatton Protected Shared arrGameField(,) As enGameObjects Apress © 2003 (696 pages) Protected Enum enGameObjects The authors Mushroom = 0 of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and Emptyprogramming = 1 with Visual Basic .NET on Everett, the latest Branch = 2of Microsoft's Visual Studio. version Netterpillar = 3 End Enum Table of Contents .NET Game Programming with DirectX 9.0As System.IntPtr Private ScreenWinHandle Foreword Preface' Game objects Introduction Private objBranchs() As clsBranch Chapter 1
- .Nettrix: GDI+ and Collision Detection
objMushrooms As clsMushroom ChapterPrivate 2 - .Netterpillars: Artificial Intelligence and Sprites MushroomNumber AsDirect3D Integer = 75 ChapterPrivate 3 - Managed DirectX First Steps: Basics and DirectX vs. GDI+ objNetterpillars(4) clsNetterpillar ChapterPublic 4 - River Pla.Net: Tiled Game Fields, As Scrolling, and DirectAudio NetterpillarNumber AsWriting Integer 1 ChapterPublic 5 - River Pla.Net II: DirectInput and Text to=Screen Public Player1 As clsNetterpillar - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 6 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
'Controls the game end - .Netterpillars II: Multiplayer Games and Directplay Public GameOver As Boolean D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterPublic 9 Paused As Boolean Nonmanaged Code Chapter 8
Bonus Chapter Porting .Nettrix to Pocket PC
' This properties will be defined as property procedures, and ' they'll use the enumerations below as property types Appendix B - Motivations in Games Property Size() As enSize Appendix C - How Do I Make Games? Property Mushrooms() As enMushrooms Appendix A - The State of PC Gaming
Appendix D - Guidelines for Developing Successful Games Index Sub MoveNetterpillars() List of Figures Sub KillNetterPillar(Netterpillar As clsNetterpillar) List of Tables Sub Render()
Sub New (WinHandle As System.IntPtr) Sub Redraw() End Class
Let's start coding the collision detection, which is accomplished by making the arrGameField array hold all the game objects and, before moving the netterpillars (the only moving objects), checking to see if there's any collision. We fill the array in the New method, including some lines to set the array just after creating the objects. At this point, we can make a simple improvement in our New and Draw procedures: Instead of creating dozens of mushroom objects, we could create a single object and move it as needed to draw all the mushrooms on the game field. This will have no effect on our collision detection algorithms, since we'll use arrGameField instead of the Mushroom object to test the collision. We'll just include the following lines in the New procedure we coded previously, starting with an initialization loop that will set all the objects in the array to Empty: ' Initialize the game array (for collision detection) For x = 0 To Width - 1 For y = 0 To Height - 1 arrGameField(x, y) = enGameObjects.Empty Next
Next .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
After creating theHatton netterpillars, we insert the code for setting all the positions in the array (head and bodies) for Apress © 2003 (696 pages) enGameObjects enumeration member: each netterpillar to the Netterpillar The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and ' Populates the array withBasic the.NET netterpillars programming with Visual on Everett, the latest For i = 0version To NetterpillarNumber - 1 of Microsoft's Visual Studio.
arrGameField(objNetterpillars(i).Location.X, _ objNetterpillars(i).Location.Y) = enGameObjects.Netterpillar Table of Contents For j = 0 To objNetterpillars(i).NetterBodyLength - 1 .NET Game Programming with DirectX 9.0 arrGameField(objNetterpillars(i).NetterBody(j).Location.X, _ Foreword objNetterpillars(i).NetterBody(j).Location.Y) = _ Preface enGameObjects.Netterpillar Introduction Next ChapterNext 1 - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Since the branches are just limiting our game field, we can simply do some loops that will set all the borders - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio (the array elements with x = 0, y = 0, x = Width - 1 or y = Height - 1) to the Branch enGameObjects Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen enumeration member: Chapter 4 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
For -x.Netterpillars = 0 To Width - 1 II: Multiplayer Games and Directplay arrGameField(x, 0) = enGameObjects.Branch D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -arrGameField(x, Height - 1) = enGameObjects.Branch Nonmanaged Code Next Porting .Nettrix to Pocket PC Bonus Chapter For y = 0 To Height Appendix A - The State of PC Gaming arrGameField(0, y) = enGameObjects.Branch Appendix B - Motivations in Games arrGameField(Width - 1, y) = enGameObjects.Branch Appendix C - How Do I Make Games? Next Chapter 8
Appendix D - Guidelines for Developing Successful Games Index
List of as Figures And for the mushrooms, we just need to set the array position to the enumeration element Mushroom for List of Tables each new mushroom added. We also need to make two more improvements to the code we used previously as
a stub: First, let's check if the random array position chosen has no objects in it, and if it does, choose another position, until we find an Empty array slot. Second, as planned before, let's save some memory by creating just one mushroom, and simply moving it from place to place when we need to draw the game field. The final code for the mushroom creation will be as follows: objMushrooms = New clsMushroom() For i = 0 To MushroomNumber - 1 ' Check to seek if we are not creating the mushrooms over other objects Do x = Int(Rnd(1) * (Me.Width - 2)) + 1 y = Int(Rnd(1) * (Me.Height - 2)) + 1 Loop While arrGameField(x, y) <> enGameObjects.Empty arrGameField(x, y) = enGameObjects.Mushroom Next
Note that we have to change the objMushrooms property definition to a variable, instead of an array. The code for drawing the mushrooms in the Draw method will be as follows: For x = 0 To Width - 1 For y = 0 To Height - 1
If arrGameField(x, y) = enGameObjects.Mushroom Then .NET objMushrooms.Location Game Programming with DirectX 9.0Point(x, y) = New ISBN:1590590511 by Alexandre Santos Lobão and Ellen objMushrooms.Draw(ScreenWinHandle) Hatton End If Next Next
Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
With these modifications, our New and Draw methods are filling the array that will help us with collision detection. We now need to change the MoveNetterpillars method to check for any collisions when the Table of Contents netterpillars move, and take the appropriate action: .NET Game Programming with DirectX 9.0
Kill the netterpillar if it hits an obstacle. Foreword Preface Make the netterpillar bigger when it collides with a mushroom, calling the EatAndMove method of the Introduction clsNetterpillar class; at this point we should decrement the mushroom number counter in order to Chapter 1 when - .Nettrix: GDI+ and Collision Detection know all the mushrooms have been eaten. Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Move netterpillar when there's collision. Chapter 3 -the Managed DirectX First Steps:no Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
In each case, we'll have to remember to empty the array in every position the netterpillar has visited previously - River Pla.Net II: DirectInput and Writing Text to Screen to avoid ghost collisions. We'll have to change the call of the Move method in MoveNetterpillars to a Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow selection that takes into account the actions just mentioned. Remember, this code goes immediately after the Chapter 7 will - Magic KindergarteN. II: Animation Techniques and Speech API code that set the incX and incY variables; to point to the next position the netterpillar will occupy, we have Chapter 8 .Netterpillars II: Multiplayer Games and Directplay to test the current position added to these increment variables: Chapter 5
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Select Case arrGameField(objNetterpillars(i).Location.X + incX, _ objNetterpillars(i).Location.Y + incY) Appendix A - The State of PC Gaming Case enGameObjects.Empty Appendix B - Motivations in Games objNetterpillars(i).Move(objNetterpillars(i).Location.X + incX,_ Appendix C - How Do I Make Games? objNetterpillars(i).Location.Y + incY, ScreenWinHandle) Appendix D - Guidelines for Developing Successful Games ' Update the Game Field - Empty the field after the Netterpillar Index arrGameField(objNetterpillars(i).NetterBody(_ List of Figures objNetterpillars(i).NetterBodyLength - 1).Location.X, _ List of Tables objNetterpillars(i).NetterBody(_ objNetterpillars(i).NetterBodyLength - 1).Location.Y) = _ enGameObjects.Empty ' Update the Game Field - Sets the Netterpillar Head arrGameField(objNetterpillars(i).Location.X, _ objNetterpillars(i).Location.Y) = enGameObjects.Netterpillar Case enGameObjects.Mushroom ' Decrement the number of Mushrooms MushroomNumber -= 1 objNetterpillars(i).EatAndMove(objNetterpillars(i).Location.X + incX, _ objNetterpillars(i).Location.Y + incY, ScreenWinHandle) ' Update the Game Field - Sets the Netterpillar Head arrGameField(objNetterpillars(i).Location.X, _ objNetterpillars(i).Location.Y) = enGameObjects.Netterpillar Case Else KillNetterPillar(objNetterpillars(i)) End Select Bonus Chapter Porting .Nettrix to Pocket PC
All we need to do now to test our program is to code the KillNetterpillar method, which will erase the netterpillar from the game field and do the updates on the Netterpillar object and the array field: Sub KillNetterPillar(Netterpillar As clsNetterpillar)
Dim i As Integer .NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen Netterpillar.IsDead = True Hatton ' Clears the game field Apress © 2003 (696 pages) arrGameField(Netterpillar.Location.X, Netterpillar.Location.Y) = _ The authors of this text show how easy it can be to produce enGameObjects.Empty interesting multimedia games using Managed DirectX 9.0 and Netterpillar.UnDraw(ScreenWinHandle) programming with Visual Basic .NET on Everett, the latest
version of Microsoft's Visual Studio.
For i = 0 To Netterpillar.NetterBodyLength - 1 arrGameField(Netterpillar.NetterBody(i).Location.X, _ Table of Contents Netterpillar.NetterBody(i).Location.Y) = enGameObjects.Empty .NET Game Programming with DirectX 9.0 Netterpillar.NetterBody(i).UnDraw(ScreenWinHandle) Foreword Next Preface End Sub Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
In the previous code we reset the array elements for the head and the bodies; then we call the Undraw method - .Netterpillars: Artificial Intelligence and Sprites of the Netterpillar class to remove it from the sight; and finally we set the IsDead property of the Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ netterpillar to true. Chapter 2 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5 - River and Writing Text to Screen At this point, afterPla.Net codingII: theDirectInput KillNetterpillar method, you may have noticed that we forgot to do Chapter 6 -on Magic Adventure DirectShow something the KindergarteN.: methods we had alreadyGames, coded: ADO.NET, We forgotand to test if the netterpillar is alive when moving it at Chapter 7 - Magic KindergarteN. II: Animation and Speech APImethod! Okay, don't panic, let's just add theMoveNetterpillars method and whenTechniques drawing it in the Redraw Chapter an If statement 8 - .Netterpillars to solve II: this. Multiplayer The MoveNetterpillar Games and Directplay method will become as follows: Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Sub MoveNetterpillars() ... Appendix A -iThe PC Gaming For = State 0 Toof NetterpillarNumber - 1 Appendix B -If Motivations in Games Not objNetterpillars(i).IsDead Then Appendix C - How code Do I Make Games? ... <Moving here> Appendix D -End Guidelines if for Developing Successful Games Index Next List of Figures End Sub Bonus Chapter Porting .Nettrix to Pocket PC
List of Tables
And here's how the Redraw procedure will look: ... For i = 0 To NetterpillarNumber - 1 If Not objNetterpillars(i).IsDead Then objNetterpillars(i).Draw(ScreenWinHandle) End If Next ...
This will prevent the dead netterpillar from moving and being drawn again. We can test our program now. The interface will be the same as in the second draft, but now we can effectively eat the mushrooms and get bigger, and die when we hit an obstacle.
Fourth Draft: Coding the Config Screen and Game Over Before starting the AI code, let's include some details to our game, adding the code for the configuration screen and the test for ending the game.
Coding for the Configuration Screen .NET Game Programming with DirectX 9.0 by Alexandre and Ellen Looking at the visual prototypeSantos of the Lobão configuration screen, we ISBN:1590590511 can see that we have two properties that don't Hatton map directly to numbers: the game field size and the quantity of mushrooms on the screen. In order to create a Apress © 2003 (696 pages) more direct mapping from the screen to the game field properties, let's add two property procedures: Size authors of this properties) text show how it can be to produce (which will set theThe width and height andeasy Mushrooms (which will set the MushroomNumber property, interesting multimedia games using Managed DirectX 9.0 and according to the current size ofwith the Visual game Basic field),.NET as shown in thethe following programming on Everett, latest code. version of Microsoft's Visual Studio.
Here's the Size property: Table of Contents Public Enum enSize
.NET Game Programming with DirectX 9.0 Small = 2 Foreword Medium = 1 PrefaceBig = 0 Introduction End Enum Chapter Private 1 -pSize .Nettrix:As GDI+ enSize and Collision = enSize.Medium Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Property Size() DirectX As enSize Chapter 3 - Managed First Steps: Direct3D Basics and DirectX vs. GDI+ ChapterGet 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
= pSize -Size River Pla.Net II: DirectInput and Writing Text to Screen End Get Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Set(Value As enSize) Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API pSize = Value Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Select Case Value D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Case enSize.Small Nonmanaged Code Width = 15 Bonus Chapter Porting .Nettrix to Pocket PC Height = 15 Appendix A - The State of PC Gaming Case enSize.Medium Appendix B - Motivations in Games Width = 25 Appendix C - How Do I Make Games? Height = 25 Appendix D - Guidelines for Developing Successful Games Case enSize.Big Index Width = 40 List of Figures Height = 30 List of TablesEnd Select End Set End Property Chapter 5
And now the Mushroom property: Public Enum enMushrooms Few = 2 JustRight = 1 Many = 0 End Enum Private pMushrooms As enMushrooms = enMushrooms.JustRight Property Mushrooms() As enMushrooms Get Mushrooms = pMushrooms End Get Set(Value As enMushrooms) pMushrooms = Value Select Case Value Case enMushrooms.Few MushroomNumber = 25 Case enMushrooms.JustRight
MushroomNumber = 75 .NET Game Programming with DirectX 9.0 Case enMushrooms.Many by Alexandre Santos Lobão =and Ellen MushroomNumber 125 Hatton End Select
ISBN:1590590511
Apress © 2003 (696 pages)
The authors of this text showThen how easy it can be to produce If Size = enSize.Medium interesting multimedia games using Managed DirectX 9.0 and MushroomNumber *= Basic 2 programming with Visual .NET on Everett, the latest ElseIf Size = enSize.Big Then version of Microsoft's Visual Studio. MushroomNumber *= 3 End If Table ofEnd Contents Set .NET Game Programming with DirectX 9.0 End Property Foreword Preface Introduction
NEW property definition differs a lot from the previous version of Visual Basic. Instead of Chapter 1 - The .Nettrix: GDI+procedure and Collision Detection IN 2 Chapter
procedures, Property Let and and Sprites Property Get, we have a new statement, named - two .Netterpillars: Artificial Intelligence .NET Property, where we can add two blocks: for the code that will be called when the Chapter 3 - Managed DirectX First Steps: Direct3D BasicsGet/End and DirectXGet vs. GDI+ property is read, and Set/End Set for the code that will be called when a value is set to the Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio If we to create a read-only property, we use the modifier ReadOnly before the Chapter 5 - property. River Pla.Net II:want DirectInput and Writing Text to Screen Property keyword, and simply don't provide a Set we can also define a write-only property Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and block; DirectShow using the modifie WriteOnly and not coding the Get block. Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay We must adjust the New method too, since we are always creating four netterpillars. Instead of using a fixed D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to number, Chapter 9 we - should use the NetterpillarNumber property, which will be set in the configuration window. Nonmanaged Code
Bonus .Nettrix Pocket PC SinceChapter we'll bePorting creating one totofour netterpillars, let's define where each of them will be created: Appendix A - The State of PC Gaming
If weB have one netterpillar, Appendix - Motivations in Gamescreate it in the center of the screen. Appendix C - How Do I Make Games?
If we have two netterpillars, create them in the center of the y axis (vertical), and at 1/3 and 2/3 along the x axis (horizontal), so we'll have a constant distance from the borders to the netterpillars and between the two Index netterpillars. It's better to initialize them running in different directions; so one will head north and another List of Figures south. Appendix D - Guidelines for Developing Successful Games
List of Tables
If we have three netterpillars, we'll put them at 1/4, 2/4, and 3/4 along the x axis, and in the middle of the y axis, heading south, north, and south again. If we have four netterpillars, we'll put them in a square, each heading in the direction of the next vertex. The vertices will be at 1/3 vertical, 1/3 horizontal; 1/3 vertical, 2/3 horizontal; 2/3 vertical, 2/3 horizontal; and 2/3 vertical, 1/3 horizontal. The code for this logic is show here: ' Create the netterpillars Select Case NetterpillarNumber Case 1 objNetterpillars(0) = New Int(Me.Height) Case 2 objNetterpillars(0) = New Int(Me.Height) objNetterpillars(1) = New Int(Me.Height) Case 3 objNetterpillars(0) = New Int(Me.Height)
clsNetterpillar(Int(Me.Width / 2), _ / 2, clsSprite.enDirection.South, False) clsNetterpillar(Int(Me.Width / 3), _ / 2, clsSprite.enDirection.South, False) clsNetterpillar(Int(Me.Width / 3) * 2,_ / 2, clsSprite.enDirection.North, True) clsNetterpillar(Int(Me.Width / 4), _ / 2, clsSprite.enDirection.South, False)
objNetterpillars(1) = New clsNetterpillar(Int(Me.Width / 4) * 2, _ .NET Game Programming with DirectX Int(Me.Height) / 2, 9.0 clsSprite.enDirection.North, True) ISBN:1590590511 by Alexandre Santos Lobão and Ellen objNetterpillars(2) = New clsNetterpillar(Int(Me.Width / 4) * 3, _ Hatton Int(Me.Height) / 2, clsSprite.enDirection.South, True) Apress © 2003 (696 pages) Case 4 The authors of this text show=how it can be to produce objNetterpillars(0) Neweasy clsNetterpillar(Int(Me.Width / 3), _ interesting multimedia games using Managed DirectX 9.0 and Int(Me.Height) / Everett, 3, clsSprite.enDirection.South, False) programming with Visual Basic .NET on the latest objNetterpillars(1) = New clsNetterpillar(Int(Me.Width / 3), _ version of Microsoft's Visual Studio. Int(Me.Height) / 3 * 2, clsSprite.enDirection.East, True) objNetterpillars(2) = New clsNetterpillar(Int(Me.Width / 3) * 2, _ Table of Contents Int(Me.Height) / 3 * 2, clsSprite.enDirection.North, True) .NET Game Programming with DirectX 9.0 objNetterpillars(3) = New clsNetterpillar(Int(Me.Width / 3) * 2, _ Foreword Int(Me.Height) / 3, clsSprite.enDirection.West, True) PrefaceEnd Select Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
To allow us to test the configuration code, we need to add some lines to the Load event and the OK button of - .Netterpillars: Artificial Intelligence and Sprites the configuration screen. Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 2
Chapter 4 - River Tiled Game Scrolling, andcurrent DirectAudio When loading thePla.Net: form, we must set Fields, the controls to the value of each of the objGameEngine Chapter 5 River Pla.Net II: DirectInput and Writing Text to Screen configuration properties: Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
Magic KindergarteN. II: Animation Techniques and Speech API Private -Sub frmConfig_Load(sender As Object, e As System.EventArgs) _ - .Netterpillars II: Multiplayer Games and Directplay Handles MyBase.Load D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to = objGameEngine.Size ChapterupdGameField.SelectedIndex 9 Nonmanaged Code updNetterpillars.Value = objGameEngine.NetterpillarNumber Bonus Chapter Porting .Nettrix to Pocket PC updMushrooms.SelectedIndex = objGameEngine.Mushrooms Appendix A - The State of PC Gaming End Sub Chapter 8
Appendix B - Motivations in Games Appendix C - How Do I Make Games?
In the OK procedure, we'll do the opposite,Games setting the objGameEngine properties to the values set on the Appendix D click - Guidelines for Developing Successful form: Index List of Figures List Sub of Tables cmdOK_Click(sender As System.Object, e As System.EventArgs) _
Handles cmdOK.Click objGameEngine.Size = updGameField.SelectedIndex objGameEngine.NetterpillarNumber = updNetterpillars.Value objGameEngine.Mushrooms = updMushrooms.SelectedIndex End Sub
Everything is now correctly positioned, but we need to show the configuration dialog box at some point in the program, else we won't be able to change the configuration settings. It's time to go back to our Main procedure, and include in it the main window, through which we can change the configuration, start a new game, or exit the game. The window will be the one that was shown as a visual prototype in the project phase, including some lines of code in the Config button to show the configuration screen, as demonstrated in the code that follows. Some code to close the window must also be included on the click event of the Exit button. Sub cmdConfig_Click(sender As System.Object, e As System.EventArgs) _ Handles cmdConfig.Click Dim WinConfig As frmConfig WinConfig = New frmConfig() WinConfig.ShowDialog() WinConfig.Dispose() End Sub
.NET Game Programming with DirectX 9.0
NEW IN .NET
In Visual Basic .NET, we don't have a parameter of the form Show method anymore to say if it ISBN:1590590511 by Alexandre Santos Lobão and Ellen should be shown modally (the form is shown and execution continues after the form is closed) or Hatton modeless (the form is pages) shown and the code continues executing); instead we have a ShowDialog Apress © 2003 (696 method that should be used when we wish to show a form modally. In the preceding sample code, The authors of this text show how easy it can be to produce theWinConfig.Dispose() line using is onlyManaged executed after the interesting multimedia games DirectX 9.0 form and is closed by the user. programming with Visual Basic .NET on Everett, the latest
version of Microsoft'sScreen Visual Studio. Coding for the Introduction
Now is a good time to create an intro screen for our game. Our suggestion is shown in the Figure 2-17, but feel free to use your artistic talent to improve it.
Table of Contents
.NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix Figure D - 2-17: Guidelines The for .Netterpillars Developingsplash Successful screen Games Index List of Figures
TheMain procedure must be changed to reflect the workflow diagram created in the project phase:
List of Tables
Sub main() Dim WinSplash As frmSplash Dim WinGameField As frmGameField ' Create the game engine object objGameEngine = New clsGameEngine(WinGameField.PicGameField.Handle) WinSplash = New frmSplash() Do While WinSplash.ShowDialog() = DialogResult.OK WinGameField = New frmGameField() WinGameField.Show() Application.DoEvents() ' Shows the window immediately objGameEngine.BackgroundImage=WinGameField.PicGameField.Image.Clone Do While Not objGameEngine.GameOver objGameEngine.Render() Application.DoEvents() Loop MsgBox("Game Over ", MsgBoxStyle.Exclamation, ".Netterpillars") WinGameField.Dispose() Loop objGameEngine = Nothing WinSplash.Dispose()
End Sub .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
That's it. We can Hatton now play with different field sizes, number of mushrooms, and netterpillars. But after playing a Apress © 2003 (696 pages) couple of times, we'll soon discover that when we run our game a second time without making any configuration The authors this text so, show how easy it can be to produce changes, our properties don'tofget reset; among other things, we'll start with the last quantity of mushrooms interesting games Managed 9.0field and screen is being created for each (that is, without the ones thatmultimedia were eaten). Andusing worst of all: If DirectX the game programming with Visual Basic .NET on Everett, the latest game, our handleversion (passed to the objGameEngine New method) becomes invalid. of Microsoft's Visual Studio. Since we can't simply move the objGameEngine creation to inside the loop (we'll need it in the configuration screen, and if we re-create the object, the previous configuration will be lost), a solution is to create a new Table of Contents method toProgramming reset the game which can be called just after the program Game Over loop. We can call .NET Game withvariables, DirectX 9.0 this method CreateGameField, and move all the code from the New procedure to it, including the parameter Foreword that receives the window handle. Preface Introduction We have shown these details to clarify a point: A game project, as any other project, will have problems en Chapter 1 -better .Nettrix: andthe Collision Detection the behavior in the coding phase. Nevertheless, there's no route. The theGDI+ project, less unexpected Chapter - .Netterpillars: Artificial Intelligence and Sprites to go back and correct everything if you think that it'll way to 2guarantee immediate success. Don't be ashamed Chapter 3 - game Managed DirectX First Steps: and DirectX vs. GDI+ make your faster, more stable, or Direct3D easier toBasics update with new features. Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Another5 detail that requires extra care isand theWriting code for setting the game field size: When we resize the game Chapter - River Pla.Net II: DirectInput Text to Screen
field, the game field window must be resized accordingly. We must do that in the Load event of the - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow frmGameField window:
Chapter 6 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Sub frmGameField_Load(sender As System.Object, As System.EventArgs)_ D-iNfEcT: Multithreading, Nonrectangular Windows, and eAccess to Chapter 9 Handles MyBase.Load Nonmanaged Code PicGameField.Location = PC New Point(0, 0) Bonus Chapter Porting .Nettrix to Pocket PicGameField.Size = New Size(objGameEngine.Width * clsSprite.IMAGE_SIZE, _ Appendix A - The State of PC Gaming objGameEngine.Height * clsSprite.IMAGE_SIZE) Appendix B - Motivations in Games Me.ClientSize = Games? PicGameField.Size Appendix C - How Do I Make End Sub Appendix D - Guidelines for Developing Successful Games Index List of this Figures With last little adjustment, our code will work. But we don't have code for the game over yet. We'll show that List of Tables next.
Coding for Game Over Looking back at our game proposal, we stated that "the game is over when all the players die (computer or human ones), or when the last mushroom is eaten." Since we have a property stating whether a player is dead or not, and a property that stores the number of mushrooms (that is already reduced every time a mushroom is eaten), all we need to do is include the code in theRender procedure to test the preceding conditions and set the GameOver property to True if one of the requirements is met. Sub Render() Dim i As Integer ' Move the Netterpillars MoveNetterpillars() ' If all Netterpillars die - GameOver GameOver = True For i = 0 To NetterpillarNumber - 1 If Not objNetterpillars(i).IsDead Then GameOver = False End If
Next Game Programming DirectX 9.0 ' If all .NET mushrooms got eatenwith - Game Over ISBN:1590590511 by Alexandre Santos Lobão and Ellen If MushroomNumber = 0 Then Hatton GameOver = True Apress © 2003 (696 pages) End If The authors of this text show how easy it can be to produce End Sub interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
We mustn't forget to remove the code for forcing the game to finish when the Esc key is pressed, on the keyboard event handler for the frmGameField, unless we need this behavior in our finished game. Table of Contents
Although code for the "game over" .NET Game the Programming with DirectX 9.0 works fine, it can be improved if we include a screen with game statistics—such as the netterpillar's size—so players can have clearer information about how well they played. Foreword
Such a screen is added in the "Adding the Final Touches" section; for now, let's alter our code to include a real computer-controlled competitor.
Preface
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Final Version: Coding the Netterpillars AI - .Netterpillars: Artificial Intelligence and Sprites
Chapter 2 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
To finish our game, we need to code the NetterpillarAI class and make the final adjustments in the Main - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio procedure, as shown in the next sections.
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow The Netterpillar AI Class
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay As we decided in the game proposal and in the game project, we only need to use a simple form of artificial intelligence. D-iNfEcT: Just avoid Multithreading, walls and eat Nonrectangular mushrooms if they Windows, are near, and Access that's all. to Chapter 9 Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
Public Class clsAINetterpillar
Appendix A - The State of PC Gaming Inherits clsGameEngine Appendix B - Motivations in Games Appendix C - How Do I Make Games? As Integer = 5 Private RandomPercent Appendix D - Guidelines for Developing Successful Games Function ChooseNetterpillarDirection(CurrentLocation As Point, _ Index CurrentDirection As clsSprite.enDirection) As clsSprite.enDirection List of Figures Function RandomDirection(CurrentLocation As Point, _
ChoosenDirection As clsSprite.enDirection) As clsSprite.enDirection List of Tables End Class
Let's review what the game objects are: Protected Enum enGameObjects Mushroom = 0 Empty = 1 Branch = 2 Netterpillar = 3 End Enum
Not by accident, when we defined this enumeration, did we put the game objects in ascending order of collision preference. When we check the objects around us, the lowest value is the preferred one: A mushroom is better than empty space, and both are preferable to a collision resulting in death. We can use this to our advantage, to ease the choice of the best object by checking the lowest value (with the min function) from the positions around the current position of the netterpillar's head: BestObject = Math.Min(Math.Min(Math.Min(_ arrGameField(CurrentLocation.X + 1, CurrentLocation.Y), _
arrGameField(CurrentLocation.X - 1, CurrentLocation.Y)), _ .NET Game Programming with DirectX 9.0 arrGameField(CurrentLocation.X, CurrentLocation.Y + 1)), _ ISBN:1590590511 by Alexandre Santos Lobão and Ellen arrGameField(CurrentLocation.X, CurrentLocation.Y - 1)) Hatton Apress © 2003 (696 pages)
The authors of chosen, this text we show how easy ititagainst can be to Once the best object has been can check theproduce next object in the current direction; and if interesting multimedia using Managed DirectX 9.0 and they are the same (there can be two orgames more optimal objects), we choose to stay in the current direction, to programming with Visual Basic .NET on Everett, the latest make the netterpillar's movement less erratic. version of Microsoft's Visual Studio.
One last step is to add some random behavior to make the movement less predictable and less prone to getting stuckofinContents an infinite loop; for example, the netterpillar could move in circles around the game field forever if Table there's no aleatory component. In our .NET Game Programming with DirectX 9.0tests, anything greater than 10 percent randomness can lead to erratic behavior (remember, we choose a new direction many times a second); a value between 0 and 5 generates Foreword good results. Preface Introduction
Function ChooseNetterpillarDirection(CurrentLocation As Point, _ Chapter 1 - .Nettrix: GDI+ and Collision Detection CurrentDirection As clsSprite.enDirection) As clsSprite.enDirection - .Netterpillars: Artificial Intelligence and Sprites Dim BestObject As enGameObjects Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Dim NextObject As enGameObjects Chapter 2 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Select Case CurrentDirection Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Case clsSprite.enDirection.East Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API NextObject = arrGameField(CurrentLocation.X + 1, CurrentLocation.Y) Chapter 8 -Case .Netterpillars II: Multiplayer Games and Directplay clsSprite.enDirection.West D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to - 1, CurrentLocation.Y) NextObject = arrGameField(CurrentLocation.X Chapter 9 Nonmanaged Code Case clsSprite.enDirection.South Bonus Chapter Porting .Nettrix to Pocket PC NextObject = arrGameField(CurrentLocation.X, CurrentLocation.Y + 1) Appendix A -Case The State of PC Gaming clsSprite.enDirection.North Appendix B - Motivations in Games NextObject = arrGameField(CurrentLocation.X, CurrentLocation.Y - 1) Appendix C How Do I Make Games? End Select Appendix D - Guidelines for Developing Successful Games Index ' Pick the lowest value - Mushroom or empty List of Figures BestObject = Math.Min(Math.Min(Math.Min(_ List of TablesarrGameField(CurrentLocation.X + 1, CurrentLocation.Y), _
arrGameField(CurrentLocation.X - 1, CurrentLocation.Y)), _ arrGameField(CurrentLocation.X, CurrentLocation.Y + 1)), _ arrGameField(CurrentLocation.X, CurrentLocation.Y - 1)) ' If the current direction is equal the best direction, ' stay in current direction If NextObject = BestObject Then ChooseNetterpillarDirection = CurrentDirection Else ' Select the direction of the best object Select Case BestObject Case arrGameField(CurrentLocation.X + 1, CurrentLocation.Y) ChooseNetterpillarDirection = clsSprite.enDirection.East Case arrGameField(CurrentLocation.X - 1, CurrentLocation.Y) ChooseNetterpillarDirection = clsSprite.enDirection.West Case arrGameField(CurrentLocation.X, CurrentLocation.Y + 1) ChooseNetterpillarDirection = clsSprite.enDirection.South Case arrGameField(CurrentLocation.X, CurrentLocation.Y - 1) ChooseNetterpillarDirection = clsSprite.enDirection.North End Select End If
ChooseNetterpillarDirection = RandomDirection(CurrentLocation, _ .NET Game Programming with DirectX 9.0 ChooseNetterpillarDirection) ISBN:1590590511 by Alexandre Santos Lobão and Ellen End Function Hatton Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce interesting multimedia games using DirectX 9.0 and To code the RandomDirection method, called in Managed the last line of the preceding code, we'll simply pick a programming with Visual Basic .NET on Everett, the latest random number from 0 to 100, and if it's less than the RandomPercent property, choose a new movement version of Microsoft's Visual Studio. direction for the netterpillar. The next code sample presents the full code for this method: Table of Contents Function RandomDirection(CurrentLocation As Point, ChoosenDirection _ .NET Game Programming with DirectX 9.0 As clsSprite.enDirection) As clsSprite.enDirection Foreword Dim x As Integer = Rnd(1) * 100 Preface Introduction RandomDirection = ChoosenDirection ChapterIf 1 x- .Nettrix: < RandomPercent GDI+ and Collision Then Detection Chapter 2
CaseArtificial ChoosenDirection -Select .Netterpillars: Intelligence and Sprites
Chapter 3
Case DirectX clsSprite.enDirection.East - Managed First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
' Try directions - River Pla.Net: Tiled the Gameother Fields, Scrolling, and DirectAudio
Chapter 5
If II: arrGameField(CurrentLocation.X, CurrentLocation.Y + 1) <= _ - River Pla.Net DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow enGameObjects.Empty Then
RandomDirection = clsSprite.enDirection.South ElseIf arrGameField(CurrentLocation.X, CurrentLocation.Y - 1) <= _ Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay enGameObjects.Empty Then D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 RandomDirection = clsSprite.enDirection.North Nonmanaged Code ElseIf arrGameField(CurrentLocation.X - 1, CurrentLocation.Y) <= _ Bonus Chapter Porting .Nettrix to Pocket PC enGameObjects.Empty Then Appendix A - The State of PC Gaming RandomDirection = clsSprite.enDirection.West Appendix B - Motivations in Games End If Appendix C - How Do I Make Games? Case clsSprite.enDirection.West Appendix D - Guidelines for Developing Successful Games ' Try the other directions Index If arrGameField(CurrentLocation.X, CurrentLocation.Y + 1) <= _ List of Figures enGameObjects.Empty Then List of Tables RandomDirection = clsSprite.enDirection.South ElseIf arrGameField(CurrentLocation.X, CurrentLocation.Y - 1) <= _ enGameObjects.Empty Then RandomDirection = clsSprite.enDirection.North ElseIf arrGameField(CurrentLocation.X + 1, CurrentLocation.Y) <= _ enGameObjects.Empty Then RandomDirection = clsSprite.enDirection.East End If Case clsSprite.enDirection.North ' Try the other directions If arrGameField(CurrentLocation.X, CurrentLocation.Y + 1) <=_ enGameObjects.Empty Then RandomDirection = clsSprite.enDirection.South ElseIf arrGameField(CurrentLocation.X + 1, CurrentLocation.Y) <= _ enGameObjects.Empty Then RandomDirection = clsSprite.enDirection.East ElseIf arrGameField(CurrentLocation.X - 1, CurrentLocation.Y) <=_ enGameObjects.Empty Then RandomDirection = clsSprite.enDirection.West End If Case clsSprite.enDirection.South ' Try the other directions If arrGameField(CurrentLocation.X, CurrentLocation.Y - 1) <= _ Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
enGameObjects.Empty Then .NET Game Programming with DirectX 9.0 RandomDirection = clsSprite.enDirection.North ISBN:1590590511 by Alexandre Lobão and Ellen ElseIf Santos arrGameField(CurrentLocation.X + 1, CurrentLocation.Y) <= _ Hatton enGameObjects.Empty Then Apress © 2003 (696 pages)
RandomDirection = clsSprite.enDirection.East
The ElseIf authors ofarrGameField(CurrentLocation.X this text show how easy it can be to produce- 1, CurrentLocation.Y) <= _ interesting multimedia games using Managed DirectX 9.0 and enGameObjects.Empty Then programming with Visual Basic .NET on Everett, the latest RandomDirection = clsSprite.enDirection.West version of Microsoft's Visual Studio.
End If End Select Table of Contents End If .NET Game Programming with DirectX 9.0 End Function Foreword Preface
Since the code in the clsGameEngine is intended to take care of the game's physics (for example, it moves Introduction the netterpillars, regardless of Collision whether Detection one is changing direction), we'll have to put the code for moving the Chapter 1 - .Nettrix: GDI+ and netterpillars based on the AI outside the game engine object; our Main procedure is the best option. - .Netterpillars: Artificial Intelligence and Sprites
Chapter 2
Chapter - Managed DirectX First Direct3D DirectX vs. GDI+ Another3 valid approach would be Steps: to include the AIBasics codeand inside the Netterpillar object—it's just a matter of Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio choice: a small number of bigger classes or many smaller ones. Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 - Magic KindergarteN.: The Main Program: Final Adventure VersionGames, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API In order8 to-call the AI code, create aGames new procedure, which will be called from the game main loop. The Chapter .Netterpillars II: we Multiplayer and Directplay
procedure, shown in the following code, just loops through theand Netterpillars objects and, if they aren't D-iNfEcT: Multithreading, Nonrectangular Windows, Access to dead and if- they are computer controlled, sets the current direction to the result of the Nonmanaged Code ChooseNetterpillarDirection method. Bonus Chapter Porting .Nettrix to Pocket PC Chapter 9
Appendix A - The State of PC Gaming Appendix Private B -objAINetterpillar Motivations in Games As New clsAINetterpillar()
Sub MoveComputerCharacters() Appendix C - How Do I Make Games? Dim As Integer Appendix D -iGuidelines for Developing Successful Games Index
' Move the Netterpillars List of Figures For i = 0 To objGameEngine.NetterpillarNumber - 1 List of Tables If Not objGameEngine.objNetterpillars(i).IsDead Then ' A.I. for the computer-controled Netterpillars If objGameEngine.objNetterpillars(i).IsComputer Then objGameEngine.objNetterpillars(i).Direction = _ objAINetterpillar.ChooseNetterpillarDirection(_ objGameEngine.objNetterpillars(i).Location, _ objGameEngine.objNetterpillars(i).Direction) End If End If Next End Sub
The main program loop should include one more section to call the MoveComputerCharacters procedure. Do While Not objGameEngine.GameOver MoveComputerCharacters() objGameEngine.Render() Application.DoEvents() Loop
This finishes our coding phase; some code to add polish to the final product is suggested in the next section.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Adding the .NET Final Touches by Alexandre Santos Lobão and Ellen
ISBN:1590590511
In this section weHatton add some extra features to our game. These final touches, although simple, are important and Apress © 2003 (696 pages) need to be considered. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Coding the Pause Game Feature
As in the .Nettrix game, we could insert code to pause (and restart) the game when the Esc key is pressed. This basic improvement is shown here: Table of Contents .NET Game Programming with DirectX 9.0 Private Sub frmGameField_KeyDown(sender As Object, _ Foreword Preface
e As System.Windows.Forms.KeyEventArgs) Handles MyBase.KeyDown
Introduction . . . Chapter 1 -Case .Nettrix: GDI+ and Collision Detection Keys.Escape Chapter 2
- .Netterpillars: objGameEngine.Paused Artificial Intelligence and = Not Sprites objGameEngine.Paused
Chapter 3
If objGameEngine.Paused Thenand DirectX vs. GDI+ - Managed DirectX First Steps: Direct3D Basics
Chapter 4
Me.Text = ".Netterpillars - Press ESC to continue" - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- RiverElse Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
Me.Text Adventure = ".Netterpillars" - Magic KindergarteN.: Games, ADO.NET, and DirectShow
If - MagicEnd KindergarteN. II: Animation Techniques and Speech API End Select Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Sub Chapter 7
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
Improving the Game Over Screen
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Our game alsoGames? needs an improvement. A good game programmer should not forget that a good Appendix C -over Howroutine Do I Make game ending is far more a nice intro screen. Players must be rewarded for all their efforts in Appendix D - Guidelines for important Developingthat Successful Games completing the game; it's very frustrating for players to spend days and days finishing a game and not getting Index
anything in return to give them a feeling of accomplishment. In our game, the "Game Over" message box is one of these frustrations. Although a high scores table would be better, let's at least give players some feedback List of Tables about the results of the game and how well they played. List of Figures
We can do this by creating a new Game Over window, where we can display some game statistics, as shown in Figure 2-18.
Figure 2-18: A Game Over screen
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
This screen can access Hatton the objGameEngine, which is a public variable, and gather information about players Apress © 2003 (696 pages) and how long their netterpillars were when the game finished. The authors of this text show how easy it can be to produce
To load the labelinteresting with the statistics, we games must access each of the objNetterpillars objects, checking the multimedia using Managed DirectX 9.0 and IsComputer property programming and thewith NetterBodyLength Visual Basic .NET onproperty. Everett, the We'll latest need to avoid unset objects (remember, the versionwith of Microsoft's Visual Studio. player could be playing any number of opponents, from 0 to 3). TheIIF commands in the next code sample (which must be placed on the Load event of the window) aren't new to .NET, although they aren't commonly used because sometimes they can lead to more complex code. .NET Programming 9.0 TheGame IIF command testswith the DirectX first parameter (an expression) and, if true, returns the second parameter; otherwise Foreword it returns the last parameter.
Table of Contents
Preface Introduction
LblPlayer1Length.Text= _
Chapter 1 objGameEngine.objNetterpillars(0).NetterBodyLength - .Nettrix: GDI+ and Collision Detection Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites LblPlayer1Is.Text= _ Chapter 3 IIf(objGameEngine.objNetterpillars(0).IsComputer, - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ "Computer", "Human") Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5 objGameEngine.objNetterpillars(1) - River Pla.Net II: DirectInput and Writing Text toIs Screen If Not Nothing Then ChapterLblPlayer2Length.Text 6 - Magic KindergarteN.: Adventure = _ Games, ADO.NET, and DirectShow Chapter 7 objGameEngine.objNetterpillars(1).NetterBodyLength - Magic KindergarteN. II: Animation Techniques and Speech API
= _ ChapterLblPlayer2Is.Text 8 - .Netterpillars II: Multiplayer Games and Directplay Chapter 9
Else
IIf(objGameEngine.objNetterpillars(1).IsComputer, "Computer", "Human") D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to -
Nonmanaged Code
LblPlayer2Length.Text = PC "-" Bonus Chapter Porting .Nettrix to Pocket LblPlayer2Is.Text = "-" Appendix A - The State of PC Gaming End IfB - Motivations in Games Appendix If NotC objGameEngine.objNetterpillars(2) Is Nothing Then Appendix - How Do I Make Games? LblPlayer3Length.Text _ Appendix D - Guidelines for Developing=Successful Games objGameEngine.objNetterpillars(2).NetterBodyLength LblPlayer3Is.Text = _ List of Figures IIf(objGameEngine.objNetterpillars(2).IsComputer, "Computer", "Human") List of Tables Else LblPlayer3Length.Text = "-" LblPlayer3Is.Text = "-" End If Index
If Not objGameEngine.objNetterpillars(3) Is Nothing Then LblPlayer4Length.Text=_ objGameEngine.objNetterpillars(3).NetterBodyLength LblPlayer4Is.Text= _ IIf(objGameEngine.objNetterpillars(3).IsComputer, "Computer", "Human") Else LblPlayer4Length.Text = "-" LblPlayer4Is.Text = "-" End If
In final version of the main program, we must replace the "Game Over" message box by a call to the ShowDialog method of the game over form.
Coding for the Garbage Collection A technical enhancement is to improve the speed of the garbage collection calling the Collect method of the System.GC object, in the end of the Render method, as shown:
.NET Game Programming with DirectX 9.0
Sub Render() by Alexandre Santos Lobão and Ellen ... Hatton System.GC.Collect() Apress © 2003 (696 pages) End Sub
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
NEW The .NET Framework provides an advanced garbage collector that frees the memory from all IN objects left behind by the program. The garbage collection takes place in idle system time, but we Table .NET of Contents can force it to run by calling the Collect method, which is good practice if we are dealing with lots .NET Game Programming DirectXand 9.0 reallocations—which we do, for example, with the Graphics object in of memory with allocations Foreword each Draw method in the game objects. Preface Introduction
Further- .Nettrix: Improvements GDI+ and Collision Detection
Chapter 1
Chapter 2 -the .Netterpillars: Artificial Intelligence andnew Sprites We saved best for last: What about creating intelligent characters for our game, maybe some Chapter 3 Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ opposition—like a spider who eats the netterpillars? Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio In the code for this chapter the samples CD-ROM, will find an almost fully working spider character. We Chapter 5 - River Pla.Net II: on DirectInput and Writing Textyou to Screen
already6did- all theKindergarteN.: dirty work: theAdventure Spider and AISpider class Chapter Magic Games, ADO.NET, andinterfaces, DirectShowthe call to the moving functions at the
MoveComputerCharacters routine and at the Render and Redraw method of the objGameEngine—almost - Magic KindergarteN. II: Animation Techniques and Speech API everything is there. The code for ChooseDirection method of the AISpider class is empty, so our spiders Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay aren't going anywhere. This gives you the opportunity to create the AI from scratch, without worrying about the D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter - the spider attack the netterpillars heads and kill them? Or will they just eat part of their tails? Or, details.9Will Nonmanaged Code maybe make Porting new mushrooms Bonus Chapter .Nettrix to grow? Pocket Start PC making your proposal for the second version of the game, and enjoy! Chapter 7
Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Summary
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
In this chapter, viaHatton the .Netterpillars game sample, we explored some additional concepts related to game Apress © 2003 (696 pages) programming, including The authors of this text show how easy it can be to produce
Basic concepts about object-oriented programming and DirectX analysis9.0 and interesting multimedia games using Managed programming with Visual Basic .NET on Everett, the latest
Basic concepts version about ofartificial Microsoft's intelligence, Visual Studio. and ideas about how to implement it to solve different challenges when programming games Table of Contents The difference between game AI and game physics .NET Game Programming with DirectX 9.0
How to create a basic objects library and use its derived classes in games Foreword Preface
How to produce high-performance drawings with GDI+, when we need to draw images with transparent colors
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter How 2 to - .Netterpillars: create computer-controlled Artificial Intelligence characters and Sprites that interact with the game engine like player-
controlled characters, with the sameDirect3D physics Basics restrictions Chapter 3 - Managed DirectX First Steps: and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
In the next chapter, we'll introduce the use of DirectX graphics with a sample program that will test many - River Pla.Net II: DirectInput and Writing Text to Screen of the basic features of Direct3D, so we can in later chapters use these concepts in our games.
Chapter 5 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Chapter .NET 3: Managed DirectX First Steps: Direct3D ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Basics and DirectX vs. GDI+ Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce
Highlights interesting multimedia games using Managed DirectX 9.0 and
programming with Visual Basic .NET on Everett, the latest version Visual Studio. In this chapter we'll followofaMicrosoft's different approach from all the other ones: There'll be no sample game, and
we'll instead concentrate on understanding the basic features of DirectX (particularly Direct3D) and how to go through its initialization routines, creating a sample application that will exemplify each of these Table of Contents features. .NET Game Programming with DirectX 9.0
Foreword Our sample application, as we'll see in the section "The Application Proposal," will comprise a main Preface window, which will display our 3-D board capabilities, and a set of separate windows that will test a specific Introduction feature each, like use of lights, 3-D transformations, and full-screen drawings. In each of these test Chapter 1 we'll - .Nettrix: GDI+ and Collision Detection of a walking man, shown in Figure 3-1, providing the windows present sequentially the drawings Chapter illusion2of movement. - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
Figure 3-1: The walking man, presented as this chapter's sample
Appendix A - The State of PC Gaming
Appendix B -a Motivations in Games DirectX is set of libraries and components that allow the programmer to access hardware features (such Appendix C How Do I Make as 3-D acceleration boardsGames? and advanced sound systems) using the same interface, disregarding the Appendix D - Guidelines fortaking Developing Successful Games device details, while still advantage of each hardware-specific feature to enhance the multimedia Index operation speed. List of Figures
The latest version of DirectX can be downloaded from http://www.microsoft.com/directx; this download includes the DirectX APIs, the managed DirectX interfaces (used to provide access to DirectX from .NET languages), the DirectX Software Development Kit (SDK), a comprehensive set of samples, and detailed documentation about all DirectX features.
List of Tables
In the next section we'll present an overview of DirectX, which will give us enough information to go on exploring Direct3D features in the later sections.
.NET Game Programming with DirectX 9.0 DirectX Overview by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton In this section we'll discuss some common terms used in the DirectX world and see how they fit together to Apress ©for 2003 (696 pages) provide us a framework building great games. The authors of this text show how easy it can be to produce
First of all, those interesting who already know previous (7 or earlier) DirectX multimedia gamesversions using Managed DirectXof9.0 and need to be aware that since programming with Visual Basic .NETgames. on Everett, latestthere is no capability for screen flipping DirectX 8 we no longer have direct support for 2-D Thatthe means version of Microsoft's Studio. and no bitmap blitting directly on videoVisual memory. We don't have the DirectDraw interface anymore, which was very comfortable to those who programmed DOS games, because it used much of a familiar, basic philosophy: Create one or more screen back buffers, draw in a back buffer, move the back buffer to video memory—in Table of Contents other words, make it visible to the player—and then start drawing in the next buffer (usually, we simply "flip" the .NET Game Programming with DirectX 9.0 buffers, moving memory pointers). Foreword
Preface In fact, the DirectDraw interface is still there, but it's for now just a backward-compatibility feature, so the old Introduction programs that use this library will still work. It's better for us not to rely on the older interface because no one Chapter .Nettrix: GDI+inand Detection knows 1if it -will be present theCollision next versions. Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites The good is that, whileFirst we need toDirect3D expend aBasics little more effort in than in DirectDraw, we can rely Chapter 3 -news Managed DirectX Steps: and DirectX vs.Direct3D GDI+
on the hardware acceleration capabilities to do most of the dirty work for us, reaching incredible speeds that - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio would not be possible with DirectDraw.
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 - Magicacceleration KindergarteN.: ADO.NET,we and DirectShow Using hardware is aAdventure wonderfulGames, thing, because can go from dozens of frames to hundreds of Chapter - Magic Animation Techniques Speech API easily reach three hundred frames per frames7drawn perKindergarteN. second. In ourII:tests in this chapter, theand basic samples Chapter 8 and - .Netterpillars II: Multiplayer Games and Directplay second, can go to almost a thousand depending on the hardware capabilities. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Of course, there's Nonmanaged a priceCode to pay. Even the simplest games must go through some complex routines, and we'll
have Chapter to learn Porting some new concepts, even Bonus .Nettrix to Pocket PC if we don't want to take full advantage of the hardware acceleration features.A - The State of PC Gaming Appendix Appendix B - Motivations in Games
When we manage to understand these initialization routines and the basic concepts, we can use the Direct3D interface to create our 2-D games without even worrying about depth buffers or vertex blending.
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games
Index Let's start with an overview of the main concepts used by DirectX and how they are related. List of Figures List of Tables
Presenting the DirectX Top-Level Objects When programming DirectX 9.0 or earlier with nonmanaged (pre-.NET) languages, we have to create a master object of type DirectXn (where n is the main number of the DirectX version, for instance, DirectX8 for the 8.1 version), and everything can be created from this object. In the managed version of DirectX 9.0, we can directly create the second-level objects, as listed here: Direct3D for access to the 3-D acceleration layer. Direct3DX for access to utility functions to make coding easier (such as matrix multiplication functions). DirectDraw for compatibility with older programs, although there are no new features for this component. It's mainly used to create 2-D games, because it allows access to a hardware blittler (hardware acceleration to allow fast transfer of large memory blocks) and creation on drawing surfaces easily. DirectInput for controlling any input devices, including newer ones, like joysticks with force feedback. DirectPlay for creating multiplayer games, creating fast and reliable data transmission across computers. It's based mainly in TCP sockets, but has some game-related extra features. DirectAudio for manipulating and playing all kinds of sounds. It includes the DirectSound and DirectMusic interfaces from previous releases, and, in fact, it's not a new interface, just a new way to call the other two when used together. Although both DirectSound and DirectMusic are present in DirectX 9.0, only DirectSound has a managed interface.
DirectShow .NET for video and audio playback or capture. In DirectX 9.0, we have only a simple playback Game Programming with DirectX 9.0 feature in DirectShow; if we need to use advanced streaming manipulation features, we have to use the ISBN:1590590511 by Alexandre Santos Lobão and Ellen nonmanagedHatton version. Apress © 2003 (696 pages)
DirectSetupThe for access to the setup API of DirectX, which can help with creating distribution packages for authors of this text show how easy it can be to produce DirectX-based applications. interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
In this chapter we'll concentrate in the Visual first object listed, Direct3D, and learn some helper functions from version of Microsoft's Studio. Direct3DX. In upcoming chapters, we'll examine the other objects one by one, with the exception of the outdated DirectDraw and the DirectSetup interface.
Table of Contents
.NET Game Programming with DirectX 9.0
Understanding Adapters
Foreword Preface
This section relates directly to video hardware. DirectX provides some functions that allow us to list all display
Introduction adapters and gather some information about them. Chapter 1 - .Nettrix: GDI+ and Collision Detection
We don't any direct operations over an adapter; the functions are here just for informational purposes, or to Chapter 2 do - .Netterpillars: Artificial Intelligence and Sprites allow us adapters when we have more onevs. acceleration board. Chapter 3 to- choose Managedbetween DirectX First Steps: Direct3D Basics andthan DirectX GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Usually we'll have only one adapter (the default), but with machines with secondary adapters (such as 3-D-only - River Pla.Net II: DirectInput and Writing Text to Screen boards), we can use the adapter identifier (a sequential number) to switch from one adapter to another.
Chapter 5 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 -the Magic KindergarteN. II: Animation Techniques and code Speech API To gather adapter information, we can use the following sample: Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Dim - AdapterInfo As AdapterDetail Nonmanaged Code
Dim i As Integer
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A For - TheiState PC Gaming = 0of To Manager.Adapters.Count - 1 Appendix B - Motivations in Games AdapterInfo = Manager.Adapters(i).Information Appendix C - How Do messageBox.show I Make Games? (AdapterInfo.Description, "Current Adapters") Appendix D Next - Guidelines for Developing Successful Games i Index List of Figures
In managed List of Tables DirectX, many of the methods were reengineered to provide a more intuitive interface. For
example, many Get methods were replaced by properties, such as the Adapters.Count property in the preceding code, which replaced the previous GetAdapterCount property. Some functions that return values as parameters were also rewritten to return values as the result of the function. There's also a new object, the Manager, presented in the previous code sample, that handle basic interactions with Direct3D. This kind of modifications made the code cleaner for the managed version of DirectX. The code listing uses the Adapters.Count property to run across the adapters and gather the description of each one. Although Description can vary for the same device and driver when dealing with different vendors, it's the only human-readable information, along with the DriverName property of the AdapterDetail structure. The other members of this structure are numeric values that identify the driver version, revision, and other internal control numbers, and won't be of interest to us (refer to DirectX SDK help for further information).
Understanding Devices DirectX offers a special object type, Device, which allows us to have access to the 3-D acceleration layer. We can choose up to three types of devices for each adapter: Hardware (Hardware Abstraction Layer): When creating HAL devices, we have direct access to the hardware acceleration features (and increased speed). If we try to create a device of this type but have no 3-D acceleration board, DirectX will raise an error and won't create the device. Reference (Reference Rasterizer): This type of device, included in the DirectX SDK, provides most of the
features available for the DirectX functions, and doesn't depend on any hardware support—everything is .NET Game Programming with DirectX 9.0 made by software. Although this type of device is very flexible, it's very slow, and must only be used for ISBN:1590590511 by Alexandre Santos Lobão and Ellen debugging purposes, because it allows us to test many features not supported by our hardware. Don't even Hatton think about creating a game with it, as the frame rate is very low—between 1 and 5 frames per second, Apress © 2003 (696 pages) usually. The authors of this text show how easy it can be to produce
interestingDevice): multimedia using Managed DirectX 9.0 and Software (Software Notgames used, unless you need plug-in support for creating a custom renderer. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
When creating a device, we must specify the adapter being used (usually the default, defined as "0" [zero]), the type of the device as described in the preceding list, the handle of the window that will be used as a viewport, and of twoContents other parameters that will define the details about the device creation, the behavior flags and the Table presentation parameters, asDirectX shown 9.0 in the next code sample: .NET Game Programming with Foreword
objDirect3DDevice = New Device(Manager.Adapters.Default.Adapter, _ Preface Introduction DeviceType.hardware, WinHandle, CreateFlags.SoftwareVertexProcessing, _ Chapter 1
-objDirect3Dpp) .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ The behavior flags must be one of the following flags defined by the CreateFlags enumeration:
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter SoftwareVertexProcessing: 5 - River Pla.Net II: DirectInput The and Writing most common Text to Screen option, it tells DirectX that all vertex calculations will Chapter be 6made - Magic by software. KindergarteN.: This option Adventure is theGames, slowest, ADO.NET, but is always and DirectShow available. Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
HardwareVertexProcessing: This option forces DirectX to rely on hardware capabilities to make all the - .Netterpillars II: Multiplayer Games and Directplay vertex-processing operations, leaving extended operations (like shading and lighting) for the software layer. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 hardware If the is notCode able to perform the vertices calculation, the creation of the device will fail. Nonmanaged Chapter 8
Bonus Chapter Porting .Nettrix to Pocket PC
MixedVertexProcessing: As the constant name states, this uses a mix of available hardware features and software-implemented ones to achieve the best results. If the hardware offers no vertex-processing Appendix B - Motivations in Games features, this call will fail, too. Appendix A - The State of PC Gaming
Appendix C - How Do I Make Games?
These flags are mutually exclusive, but they canGames be combined with the following flags to pass additional Appendix D - Guidelines for Developing Successful information to DirectX when creating a device: Index List of Figures
FPU_Preserve: This flag informs DirectX to perform all the calculations using double-precision floating points, which can lead to slower performance.
List of Tables
MultiThreaded: Use this flag to inform DirectX that you need a multithread safe environment. In order to control the critical sections, DirectX can lose performance, so you must use this flag only when needed. PureDevice: This flag is used only in combination with the HardwareVertexProcessing flag, and specifies that the hardware can do rasterization, matrix transformations, and lighting and shading calculations. It's the best choice for any application, but few boards offer these features. The last parameter for creating a device, the Presentation Parameters, is a complex structure whereby the programmer can define many low-level details about the device being created. We'll present here the most commonly used attributes. For a full list refer to the DirectX SDK help feature. EnableAutoDepthStencil and AutoDepthStencilFormat: These structure members tell DirectX that you want to use a depth buffer, and which is the format to be used in such buffer (according to the Format enumeration), respectively. The depth buffer helps with defining the relative distance of the object in relation to the screen, which is used to draw nearby objects in front of far ones. Although this seems to be a concept exclusive to the 3-D gaming world, it's not entirely true: Even some very basic 2-D games have socalled layers—usually the background and any objects that must appear behind the player (such as trees or bushes) stay in a back layer, and the player and other objects stay in the front layers. After creating the device, the program must set the ZBufferEnable member of the device's RenderState component to enable the depth buffering. BackBufferCount,BackBufferFormat,BackBufferWidth, and BackBufferHeight: These
members define the number of back buffers (from 1 to 3), the format of such buffers (defined by the .NET Gameand Programming with DirectX Format enumeration), their width and height. The9.0 back buffer format (as with the depth stencil buffer) ISBN:1590590511 by Alexandre Santos Lobão and Ellen must be valid, one that can be checked by the CheckDeviceType method of the Direct3D object. If the Hatton buffer cannot be created (at least one is required), the creation of the Device will fail. The back buffers are Apress © 2003 (696 pages) used to render the scene being draw in the background automatically, in order to allow a smooth transition The authors of this text show how easy it can be to produce between frames drawn (no partial drawing is shown to the player). This parameter is closely related to the interesting multimedia games using Managed DirectX 9.0 and SwapEffect attribute, which tell Basic DirectX how swap the back buffers to the screen, and to the programming withwill Visual .NET on to Everett, the latest Windowed attribute, which will force some limitations to the possible values. version of Microsoft's Visual Studio. SwapEffect: A constant of the SwapEffect enumeration that defines the behavior of the buffers swap Table of Contents operation. This enumeration includes the following options: .NET Game Programming with DirectX 9.0 Foreword Preface
SwapEffect.Discard: The back buffers content isn't preserved in the swap operation, allowing the application to choose the best performing technique, sometimes leading to big performance gains in the swapping operation. However, the scene must be completely redrawn for each frame.
Introduction
Chapter 1 SwapEffect.Flip: - .Nettrix: GDI+ and Collision CreatesDetection a circular list of buffers to be swapped to screen (called a swap chain), Chapter 2 allowing - .Netterpillars: Artificial Intelligence and refresh Sprites rate in a smooth way when running full screen. The synchronization with the video Chapter 3 "flip" - Managed DirectXthat Firstwe Steps: DirectX vs. GDI+ term means haveDirect3D no copy Basics of the and memory block—DirectX just repositions the video Chapter 4 memory - River Pla.Net: Tiled Game Scrolling, andrunning DirectAudio start pointer to the Fields, next buffer. When in windowed mode, there's no real flip; the Chapter 5 video - River memory Pla.Net gets II: DirectInput copied to the and window, Writing Text which to is Screen an operation with slower performance. In this
the front buffer becomes one of the backand buffers, so the game can rely on this to redraw Chapter 6 operation, - Magic KindergarteN.: Adventure Games, ADO.NET, DirectShow partKindergarteN. of the scene.II: Animation Techniques and Speech API Chapter 7 only - Magic Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
SwapEffect.Copy: This setting preserves the contents of the back buffer, just copying it over the D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 front buffer (the screen). This setting forces BackBufferCount to be set to 1, since there's no need Nonmanaged Code to more buffers. This is the most simple of the buffer swap operations, although it's the one with the Bonus Chapter Porting .Nettrix to Pocket PC worst performance. The most important gain for the programmer is that the application is not forced to Appendix A - The State of PC Gaming perform complex control operations over multiple back buffers. Appendix B - Motivations in Games
Appendix C - How Do I Make Games? Windowed: When set to True, indicates that the application will run in a window; a setting of False Appendix D - Guidelines for Developing Successful indicates the application will run full screen.Games When running in windowed mode, BackBufferFormat must Index match the current display resolution, and BackBufferWidth and BackBufferHeight may not be List ofspecified, Figures assuming the window client area dimensions. When running in full screen, the width and height of
back buffer must match one of the possible display modes (explained in the next section) for the device. List ofthe Tables DeviceWindowHandle: The handle of the window to be used by DirectX. If it's set to Nothing, DirectX will use the active window.
Understanding Display Modes While the term adapter refers to the hardware and its driver and the term device refers to the main object used to access a specific window and draw over it, we use the term display modes to define the objects (the DisplayMode class) that store basic information about the screen status, including width, height, refresh rate, and a format flag that returns extra information about how colors are controlled by the display. The formats for rendering displays are as follows: A8R8G8B8: Color format in which each pixel on screen is defined using a 32-bit ARGB value—255 possible values for each red, green, and blue (RGB) color component, and an extra alpha (A) value that defines the transparency of each pixel (255 is fully opaque and is 0 is totally transparent). X8R8G8B8: Color format with 32-bit RGB values, and an extra byte (indicated by the "X") for color definition, not used. As with the previous setting, this color format allows up to 16 million colors. R5G6B5: Color format using 16 bits, where each RGB color component can assume 32 different values; an extra bit for green make this show 64 possible values, reaching a total of about 64 thousand colors. X1R5G5B5: 16-bit color format in which each color component takes 5 bits (32 possible values), making a
total of a little more than 32 thousand colors.
.NET Game Programming with DirectX 9.0
ISBN:1590590511 by Alexandre Santos and When choosing the display mode for Lobão games, it'sEllen important to balance the number of desired colors against the Hatton them. The 32-bit format spends almost twice as much time to display the same memory used to display © 2003the (696copy pages)swap modes than do the 16-bit formats. However, the 32-bit format number of pixels Apress when using The authors of this textmay show easy with it can be to produce enables a huge number colors, which behow needed games that have more sophisticated artwork. The interesting games using Managed DirectX 9.0 and rule of thumb is always use multimedia 16-bit format, unless you need more colors, so you'll get the best performance.
programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Note When running in windowed mode, we must use the computer's current resolution and color depth, so this discussion does apply only to full-screen modes. Table of Contents
Creating a Simple Direct3D Program
.NET Game Programming with DirectX 9.0 Foreword
Now that we understand the basic concepts involved in a DirectX (specifically Direct3D) program, let's put it all Preface together and see the basic structure for a Direct3D program. This basic structure will always be the same, even Introduction for the 1most sophisticated programs. Chapter - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites All the drawing operations on Direct3D are made with the use of a Device object, and must occur between the
Chapter Managed DirectX First Steps: Direct3D Basics and methods DirectX vs. GDI+ lock the back buffer we use while calls of3the- BeginScene and EndScene methods. These internally Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio rendering and unlock it when we finish. Calling the Present method of the Device object, after ending the Chapter River Pla.Net II: DirectInput and Writing Screen scene, 5will-display the contents of the back buffer toText theto screen (front buffer), according to the behavior Chapter 6 - Magic KindergarteN.: Adventure parameters set when creating the device. Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
The basic for a II: Direct3D program is and shown in the following pseudocode: Chapter 8 -structure .Netterpillars Multiplayer Games Directplay Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Nonmanaged Codeparameters for the device to be created Set the presentation Bonus Chapter .Nettrix to Pocket PC Create thePorting Device object Appendix - The of PC Gaming RepeatA in a State loop, until Game Over Appendix B - Motivations Clear in Games the Device Begin Scene Appendix C - How Do I Make the Games? Draw the Scene (render) Appendix D - Guidelines for Developing Successful Games End the Scene Index Present the Scene to the user List of Figures Dispose the Device object List of Tables
This will map to the following code: Dim ObjDirect3DDevice As Device Dim DispMode As DisplayMode Dim ObjDirect3Dpp As PresentParameters ' Get the current display mode - when running in windowed mode, it's a must DispMode = Manager.Adapters( _ Manager.Adapters.Default.Adapter).CurrentDisplayMode ' Set the presentation parameters to run in windowed mode ObjDirect3Dpp = New PresentParameters() ObjDirect3Dpp.Windowed = True ObjDirect3Dpp.SwapEffect = SwapEffect.Discard ObjDirect3Dpp.BackBufferFormat = DispMode.Format ' Create the Device - frmDX is a previously created window objDirect3DDevice = New Device(Manager.Adapters.Default.Adapter, _ DeviceType.hardware, frmDX.Handle, CreateFlags.SoftwareVertexProcessing, _ ObjDirect3Dpp) ' The rendering loop - GameOver is set in the Render procedure when the game ends
Do While Not GameOver .NET the Gamedevice, Programming with DirectX 9.0 black ' Clear painting it with ISBN:1590590511 by Alexandre Santos Lobão and Ellen ObjDirect3DDevice.Clear(ClearFlags.Target, _ Hatton Color.FromArgb(0, 0, 255), 1.0F, 0) Apress © 2003 (696 pages) ' Start the Scene The authors of this text show how easy it can be to produce ObjDirect3DDevice.BeginScene() interesting multimedia games using Managed DirectX 9.0 and ' Render is our drawing procedure programming with Visual Basic .NET on Everett, the latest Render() version of Microsoft's Visual Studio. ' End the Scene ObjDirect3DDevice.EndScene() Table of Contents ' Shows the scene drawn in the screen .NET Game Programming with DirectX 9.0 ObjDirect3DDevice.Present() Foreword ' We must give the application some time to process its events Preface Application.DoEvents() Introduction Loop ' Clean-up the GDI+ house Chapter 1 - .Nettrix: and Collision Detection DispMode = Nothing Artificial Intelligence and Sprites Chapter 2 - .Netterpillars: ObjDirect3Dpp Nothing Chapter 3 - Managed= DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ ObjDirect3DDevice.Dispose() Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio ObjDirect3DDevice = Nothing Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API That's it. Of course, some mode details are not presented here, the most important one being the error
Chapter 8 For - .Netterpillars Gamessequence and Directplay trapping. instance, inII: theMultiplayer scene drawing we have three related methods—Begin,End, and D-iNfEcT: Multithreading, Nonrectangular to will fail, too. But we'll see the Present—that must be executed as a whole; if oneWindows, of them and fails,Access the others Chapter 9 Nonmanaged Code
details in the section "The Coding Phase."
Bonus Chapter Porting .Nettrix to Pocket PC
Appendix - The State of details PC Gaming If we runAthis code (see about setting the correct reference to the managed DirectX type library in the Appendix section "The B - Motivations Coding Phase"), in Games all we get is a black window, because we don't know yet what we can use in the
RenderCprocedure drawGames? something. But DirectX will already be up and running, ready for us! Appendix - How Do ItoMake Appendix D - Guidelines for Developing Successful Games
To complete our first program, let's see some basic concepts regarding Direct3D drawing in the next sections.
Index
List of Figures List of Tables
.NET Game Programming DirectX 9.0 3-D Coordinate Systems andwith Projections by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Even if we have no interest in creating 3-D games, we must understand the basic concepts of a 3-D Apress © 2003everything (696 pages) we do in Direct3D is defined by points and images in a 3-D world. coordinate system, because Of course we canThe ignore the z that weitare a to 2-D world—and we'll see how to do authors ofaxis this and text pretend show how easy caninbe produce interesting this—but the z zeroed valuemultimedia will still begames there. using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of three Microsoft's Visualdimensions, Studio. When we are dealing with Cartesian there are two types of coordinate systems: left-
handed and right-handed. These names refer to the z-axis position relative to the x and y axis. To determine this position, point the fingers of one hand to the x-axis positive direction and move them in the Table of Contents counterclockwise direction to the y-axis positive position; the z-axis direction will be the direction your .NET Game Programming with DirectX 9.0 thumb points to. Figure 3-2 illustrates this concept. Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
3-2: The .Nettrix Cartesian 3-D coordinate systems BonusFigure Chapter Porting to Pocket PC Appendix A - The State of PC Gaming
To put it a different way, in the left-handed coordinate system, the z value gets bigger (the positive direction) when we go from the screen to a point away from us (considering that the x axis and the y axis Appendix C - How Do I Make Games? are on the computer screen). The right-handed 3-D system is the opposite: The z values increase toward Appendix D - Guidelines for Developing Successful Games us from the screen. Appendix B - Motivations in Games
Index
List of Figures Direct3D uses the left-hand coordinate system, which means that positive values for z are visible, and the List greater of Tables they are for a given object, the farther the object is (and, depending on the projection chosen, the
littler it appears on the screen); and negative values are not shown (unless we change our "camera position," which is possible too in Direct3D). After understanding 3-D coordinate systems, the next step to explore is how they present 3-D objects to our 2-D screen. Fortunately, all the hard mathematical work is done by DirectX, but we have to know the concept of projections and how they apply to DirectX in order to give the basic instructions about how to present the objects on screen. Direct3D support two different types of projections: Perspective projection: The most common type of projection, it takes in account the z distance and adjusts the objects accordingly. This projection makes objects appear smaller when far from the screen—the objects get deformed, like in the real world. For example, the borders of a straight road appear to come together in the horizon. Figure 3-3 show a graphical representation of the perspective projection.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Figure 3-3: Perspective projection Table of Contents .NET Game Programming with DirectX Orthogonal projection: In this 9.0 type of projection, the z component is just ignored, and the objects Foreword don't get bigger when closer to the screen or smaller when they are farther away. This projection
mostly used for 2-D games or simpler 3-D games. Figure 3-4 presents orthogonal projection. Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to 3-4: Orthogonal projection Chapter 9 Figure Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
When defining projection type, we must choose the type of coordinating system and pass the Appendix A - Thethe State of PC Gaming parameters for the projection, according to its type. Direct3D offers six main functions (besides four others Appendix B - Motivations in Games
for creating custom coordinates systems) that allow us to specify the projection for our game. These functions return matrices that will be used by Direct3D to calculate the conversion from 3-D coordinates to Appendix D - Guidelines for Developing Successful Games screen coordinates. Appendix C - How Do I Make Games? Index
List ofMatrix.OrthoRH, Figures Matrix.OrthoLH: Returns the matrix with the transformations that need to be List ofapplied Tables to the object coordinates to define an orthogonal projection (RH stands for right-handed, LH
for left-handed). Each function receives the width and the height of the view port (usually, the screen) and the range of z values that will be viewed (points before the first z value and after the last one won't be viewed). Matrix.PerspectiveRH,Matrix.PerspectiveLH: Returns the transformation matrix for perspective projection, passing the width and height of the viewport and the z distance viewed (first and last points) for right-handed and left-handed coordinate systems. Matrix.PerspectiveFovRH,Matrix.PerspectiveFovLH: Returns the transformation matrix for perspective projection, passing the angle in radians of our field of view (Fov) and the z distances; for right-handed and left-handed coordinate systems. Figure 3-5 shows graphically the Fov angle and the z distance viewed (defined by view planes).
Figure 3-5: The field of view angle and view planes for perspective projection .NET Game Programming with DirectX 9.0
ISBN:1590590511 Alexandre Santos Lobãoconcept and Ellen In the next sectionbywe'll explore the matrix and learn how it helps us to convert coordinates of a 3D world to screenHatton coordinates, allowing us to easily perform complex operations on our game objects.
Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce
Understanding Matrices interesting multimediaand games3-D using Transformations Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
Knowing how to work version with oftransformation Microsoft's Visual matrices Studio.is possibly the most important point when dealing with Direct3D. Using matrices, we can perform rotation, scaling, or translation of any object on the 3-D world (or in the 2-D world, if we choose to ignore the z component), and these operations, correctly applied, will Table of Contents help us to define our projection type (as shown in the previous section) or even move the camera to see .NET Game scene Programming with DirectX 9.0 the same from different points. Foreword
Let's discuss the use of transformation matrices to do a simple translation, and then extrapolate the idea Preface for more complex operations. Suppose that we want to move a triangle up the y axis, as shown in Figure 3Introduction 6. Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List ofFigure Figures3-6: Moving a triangle on the y axis List of Tables
Let's assume the triangle vertices are defined by the points shown here. VERTEX
X
Y
Z
1
50
10
0
2
60
10
0
3
53
25
0
To translate 40 units over the y-axis positive direction, all we need is to sum 40 to each y position, and we have the new coordinates for the vertices, shown here: VERTEX
X
Y
Z
1
50
50
0
2
60
50
0
3
53
65
0
The same results can be achieved by representing each vertex as a matrix with one row and four columns, with the vertex coordinates as the first three columns and 1 as the value in the last one, and multiplying this matrix to a special matrix, constructed to produce the translation transformation to the vertex matrix.
Figure 3-7 presents the same operation applied to the first vertex. .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Figure 3-7: Applying a matrix multiplication to a 3-D vertex
To calculate the resulting matrix, we must take each value in the row of the first matrix and multiply them by each of the values in the corresponding column in the second matrix, and then perform the sum of all .NET Game Programming with DirectX 9.0 results. So, in the previous sample, the calculations are as follows:
Table of Contents Foreword
x' = (50 × 1) + (10 × 0) + (0 × 0) + (1 × 0) = 50 Preface Introduction
y' = (50 × 0) + (10 × 1) + (0 × 0) + (1 × 40) = 50
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter - .Netterpillars: Artificial z' =2 (50 × 0) + (10 × 0) + (0 × Intelligence 1) + (1 × 0) and = 0 Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ We don't to Pla.Net: get into much deeper detail here, but suffice it to say that we can perform translations by Chapter 4 want - River Tiled Game Fields, Scrolling, and DirectAudio
putting the-desired values for translation over the x, y, and z in the last row of the transformation matrix; River Pla.Net II: DirectInput and Writing Text to Screen perform scaling by replacing the 1s on the diagonal to fractional values (to shrink) or greater values (to Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow expand); and perform rotation around any axis using a combination of sine and cosine values in specific Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API positions in the matrix. Chapter 5
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Tip9For Chapter - those who want to know more about the transformation matrices, DirectX SDK help has full Nonmanaged Code showing each of the matrices and explaining how to use them. coverage of this topic, Bonus Chapter Porting .Nettrix to Pocket PC
Luckily enough, we don't need to understand all these details to use the transformations in our program. Appendix A - The State of PC Gaming All we need to know is the following: Appendix B - Motivations in Games Appendix C - How Do I Make Games?
The transformation matrices can be multiplied by each other without losing information. If we want to translate and rotate an object at the same time, we can simply multiply the translation matrix to the Index rotation matrix and multiply the result for our vertices, acquiring the desired result. Appendix D - Guidelines for Developing Successful Games List of Figures
List ofThe Tables Device object has three special properties: one used to receive the projection matrix (explained
in the previous section),.Transform.Projection; another to indicate the transformations desired in our 3-D world (explained here), .Transform.World; and the third to specify the camera position (explained in the next section),.Transform.View. The D3DX utility library has functions to create all the transformation matrices for us, functions for matrices multiplication, and a function that returns an identity matrix (a special matrix that returns the vertices without transformations, which is used to clean the old world matrix before updating it). We'll see these functions in the section "The Code Phase."
Positioning the Camera As an extra feature when dealing with 3-D coordinate systems, DirectX allows us to position the camera to see the same scene from different points. The camera position is calculated by some special transformations applied to the object's world coordinates. We can calculate the matrix for these transformations manually, and set it to the .Transform.View property, or we can use the helper functions Matrix.LookAtLH and Matrix.LookAtRH. These helper functions define the camera position and the direction it's looking to by three points: the 3-D position of the camera, the 3-D position the camera is looking at, and the current "up" direction, usually the y axis. If we don't define a view (camera) matrix, DirectX will provide a default one for us, but it's an important concept to have in mind. Do you remember the first Prince of Persia game in which, at a given level, the
prince drank a special potion and the screen turns upside down? Imagine creating this feature with a .NET Game Programming with DirectX 9.0 single line of code, rotating the view matrix by 180 degrees (multiplying it for a rotation matrix). This ISBN:1590590511 by benefit Alexandre SantosDirect3D Lobão and Ellen scenario shows the of using even for 2-D games. Hatton Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 Drawing Primitives and Texture by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton We're ready to start working now: We know what adapters and devices are, we understand what display Apress 2003 (696 pages) program structure, and we know all we need to know (for now) about modes are, we know the© basic Direct3D projections, cameras, and transformations. The stage the play. All we need now is to meet the The authors of this text show how easy isit all canready be tofor produce interesting multimedia games using Managed DirectX 9.0 and actors: the drawing primitives. programming with Visual Basic .NET on Everett, the latest version ofprimitives, Microsoft's are Visual Studio. Drawing primitives, or 3-D vertex collections that define single 3-D objects. Direct3D uses the
simplest polygon-a triangle-as a base to create all other 3-D objects. This is done because a primitive defined with only three points is guaranteed to be in a single plane, and to be convex, and these characteristics are the Table of Contents key to perform the fastest rendering possible. .NET Game Programming with DirectX 9.0
Foreword So, for example, if we want to draw a square on screen, we'll have to use two squares. If we want to create a Preface cube, we'll use 12 triangles (2 for each facet), as shown in Figure 3-8. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - 3-8: How A Docube I Make Games? Figure made with triangles Appendix D - Guidelines for Developing Successful Games
Along with triangles, Direct3D allows us to define lists of lines and lists of points, which are useful mainly for Index debugging List of Figurespurposes in that they help us to see the wireframe image for our objects and check the hidden surfaces when we use triangles. List of Tables The steps for creating objects in Direct3D are as follows: 1. Define the vertex type. 2. Create a vertex buffer. 3. Fill the buffer with each of the vertices of the object, according to the defined vertex type. 4. Draw the buffer on the device, informing the primitive type. For now, let's just consider that all the vertices are defined only by x, y, and z coordinates (we'll see more details about this later), so we can concentrate on the drawing primitive types. Once the vertex buffer is filled, we use the following code lines to draw it on screen, assuming that vertBuffer is a valid VertexBuffer object: ObjDirect3DDevice.SetStreamSource(0, vertBuffer, 0) ObjDirect3DDevice.DrawPrimitives(<primitive type>, 0, )
A primitive type can be one of the following values of the PrimitiveType enumeration: PointList: Each vertex is rendered isolated from the others, so we can see a list of floating points. Not quite useful, even less so now, because since DirectX 8.0 we have a new feature-point sprites-that can be
used to create particle system effects. Figure 3-9 presents a set of vertices rendered as a point list. .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction
3-9: GDI+ Vertices as a point list Chapter 1 Figure - .Nettrix: andrendered Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 - Managed Direct3D Basics DirectX vs. GDI+ LineList: The DirectX verticesFirst are Steps: rendered in pairs, withand lines connecting each pair. This call fails if we fail to Chapter 4 a- vertex River Pla.Net: Tiledan Game Scrolling, and DirectAudio pass buffer with evenFields, number of vertices. Figure 3-10 illustrates the use of a line list primitive Chapter type. 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 3-10: The same vertices rendered as a line list LineStrip: All the vertices in the buffer are rendered as a single polyline. This is useful when debugging, because this primitive type allows us to see a wireframe image of our objects, regardless of the number of vertices. Figure 3-11 presents a line strip primitive type sample.
Figure 3-11: The same vertices rendered as a line strip
TriangleList: The vertices are rendered in groups of three, as isolated triangles. This provides us the .NET Game Programming with DirectX 9.0 greatest flexibility when rendering complex scenes, but there's the drawback of having duplicated vertices Alexandre Santos Lobão and Ellen if we want to by draw connected triangles. Figure 3-12 showsISBN:1590590511 the use of the triangle list primitive type to Hatton render vertices. Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 Chapter 4 Chapter 5
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Figure 3-12: The same vertices rendered as a triangle list
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio - River Pla.Net II: DirectInput and Writing Text to Screen
TriangleStrip: We'll useAdventure this primitive type ADO.NET, when drawing connected triangles. It's the usual choice for Chapter 6 - Magic KindergarteN.: Games, and DirectShow rendering scenes, because it's more efficient, since we don't have Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech APIto repeat the duplicated vertices. Every new (after theII: first two) added to the buffer creates a new triangle, using the last two defined Chapter 8 vertex - .Netterpillars Multiplayer Games and Directplay vertices.D-iNfEcT: Figure 3-13 presents a triangle strip primitive typeand example. Multithreading, Nonrectangular Windows, Access to Chapter 9
-
Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 3-13: A complex polygon created with a triangle strip TriangleFan: In this primitive, all the triangles share a common vertex-the first one in the buffer-and each new vertex added creates a new triangle, using the first vertex and the last defined one. Figure 3-14 illustrates the last of the primitive types, the triangle fan.
Figure 3-14: A triangle fan example
When drawing triangles, we need to take special about .NET Game Programming with care DirectX 9.0the triangle vertex ordering if we want Direct3D to draw only the front part of a triangle. The feature of hiding the backfaces are called culling, and when ISBN:1590590511 by Alexandre Santos Lobão and Ellen choosing a cullingHatton mode, we must define if we want the front face to be the clockwise-ordered one or the © 2003 (696 pages) counterclockwiseApress one; so we must draw all triangles using the same ordering for the vertices. The authors of this text show how easy it can be to produce
Okay, you're probably thinking, "These games primitive types are interesting, butand what if I just want to draw a single interesting multimedia using Managed DirectX 9.0 programming with Basic .NET onIEverett, the image, say, a bitmap file on disk, toVisual the screen? Can't just draw it latest directly on screen?" version of Microsoft's Visual Studio.
The answer is no. You must create a square (composed with two triangles) and apply the image on it, as a texture. We can even state that a specific color must be treated as transparent, so it appears that we are Table of Contents dealing with nonregular objects. That's what we'll see in the next section. .NET Game Programming with DirectX 9.0 Foreword
Texturing and Coloring with Flexible Vertex Formats
Preface
Introduction
Direct3D gives us the power to choose how we can define the vertices that will compose our drawing
Chapter 1 -using .Nettrix: and flexible Collisionvertex Detection primitives, the GDI+ so-called formats (FVF). Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites
Before 3creating a vertex buffer (explained in the previous section), Chapter - Managed DirectX First Steps: Direct3D Basics and DirectXwe vs.must GDI+specify which kind of information each vertex will hold, creating custom vertex structure using it when creating a new VertexBuffer Chapter 4 - River Pla.Net: Tiled a Game Fields, Scrolling, andand DirectAudio object, 5as -presented in the code sample: Chapter River Pla.Net II:next DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Vbuffer NewKindergarteN. VertexBuffer(VertSize, VertNum, Device, Usage, VertexFormat, Pool) Chapter 7 -=Magic II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 The parameters for this code Nonmanaged Code line are as follows: Bonus Chapter Porting .Nettrix to Pocket PC
VertSize is the size of the custom vertex, in bytes.
Appendix A - The State of PC Gaming
Appendix B - Motivations in Games VertNum is the number of vertices we'll want the buffer to hold. Appendix C - How Do I Make Games?
Device is the Direct3D reference to the current Appendix D - Guidelines for Developing Successful Gamesdisplay device. Index
Usage defines the purpose of the vertex buffer, allowing Direct3D to perform any extra control it needs.
List ofWe'll Figures usually use WriteOnly for this, meaning that we are only writing to the buffer and passing it later to List ofthe Tables device, and won't read from it. This flag allows Direct3D to choose the best memory allocation for fast
writing and rendering. VertexFormat is the flexible vertex format used in each vertex, explained a little later. Pool provides extra information to Direct3D, defining where the resource must be placed (system memory or managed memory, for example). Usually we'll use the Default enumeration member for this parameter. TheVertexFormat parameter is a combination of flags that will tell Direct3D what information we are using in our vertices, allowing us to include diffuse light or texture information on each vertex. Among the many possible values on the VertexFormat enumeration, the ones we'll be using in this book are as follows: Diffuse: We'll include information for a diffuse color (which may be thought of as a diffuse-colored light) in the vertex. Position: Our vertex coordinates need transformation (remember the matrices?) from world coordinates to screen coordinates before being displayed. This flag cannot be used with the VertexFormat.Transformed flag. Transformed: Our vertices are already in screen coordinates, so we won't need any projection information. This enumeration member can't be combined with the Position one. VertexFormat.Texture0 through VertexFormat.Texture8: Our vertices include from 0 to 8 different texture coordinates.
The following code sample a complete example, .NET Gameshows Programming with DirectXfrom 9.0 defining the vertex structure to creating the vertex buffer: ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Apress vertex © 2003 (696format pages) ' Our Custom will need to be transformed, and The authors of this text show how easyand it candiffuse be to produce ' has information about texturing colors interesting multimedia games using Managed DirectX 9.0 and Public Const FVF_CUSTOMVERTEX As VertexFormats = VertexFormats.Position Or _ programming with Visual Basic .NET on Everett, the latest or VertexFormats.Diffuse version of Microsoft's VisualVertexFormats.Texture1 Studio.
' We need our vertex buffer to hold 36 vertices Dim NUM_VERTS = 36 Table of' Contents Here is the vertex structure .NET Game Programming with DirectX 9.0 Private Structure CUSTOMVERTEX Foreword Public X As Single Public Y As Single Preface Introduction Public Z As Single color Integer Chapter 1 -Public .Nettrix: GDI+ andAs Collision Detection Public tu As Single Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites As First Single Chapter 3 -Public Managed tv DirectX Steps: Direct3D Basics and DirectX vs. GDI+ End Structure Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Dim vertBuffer As VertexBuffer Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen ' Create the vertex buffer Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow vertBuffer = New VertexBuffer(GetType(CUSTOMVERTEX), _ Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API NUM_VERTS, ObjDirect3DDevice, Usage.WriteOnly, _ Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay FVF_CUSTOMVERTEX, Pool.Default) Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A IN - The PC Gaming NEW TheState Typeofkeyword, used in previous versions of Visual Basic, was upgraded to the Structure Appendix B Motivations in .NET keyword. TheGames latter is far more flexible, allowing the declarations of functions and different scope Appendix C - How Do I Make specifiers in theGames? members declaration, but still being a value type with all its particularities (classes Appendix D - Guidelines for features Developing Successful Games have similar to structures, but are reference types and have additional different features Index
and limitations).
List of Figures
It's important to understand how we can deal with the color and tu/tv (texture) parameters.
List of Tables
Thecolor parameter specifies a color for each vertex. The vertex colors generate gradients between each vertex, as shown in the square in Figure 3-15: The upper-left corner is rendered with blue, the upper-right with red, the lower-left with yellow, and the lower-right with green.
Figure 3-15: Applying colors to square vertices We must specify the colors through their RGB components using the Color.FromARGB function. The color codes are the same ones defined in the System.Drawing.Color component. We can't use the old GDI's
RGB function to specify such color, because it is intrinsically different from the new Color.FromARGB Game Programming with DirectX 9.0 function, and we .NET can have unexpected results, like the blue and red components being inverted. by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Think of the texture position parameters, tu and tv, as the x and y position in the texture previously loaded 2003 (696 pages) All textures have rectangular shapes, and these values range from (0, that correspondsApress to the © vertex position. Thecorner authors this text show easy can be to produce 0) for the upper-left ofofthe texture to (1,how 1) for theit lower-right corner. The texture is applied to the object interesting multimedia games using 3-16 Managed DirectX 9.0 and according to the values set to all vertices. In Figure we see three vertexes with valid tu and tv values, programming with Visual Basic .NET on Everett, the latest the texture loaded, and the result rendered by the device. version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 - 3-16: .Netterpillars: Sprites Figure Texture Artificial mappingIntelligence with (tu,tv)and pairs of values Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
TheDevice object needsTiled to have theFields, information about texture it must use for each call of the Chapter 4 - River Pla.Net: Game Scrolling, andwhich DirectAudio DrawPrimitives function (explained and in the previous Chapter 5 - River Pla.Net II: DirectInput Writing Textsection), to Screenwhich will receive the vertex buffer with the vertex and coordinates. For this, weGames, must pass a previously loaded texture to the SetTexture method Chapter 6 -texture Magic KindergarteN.: Adventure ADO.NET, and DirectShow of the device. Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Chapter - .Netterpillars II: Multiplayer Games and Directplay We can8 load the texture from a file using the FromFile method of the TextureLoader helper object, which D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to can receive Chapter 9 - different parameters depending on the need of the program. To load opaque textures, it will Nonmanaged Code
simply receive the filename and the device to which the texture will be rendered. When calling the method to load transparent textures, the functions receive many other parameters, allowing a greater control over the Appendix A - The State of PC Gaming loaded texture, including a color key that will specify the transparent color for the texture loaded. Bonus Chapter Porting .Nettrix to Pocket PC Appendix B - Motivations in Games
Appendix We'll seeC the - How details Do I about Make Games? how to implement texture features on our program in the next sections. In the
followingDsection we'll for outline the proposal for the sample application of this chapter. Appendix - Guidelines Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Application Proposal by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Our proposal for Hatton this chapter sample is to create a simple application that will help us to understand the 2003apply (696 pages) basics of DirectX,Apress so we©can this knowledge to creating games in coming chapters. The authors of this text show how easy it can be to produce
To accomplish this, we'll create an application that will test our machines and return the capabilities of the interesting multimedia games using Managed DirectX 9.0 and programming with Visual .NET on Everett, the give latest installed hardware and software, and alsoBasic run some tests that will us the necessary information on version of Microsoft's Visual Studio. how to Create an application that runs in windowed mode.
Table of Contents
.NET Game with DirectX CreateProgramming an application that runs 9.0 in full-screen mode. Foreword
Create an application that shows a transparent sprite using texture capabilities. Preface Introduction
Create an application that deals with lighting, using different light colors. Although we won't explore
Chapter - .Nettrix: GDI+ and Collision this1 feature extensively in this book,Detection it's quite useful to learn the basics of lighting, so we can create Chapter 2 .Netterpillars: Artificial Intelligence and Sprites interesting effects in our games. Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Create application that Game deals Fields, with basic matrixand transformations, which will be very useful in our Chapter 4 - an River Pla.Net: Tiled Scrolling, DirectAudio
games because theyII: provide a built-in to translate Chapter 5 - River Pla.Net DirectInput and capability Writing Text to Screen (move around the screen), rotate around an 6axis, and scale any preloaded images to different sizes. Chapter - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
We'll create a separate window for each of the tests listed previously, and all the tests will execute the - .Netterpillars II: Multiplayer Games and Directplay same drawing procedure—one that will present the walking man textures at full speed on screen in order Multithreading, Windows, and to give 9us -anD-iNfEcT: idea of how fast our 3-DNonrectangular acceleration board really is.Access to Chapter Chapter 8
Nonmanaged Code
Bonus Chapterman Porting .Nettrixused to Pocket The walking drawings in thisPC chapter were made by Igor Sinkovec, a graphic artist and game Appendix A - The State of PC Gaming programmer (http://maniacco.tripod.com/). Appendix B - Motivations in Games
In the next discuss some extra details about our sample application. Appendix C -section How Dowe'll I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Application Project by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hattonwill be very straightforward; we can't add too much detail to it for now, because Our application project © 2003 we're focusing onApress what we can(696 dopages) with Direct3D in this chapter. The authors of this text show how easy it can be to produce
The coding phaseinteresting will be divided into six steps,using as described in the following multimedia games Managed DirectX 9.0 and list, each one exploring programming withDirect3D Visual Basic .NET on Everett, the latest additional features involved in the application: version of Microsoft's Visual Studio.
1. Create a main window with four list boxes that will show us the machine adapters, the devices for each adapter, the display modes for each device, and the device capabilities. From the main Table of window, Contentspresent the other windows that will do each of the tests defined in the project proposal. The main window is shown in the 9.0 Figure 3-17. .NET Game Programming with DirectX Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Figure 3-17: The main window interfaceWindows, and Access to D-iNfEcT: Multithreading, Nonrectangular Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
2. Create a DirectX windowed test that will use a set of textures to produce the illusion of a walking man. The bitmaps with the walking man images are on the accompanying CD-ROM, within the Appendix B - Motivations in Games directory that contains this chapter's sample code. Appendix A - The State of PC Gaming
Appendix C - How Do I Make Games?
Appendix D - Guidelines Developing Successful 3. Adjust the codefor from the previous step toGames create a DirectX application that runs in full-screen mode. Index
4. Figures Create a new DirectX windowed test, from the test created in step 2, to test the use of transparent List of textures. For this test we'll create an image with transparent parts that can be moved with the List of Tables mouse, so we can see that it's really transparent.
5. From the test created in step 2, create a new test that will exemplify the use of lighting. For this test we'll create a control window that will allow us to change each of the RGB components of the diffuse light colors in each of the figure vertices. Figure 3-18 presents the interface that we'll use to control the light colors.
Figure 3-18: The Light Control window 6.
.NET Game Programming with DirectX 9.0
6. Our last test will demonstrate the use of matrix transformations on tridimensional figures. For this ISBN:1590590511 by Alexandre Santos Lobão and Ellen we'll create a cube and a window that will control the matrix transformations on it. We'll also add an Hatton option to make figure Apressthe © 2003 (696move pages)automatically, shaking around. The matrix transformations control window is shown on Figure 3-19. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
3-19: The window -Figure .Nettrix: GDI+ andMatrixControl Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 -section Managed DirectX Steps: Direct3D Basics and DirectX vs.main GDI+ In the next we'll start First coding our application, starting from the window code. Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 The Coding.NET Phase by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Before we start any coding in our project, we need to set a reference to the Direct3D and DX3D components of Apress © 2003 pages) managed DirectX. To add the (696 references, choose Project × Add Reference, and locate the appropriate components on the list in the .NET components tab. If the components are not in the list, then you possibly don't The authors of this text show how easy it can be to produce interesting multimedia games using DirectX 9.0 and have the managed DirectX interface installed in yourManaged computer. Since this interface is installed with DirectX 9.0, programming with Visual on Everett, the latest site. you'll need to install it by downloading theBasic latest.NET version from the Microsoft version of Microsoft's Visual Studio.
First Step: Coding the Main Window
Table of Contents
.NET withwindow, DirectX which 9.0 Let'sGame start Programming coding the main will allow us to see our hardware capabilities, and then we can code Foreword the tests one by one, from the simpler to the most complex ones. Preface
After creating the main window, as shown in the visual prototype in the project phase, we need to know the functions that list the adapters, devices, display modes supported, and capabilities. A quick look in SDK help Chapter 1 - .Nettrix: GDI+ and Collision Detection shows us these methods and properties of the Manager object: Introduction Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Adapters.Count: Returns the number of adapters (3-D boards) in the machine. Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Adapter(n).Information: Returns the adapter according to an ordinal adapter Chapter 5 - River Pla.Net II: DirectInput and Writing Text tocharacteristics, Screen number. Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API GetDeviceCaps: Returns the device capabilities in a complex structure. The function receives the ordinal
Chapter 8 - .Netterpillars II: and Multiplayer Directplay number of the adapter the typeGames of theand device (Hardware or Reference). Remember, Reference is D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to software Chapter 9 - based and always supported; Hardware is hardware based and depends on the boards installed. Nonmanaged Code BonusAdapters(n).SupportedDisplayModes: Chapter Porting .Nettrix to Pocket PC Returns the characteristics of a specific display mode, given Appendix A - Thenumber. State of PC Gaming its ordinal Appendix B - Motivations in Games
CheckDeviceType: Appendix C - How Do I Make Checks Games? if a specific display mode is supported by the current device. Appendix D - Guidelines for Developing Successful Games
A quick look in the DirectX SDK help will also show us that most of these functions don't return a readable description (which could be used to fill the list), so we'll need to create some functions to return display names List of Figures where appropriate. Index
List of Tables
Since all the information between the lists are related (the devices supported may vary for each adapter, and the display modes and device characteristics may vary depending on the device), it's better to force an update of the related list every time a new item is selected on a high-order list. Our program basic structure will be as follows: On the "load" event: Load the adapters list Select the fist list item, in order to fire the selection changed event On the adapter list "selected item changed" event: Reload the device list Select the fist list item, in order to fire the selection changed event On the device list "selected item changed" event: Reload the display modes list Reload the device capabilities list
Because we'll be using the Device object all over the form, we can dimension the variable at form level: Dim ObjDirect3DDevice As Device
In the Load event, we can call the ListAdapters function:
Sub FrmDirectX_Load() .NET Game Programming Handles MyBase.Load with DirectX 9.0 ' Fill the Adapters listand Ellen by Alexandre Santos Lobão Hatton ListAdapters() Apress © 2003 (696 pages) End Sub
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and Sub ListAdapters() with Visual Basic .NET on Everett, the latest Dim iprogramming As Integer version of Microsoft's Visual Studio. Dim AdapterInfo As AdapterDetail ' Add each adapter to the lstAdapters list box For i = 0 To Manager.Adapters.Count - 1 Table of Contents AdapterInfo = 9.0 Manager.Adapters(i).Information .NET Game Programming with DirectX lstAdapters.Items.Add(AdapterInfo.Description) Foreword Next i Preface ' Select the first availiable index, in order to fire the change event Introduction lstAdapters.SelectedIndex = 0 Chapter 1 - .Nettrix: GDI+ and Collision Detection End Sub Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 remember - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio We must to add code for releasing the Device object in the Closing event (which replaces the Chapter 5 River Pla.Net II: DirectInput and Writing Text to Screen Unload event from the previous versions of Visual Basic): Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 -Sub MagicFrmDirectX_Closing() KindergarteN. II: Animation Techniques Speech API Private Handles and MyBase.Closing Chapter 8 -If .Netterpillars II: Multiplayer Games and Directplay Not ObjDirect3DDevice Is Nothing Then ObjDirect3DDevice.Dispose() Chapter 9
End Sub
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to -ObjDirect3DDevice = Nothing Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix If we runBour - Motivations code now,inwe'll Games see the first list filled with the adapters' descriptions. The devices list, which must
be filled Cfor- each adapter Appendix How Do I Makechosen, Games?will always have one or two members: the reference rasterizer, which will always be andfora Developing hardware abstraction layer (HAL) rasterizer, which will be presented only if supported Appendix D -present, Guidelines Successful Games by a 3-D board. To check the presence of hardware acceleration, we can query the device capacities using the Index previously shown function, and, if there's no error, then we can add the HAL to our list. List of Figures List of Tables
The function for filling the devices list and the code for calling it (in the event that handles the selected item change at the adapters list) is shown in the following code sample: Sub lstAdapters_SelectedIndexChanged() Handles _ lstAdapters.SelectedIndexChanged ' Update the devices list every time a new adapter is chosen ListDevices(lstAdapters.SelectedIndex) End Sub Sub ListDevices(Adapter As Integer) On Error Resume Next Dim DeviceCaps As Caps ' Add each supported device to the lstDevices list box lstDevices.Items.Clear() ' The Reference Rasterizer will always be supported lstDevices.Items.Add("Reference Rasterizer (REF)") ' If there's no error when getting the HAL capabilities, ' then we have a hardware acceleration board installed DeviceCaps = Manager.GetDeviceCaps(Adapter, DeviceType.Hardware) If Err.Number = 0 Then lstDevices.Items.Add("Hardware Acceleration (HAL)") End If
' Select the first available index, in order to fire the change event .NET Game Programming with lstDevices.SelectedIndex = 0DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
End Sub
ISBN:1590590511
Thewill authors of this textadapter show how can be to produce The display modes depend on the andeasy the itdevice chosen, so we can create a function interesting using Managed DirectX 9.0 and (listDisplayModes) thatmultimedia will receivegames this information as parameters, and call it on the selection change programming with Visual Basic .NET on Everett, the latest event of the devices list box: version of Microsoft's Visual Studio.
Sub lstDevices_SelectedIndexChanged() Handles lstDevices.SelectedIndexChanged Table of Contents ' The first entry in lstDevices is the Reference Rasterizer .NET Game Programming with DirectX 9.0 If lstDevices.SelectedIndex = 0 Then Foreword
ListDisplayModes(lstAdapters.SelectedIndex, DeviceType.Reference)
Preface
Else
Introduction Chapter 1
ListDisplayModes(lstAdapters.SelectedIndex, DeviceType.Hardware)
-End .Nettrix: If GDI+ and Collision Detection
End Sub Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Listing the display modes is not as straightforward as listing the adapters. First we must check if every mode Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow returned by the adapter is supported by the device, and then we must compose each list item with a Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API combination of various properties that will identify uniquely each display mode: Width,D-iNfEcT: Height: The Multithreading, width and height Nonrectangular of the screen. Windows, If creating and Access a full-screen to device, these properties will Chapter 9 Nonmanaged define the resolution Code of the screen; when in windowed mode, Direct3D only will manage to create the Bonusdevice Chapter Porting .Nettrix to Pocket without errors if the currentPC display is one of these resolutions. Appendix A - The State of PC Gaming
Format: The format of the display mode, as explained in the section "Understanding Display Modes." Appendix B - Motivations in Games Appendix C - How Do I Make Games?
RefreshRate: The monitor refresh rate, in MHz, or 0 if the default. Usually we don't have to care about this, but it's possible for a device to support the same resolution with different refresh rates, so it's better to Index list it in our list box, or we could finish with duplicated entries. Appendix D - Guidelines for Developing Successful Games List of Figures
Because the Format property returns a member of the Format enumeration, we can't display it directly in the List of Tables list box; we must create a "translation" function that will map the valid modes to readable strings. Function DisplayModeName(Format As Format) As String Select Case Format Case Format.R8G8B8 DisplayModeName = "R8G8B8" Case Format.X8R8G8B8 DisplayModeName = "X8R8G8B8" Case Format.A8R8G8B8 DisplayModeName = "A8R8G8B8" Case Format.R5G6B5 DisplayModeName = "R5G6B5" Case Format.X1R5G5B5 DisplayModeName = "X1R5G5B5" End Select End Function
With this function, we can now complete the Display Modes list box as follows: Sub ListDisplayModes(Adapter As Integer, Renderer As DeviceType)
Dim DispMode As DisplayMode .NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen lstDisplayModes.Items.Clear() Hatton For Each DispMode In Manager.Adapters(Adapter).SupportedDisplayModes Apress © 2003 (696 pages) ' Check to see if the display mode is supported by the device The authors of this text show how easy it can be to produce If Manager.CheckDeviceType(Adapter, Renderer, _ interesting multimedia games using Managed DirectX 9.0 and DispMode.Format, DispMode.Format, False) Then programming with Visual Basic .NET on Everett, the latest ' Fill version the display modes with the width, height, _ of Microsoft's Visuallist Studio. ' the mode name and the refresh rate lstDisplayModes.Items.Add(DispMode.Width & "x" & DispMode.Height & _ Table of Contents " ( " & DisplayModeName(DispMode.Format) & " - " & _ .NET Game Programming with DirectX 9.0 IIf(0, "Adapter Default", DispMode.RefreshRate & "Mhz)")) Foreword End If Preface Next Introduction End Sub
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Running our program now, we can see the first three list boxes filled with information, as shown in Figure 3-20. - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Figure The for filled Adapters,Successful Rendering Devices, and Display Modes list boxes Appendix D - 3-20: Guidelines Developing Games Index List of last Figures The list box, which will list the device capabilities, will be a tougher one to fill. The function GetDeviceCaps List of Tables returns a complex structure with many dozens of flags, organized in many different enumerations. Since we
can't simply list the composed flags, we must create functions to return readable strings for each property. We'll use the descriptions provided in SDK help to create the functions that will list the most important flags for our purposes, but there are some we'll leave aside. If you want to create a comprehensive list, just follow the steps explained here. The first function we create checks for some simple flags in the Caps structure and adds the appropriate strings to the Device Capabilities list box: Sub listGeneralCaps(DevCaps As Caps, lstCaps As ListBox) lstCaps.Items.Add(" ----- General Caps ------------------------") If DevCaps.MaxActiveLights = -1 Then lstCaps.Items.Add("Maximum Active Lights: Unlimited") Else lstCaps.Items.Add("Maximum Active Lights: " & _ DevCaps.MaxActiveLights) End If If DevCaps.MaxPointSize = 1 Then lstCaps.Items.Add("Device does not support point size control") Else LstCaps.Items.Add("Maximum point primitive size: " & _ DevCaps.MaxPointSize) End If
lstCaps.Items.Add("Maximum Primitives in each DrawPrimitives call: " & _ .NET Game Programming with DirectX 9.0 DevCaps.MaxPrimitiveCount) ISBN:1590590511 by Alexandre Santos Lobão and Ellen lstCaps.Items.Add("Maximum Textures simultaneously bound: " & _ Hatton DevCaps.MaxSimultaneousTextures) Apress © 2003 (696 pages) lstCaps.Items.Add("Maximum Texture aspect ratio: " & _ The authors of this text show how easy it can be to produce DevCaps.MaxTextureAspectRatio) interesting multimedia games using Managed DirectX 9.0 and lstCaps.Items.Add("Maximum size:the " latest & DevCaps.MaxTextureWidth & _ programming with Visual BasicTexture .NET on Everett, "x" & DevCaps.MaxTextureHeight) version of Microsoft's Visual Studio. lstCaps.Items.Add("Maximum matrixes blending: " & _ DevCaps.MaxVertexBlendMatrices) Table of Contents lstCaps.Items.Add("Maximum vertex shaders registers: " & _ .NET Game Programming with DirectX 9.0 DevCaps.MaxVertexShaderConst) Foreword End Sub Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection To help2 us- to show specific deviceIntelligence capabilities, weSprites created many other functions with the same basic structure: Chapter .Netterpillars: Artificial and
a simple sequence of if commands, each one testing for a specific flag within the composed flag members. - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ The following code shows an example of such a function, one that lists the flags that compose the Caps Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio member of DriverCaps: Chapter 3 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Sub listDriverCaps(ByVal DriverCaps As DriverCaps, ByVal lstCaps As ListBox) - Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 7 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
lstCaps.Items.Add(" ----- Driver Caps ------------------------") D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterIf 9 DriverCaps. SupportsDynamicTextures Then Nonmanaged Code lstCaps.Items.Add("The driver support Dynamic Textures") Bonus Chapter Porting .Nettrix to Pocket PC End If Appendix A - The State of PC Gaming Appendix B - Motivations in Games
If DriverCaps.CanCalibrateGamma Then lstCaps.Items.Add("The driver can automatically adjust the gamma ramp") Appendix D - Guidelines for Developing Successful Games End If Appendix C - How Do I Make Games? Index List of Figures If DriverCaps. SupportsFullscreenGamma Then List of Tables lstCaps.Items.Add("The driver can do dynamic gamma ramp adjustment" & _
" in full-screen mode.") End If End Sub
Eachif statement in this kind of function tests a specific Boolean value inside the composed flag. In this sample, DriverCaps is a structure with many composed flags, each one being a Boolean value associated with a specific driver feature. We created similar functions to list the flags for the TextureCaps,RasterCaps,DeviceCaps, and TextureCaps members. Since they present the same structure and the information they add to the list box is basically the one found in SDK help, we won't reproduce them here; for those interested, they can be found in the accompanying CD-ROM. We can create a special function now that will retrieve the Caps structure for the current device and call the functions created as mentioned previously: Sub ListDeviceCaps(Adapter As Integer, DeviceType As DeviceType) Dim Caps As Caps LstDeviceCaps.Items.Clear() Caps = Manager.GetDeviceCaps(Adapter, DeviceType)
' List some general driver capabilities .NET Game Programming with DirectX 9.0 listGeneralCaps(Caps, LstDeviceCaps) ISBN:1590590511 by Alexandre Lobão and Ellen ' List the deviceSantos capabilities Hatton ListDevCaps(Caps.DeviceCaps, LstDeviceCaps) Apress © 2003 (696 pages) ' List specific driver capabilities The authors of this text show how easy it can be to produce listDriverCaps(Caps.DriverCaps, LstDeviceCaps) interesting multimedia games using Managed DirectX 9.0 and ' List rasterizer capabilities programming with Visual Basic .NET on Everett, the latest ListRasterCaps(Caps.RasterCaps, version of Microsoft's Visual Studio. LstDeviceCaps) ' List texturization capabilities ListTextureCaps(Caps.TextureCaps, LstDeviceCaps) Table Contents End ofSub .NET Game Programming with DirectX 9.0 Foreword
We must include a call to this function on the selected item changed event for the Devices list box, so the list Preface gets updated for every new device chosen in the list. Figure 3-21 presents the finished main window of this Introduction chapter1 sample. Chapter - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - 3-21: Motivations in Games Figure The finished main window Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
Second Step: Coding Our First Windowed Test
Index
List of Figures
This test is very important, because it will establish the base of all future tests and programs. So we'll make List of first Tables it very simple: Let's just initialize the Direct3D, create the device, draw a simple image, and count the frame rate. In order to allow us to see something happening, let's load an array of images (loaded as textures) and render them one at a time, over a square (composed of two triangles), so we'll see the illusion of a walking guy. We'll use the basic Direct3D program structure, explained in the "Creating a Simple Direct3D Program" section, dividing the code into two groups: In our main window (code in the click event for the corresponding button): the code that simply creates (and destroys) the test window and call to the initialization, finalization, and rendering routines defined in the test window. In the test window: all the Direct3D routines—initialization, finalization, and rendering. The code for the main window, which will be very similar to other tests, is show here: Dim WinWindowTest As New WindowTest() WinWindowTest.Show() ' Initialize Direct3D and the device object If Not (WinWindowTest.InitD3D(WinWindowTest.Handle)) Then MessageBox.Show("Could not initialize Direct3D.") WinWindowTest.Dispose() Exit Sub
' Load the textures and create the square to show them .NET Game Programming with DirectX 9.0Then ElseIf Not (WinWindowTest.CreateTextures()) ISBN:1590590511 by Alexandre Santos Lobão and initialize Ellen MessageBox.Show("Could not vertices and textures.") Hatton WinWindowTest.DisposeD3D() Apress © 2003 (696 pages) WinWindowTest.Dispose() The authors of this text show how easy it can be to produce Exit Sub interesting multimedia games using Managed DirectX 9.0 and End If programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
' If we have no errors, then enter the rendering loop Do While Not WinWindowTest.EndTest Table of Contents WinWindowTest.Render() .NET Game ' Programming with calculation DirectX 9.0 Frame rate Foreword WinWindowTest.Text = "Window Test. Frame rate: " & CalcFrameRate.ToString Preface Application.DoEvents() Introduction Loop ' Call finalization routines and close the window Chapter 1 the - .Nettrix: GDI+ and Collision Detection WinWindowTest.DisposeD3D() Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites WinWindowTest.Dispose() Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow In the rendering procedure we used a helper function, CalcFrameRate, that we created in order to make our - Magic KindergarteN. II: Animation Techniques and Speech API code cleaner. In this function (shown in the next code listing) we are using Chapter 8 - .Netterpillars II: Multiplayer Games and the Directplay System.Environment.TickCount to retrieve current tick of the processor clock (with the precision rate D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to is not very accurate, but since we'll of a millisecond), so we can calculate the frame rate. Note that this function Chapter 9 Nonmanaged Code only use frame rate calculations to give us an idea of the speed at which we're drawing the scene, and won't Bonus Chapter Porting .Nettrix to Pocket PC include it in our final games, we think that using it is a valid approach. Chapter 7
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Public Function CalcFrameRate() As Integer Static FrameRate As Integer Appendix D - Guidelines for Developing Successful Games Static LastFrameRate As Integer, LastTick As Integer Appendix C - How Do I Make Games? Index List of Figures ' Frame rate calculation List of Tables If System.Environment.TickCount - LastTick >= 1000 Then
LastFrameRate = FrameRate FrameRate = 0 LastTick = System.Environment.TickCount End If FrameRate += 1 CalcFrameRate = LastFrameRate End Function
Following the sequence of the code just shown, let's see the initialization routines. The InitD3D procedure will create the Direct3D object, define the presentation parameters for the window creation based on the current display mode, and create the Device object. If you don't understand any part of the following code, refer to the first sections of this chapter for detailed explanations. Since we'll use the Direct3D object and the Device object on many different functions, let's create them as public variables on the form: Dim ObjDirect3DDevice As Device = Nothing Function InitD3D(WinHandle As IntPtr) As Boolean Dim DispMode As DisplayMode Dim ObjDirect3Dpp As PresentParameters
DispMode .NET = Manager.Adapters(_ Game Programming with DirectX 9.0 Manager.Adapters.Default.Adapter).CurrentDisplayMode ISBN:1590590511 by Alexandre Santos Lobão and Ellen ' Define Hatton the presentation parameters ObjDirect3Dpp New Apress ©=2003 (696PresentParameters() pages) ObjDirect3Dpp.Windowed = True The authors of this text show how easy it can be to produce ObjDirect3Dpp.SwapEffect = SwapEffect.Discard interesting multimedia games using Managed DirectX 9.0 and ObjDirect3Dpp.BackBufferFormat programming with Visual Basic .NET = DispMode.Format on Everett, the latest of Microsoft's Visual Studio. ' Try to version create the device Try objDirect3DDevice = New Device(Manager.Adapters.Default.Adapter, _ Table of Contents DeviceType.Hardware, WinHandle, CreateFlags.SoftwareVertexProcessing, _ .NET Game Programming with DirectX 9.0 objDirect3Dpp) Foreword ' Define which type of vertex will be used Preface objDirect3DDevice.VertexFormat = fvf_CUSTOMVERTEX Introduction InitD3D = True ChapterCatch 1 - .Nettrix: GDI+ and Collision Detection Chapter 2 InitD3D - .Netterpillars: Artificial Intelligence and Sprites = False ChapterEnd 3 -Try Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter'4 Dispose - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio the used objects ChapterDispMode 5 - River Pla.Net = Nothing II: DirectInput and Writing Text to Screen = Nothing ChapterObjDirect3Dpp 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow End Function Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 important The most part in the preceding code is the definition of the presentation parameters, which will rule Nonmanaged Code
the device creation. analyze this one Bonus Chapter PortingLet's .Nettrix to Pocket PC line at a time. Appendix A - The State of PC Gaming
In the first line of the code listing, we create the presentation parameters as an object of the
Appendix B - Motivations intype: Games PresentParameters
Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index
ObjDirect3Dpp = New PresentParameters()
List of Figures List of Tables Then we state that we want to run in windowed mode. Since we didn't specify the window size, the device will
use the whole client area of the target window (defined by the handle used when creating Device). ObjDirect3Dpp.Windowed = True
In the next line, we instruct the device to choose the best memory allocation when doing the screen flips, even if our back buffer got discarded. Note that this option doesn't force the back buffer to be discarded, it just tells the device that we are re-creating the whole scene in the Render procedure, so it doesn't need to preserve the contents of the back buffer when flipping. ObjDirect3Dpp.SwapEffect = SwapEffect.Discard
The last line tells the format of our back buffer. Since we are running in windowed mode, it's a must for us to use the current display mode format, because the window will be rendered using the same resolution and colors of the rest of the screen. ObjDirect3Dpp.BackBufferFormat = DispMode.Format
The next function, following the main program sequence, is the one that will load the textures from disk and
create a square in which to display them. To create such a function, let's first refer to the flexible vertices format Game Programming with DirectX 9.0 (FVF) definition in.NET the "Texturing and Coloring with Flexible Vertex Formats" section. We see that we'll need to by Alexandre Santos Lobão and Ellen create a custom vertex type that will hold texture information inISBN:1590590511 addition to the x, y, and z coordinates. And since Hatton we don't want to make any 3-D transformations, let's create the vertex with an extra flag (rhw) that informs the Apress © 2003 (696 pages) device that the coordinates are already transformed (they are screen coordinates). The definition of our authors of this text show howand easy it can be tocorresponding produce VertexFormat The is made using a constant value creating the structure: interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's constant Visual Studio. ' Simple textured vertices and structure
Public Const FVF_CUSTOMVERTEX As VertexFormats = VertexFormats.Transformed Or _ VertexFormats.Texture1
Table of Contents
.NET Game Programming with DirectX 9.0
Private Structure CUSTOMVERTEX Public X As Single Preface Public Y As Single Introduction Public Z As Single Chapter 1 -Public .Nettrix: GDI+ and Single Collision Detection rhw As Chapter 2 -Public .Netterpillars: Artificial Intelligence and Sprites tu As Single Chapter 3 -Public Managed tv DirectX Steps: Direct3D Basics and DirectX vs. GDI+ As First Single Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio End Structure Foreword
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
In order to-help us fill the VertexFormat structure for each new vertex, it's a good idea to create a helper Magic KindergarteN. II: Animation Techniques and Speech API function that fill the structure members and return the vertex, as show in the following code snippet: Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Chapter 7
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Function Nonmanaged CreateFlexVertex(X Code As Single, Y As Single, Z As Single, _ rhw As Single, tuPCAs Single, tv As Single) As CUSTOMVERTEX Bonus Chapter Porting .Nettrix to Pocket CreateFlexVertex.X = X Appendix A - The State of PC Gaming CreateFlexVertex.Y Appendix B - Motivations in Games= Y CreateFlexVertex.Z = Z Appendix C - How Do I Make Games? CreateFlexVertex.rhw = Successful rhw Appendix D - Guidelines for Developing Games CreateFlexVertex.tu = tu Index CreateFlexVertex.tv = tv List of Figures End Function List of Tables
Now we can start thinking about the CreateTextures routine. Based on the basic concepts shown earlier, we can create a draft for the function: 1. Define the array of textures (must be public to the form, since it'll be used in the Render procedure). 2. Create the textures for each array element. 3. Create and open the vertex buffer. 4. Define the vertices. 5. Close the buffer. The textures we'll be using show a draft of the walking man, and are numbered from walk1.bmp to walk10.bmp, as shown in Figure 3-22.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents
Figure 3-22: Walking man textures, from walk1.bmp to walk10.bmp (courtesy of Igor Sinkovec)
.NET Game Programming with DirectX 9.0
Foreword The code for the previous steps is shown next. Preface
Note Notice that we created a separate function to generate the vertices, so the code becomes more Introduction Chapter 1
readable and more easy to expand with different vertices. - .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Dim NUM_VERTS 4 Chapter 3 - Managed= DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Dim vertBuffer As VertexBuffer Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Dim Textures(10) As Texture - River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 5 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Function CreateTextures() As Boolean - Magic KindergarteN. II: Animation Techniques and Speech API Dim verts As CUSTOMVERTEX() Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Dim i As Integer Chapter 7
Chapter 9
Try
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
' Load the textures, named from "walk1.bmp" to "walk10.bmp" For i = 1 To 10 Appendix B - Motivations in Games Textures(i - 1) = TextureLoader.FromFile(ObjDirect3DDevice, _ Appendix C - How Do I Make Games? Application.StartupPath + "\..\Walk" & CStr(i) & ".bmp") Appendix D -Next Guidelines for Developing Successful Games Appendix A - The State of PC Gaming
Index List of Figures ' Define the vertex buffer to hold our custom vertices List of TablesvertBuffer = New VertexBuffer(GetType(CustomVertex),_
NUM_VERTS, ObjDirect3DDevice, Usage.WriteOnly, _ FVF_CUSTOMVERTEX, Pool.Default) ' Locks the memory, which will return the array to be filled verts = vertBuffer.Lock(0, 0) ' Defines the vertices verts = SquareVertices() ' Unlock the buffer, which will save our vertex information to the device vertBuffer.Unlock() Return True Catch Return False End Try End Function Function SquareVertices() As CUSTOMVERTEX() Dim vertices As CUSTOMVERTEX() ReDim vertices(4) ' Create a square, composed of 2 triangles vertices(0) = CreateFlexVertex(60, 60, 0, 1, 0, 0) vertices(1) = CreateFlexVertex(240, 60, 0, 1, 1, 0) vertices(2) = CreateFlexVertex(60, 240, 0, 1, 0, 1)
vertices(3) = CreateFlexVertex(240, 240, 0, 1, 1, 1) .NET Game Programming with DirectX 9.0 SquareVertices = vertices ISBN:1590590511 by Alexandre Santos Lobão and Ellen End Function Hatton Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX With all the textures and vertices loaded, all we need now is to code 9.0 the and Render procedure to load one texture programming with Visual Basic .NET on Everett, the latest a time, and a finalization routine to dispose the used objects. The Render routine follows the structure of the version of Microsoft's Visual Studio. scene starting, ending, and being presented, as shown earlier. Table Contents Sub ofRender() .NET Game Programming with DirectX Static x As Integer = 9.0 0 Foreword PrefaceIf (ObjDirect3DDevice Is Nothing) Then Return Introduction ' Clears the device with blue color Chapter ObjDirect3DDevice.Clear(ClearFlags.Target, 1 - .Nettrix: GDI+ and Collision Detection _ Chapter 2
Color.FromArgb(255, 0, 0, 255), 1.0F, 0) - .Netterpillars: Artificial Intelligence and Sprites
ChapterObjDirect3DDevice.BeginScene() 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio one texture a time, order create the illusion of a walking guy Chapter'5 Show - River Pla.Net II: DirectInput and in Writing Text to to Screen ChapterObjDirect3DDevice.SetTexture(0, 6 - Magic KindergarteN.: Adventure Games,Textures(x)) ADO.NET, and DirectShow
x +=- Magic 1 KindergarteN. II: Animation Techniques and Speech API If x = 10 Then x = 0
Chapter 7 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter ' 9 Define which vertex buffer should be used Nonmanaged Code
ObjDirect3DDevice.SetStreamSource(0, vertBuffer, 0) ' Draw the vertices of the vertex buffer, rendering them as a Appendix A - The State of PC Gaming ' triangle strip, using the given texture Appendix B - Motivations in Games ObjDirect3DDevice.DrawPrimitives(PrimitiveType.TriangleStrip, _ Appendix C - How Do I Make Games? 0, NUM_VERTS - 2) Appendix D - Guidelines for Developing Successful Games ObjDirect3DDevice.EndScene() Index ' Present the rendered scene List of Figures ObjDirect3DDevice.Present() List of Tables End Sub Bonus Chapter Porting .Nettrix to Pocket PC
Note that we don't have any mention of back buffers or screen swapping (flipping) operations here, so why do we care about these in the Device object creation? In fact, everything is done here, but is performed in the background by the device: The back buffer is cleared using the Clear command, it is locked for drawing using theBeginScene method, it's unlocked after we render the scene with the EndScene function, and it is finally flipped to the screen, and maybe discarded, using the Present method. Our final routine just disposes of all objects created in the previous functions, and it's called by the main program after the main loop is finished and when the window is closing: Sub DisposeD3D() Dim i As Integer For i = 0 To 9 If Not (Textures(i) Is Nothing) Then Textures(i).Dispose() Textures(i) = Nothing Next If Not (vertBuffer Is Nothing) Then vertBuffer.Dispose() vertBuffer = Nothing If Not (ObjDirect3DDevice Is Nothing) Then ObjDirect3DDevice.Dispose()
ObjDirect3DDevice = Nothing .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
End Sub
ISBN:1590590511
authors of this text how it can be toroutine, producewhich will end the form when the Esc This last functionThe ends our sample. Aftershow coding a easy simple escape interesting multimedia using DirectX 9.0 and key is pressed, we can run our sample games and see the Managed results, as presented in Figure 3-23. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - 3-23: Motivations in Games Figure Running our first DirectX program Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
Public EndTest As Boolean = False Index Sub TestWindow_KeyDown(sender As Object, e As KeyEventArgs) _ List of Figures MyBase.KeyDown List ofHandles Tables If e.KeyCode = Keys.Escape Then EndTest = True End If End Sub
Third Step: Creating a Full-Screen Sample To make our sample run in full-screen mode, all we need to do is change the presentation parameters in the InitD3D routine. In order to have all sample codes separated from each other, we'll create a new button in the main window to fire the full-screen mode. Since most of the code will be the same, we can copy all the code from the windowed mode and simply apply the following updates. Let's analyze the code for setting the presentation parameters, line by line. The initial lines are the same from the windowed mode; just gather information about the current display mode and create the presentation parameters object: DispMode = Manager.Adapters(Adapter.Default).CurrentDisplayMode ' Define the presentation parameters ObjDirect3Dpp = New PresentParameters()
Following the definition, we set the parameters for creating the back buffer. In our sample, we'll be using the .NET Game Programming with DirectX 9.0 current format, width, and height (we must specify these three parameters); but we could be using any of the ISBN:1590590511 by Alexandre Santos Lobão and Ellenlist on the main formats or resolutions shown in our Display Modes screen. Hatton Apress © 2003 (696 pages)
ObjDirect3Dpp.BackBufferFormat = DispMode.Format The authors of this text show how easy it can be to produce ObjDirect3Dpp.BackBufferWidth = DispMode.Width interesting multimedia games using Managed DirectX 9.0 and ObjDirect3Dpp.BackBufferHeight programming with Visual Basic .NET=onDispMode.Height Everett, the latest version of Microsoft's Visual Studio.
The last line is the same as the one in the windowed mode: Set the flipping operation to the one that has the best performance, instructing the device not to care about preserving the back buffer.
Table of Contents
.NET Game Programming with DirectX 9.0 Foreword Preface
ObjDirect3Dpp.SwapEffect = SwapEffect.Discard
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 Using - .Netterpillars: Artificial Intelligence and the Sprites Note the Discard swap effect forces use of only one back buffer, so we don't need to set the Chapter 3 BackBufferCount - Managed DirectX First Steps: Direct3D Basics and DirectX vs.isGDI+ property to 1. Another important point that we don't worry about setting the Chapter 4 Windowed - River Pla.Net: Tiled to Game Fields, DirectAudio property false, sinceScrolling, running and full screen is the default. Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen
It's enough make our code runAdventure in full-screen mode, but weand canDirectShow make a simple improvement in our Chapter 6 - to Magic KindergarteN.: Games, ADO.NET,
SquareVertices function to create a square that covers the entire screen, stretching the walking man - Magic KindergarteN. II: Animation Techniques and Speech API textures, to generate a nicer effect. We can gather the screen resolution, using the same method we saw Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay before, with a display mode object. Our final function will be as follows: Chapter 7
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Private Function SquareVertices() As CUSTOMVERTEX() Bonus Chapter Porting .Nettrix to Pocket PC vertices As CUSTOMVERTEX() Appendix A -Dim The State of PC Gaming vertices(4) Appendix B -ReDim Motivations in Games mode As Games? DisplayMode Appendix C -Dim How Do I Make = Manager.Adapters(Adapter.Default).CurrentDisplayMode Appendix D -mode Guidelines for Developing Successful Games Index
' Create a square, composed of 2 triangles, taking all the screen vertices(0) = CreateFlexVertex(0, 0, 0, 1, 0, 0) List of Tables vertices(1) = CreateFlexVertex(mode.Width, 0, 0, 1, 1, 0) vertices(2) = CreateFlexVertex(0, mode.Height, 0, 1, 0, 1) vertices(3) = CreateFlexVertex(mode.Width, mode.Height, 0, 1, 1, 1) SquareVertices = vertices End Function List of Figures
Just run the program now and press the Full Screen button in the main window to see the textures applied to the entire screen, with no visible loss in the frame rate, as presented in Figure 3-24.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface
Figure 3-24: Running our DirectX program in full-screen mode
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Fourth- Step: Using Transparent Textures Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 3
Chapter 4 the - River Pla.Net: Game for Fields, Scrolling, and DirectAudio We'll use same code Tiled employed the windowed mode test as the basis for our transparency test. We'll still Chapter 5 River Pla.Net II: DirectInput and Writing Text to Screen have the walking man as a background texture, and will load another texture over it, with a color set to Chapter 6 - Magic Adventure Games, and DirectShow transparent, so weKindergarteN.: can see the man running behindADO.NET, parts of it. Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API For this8purpose, we created a window Games drawing and filled the panes and surrounding areas with blue color, as Chapter - .Netterpillars II: Multiplayer and Directplay
shown in Figure 3-25.Multithreading, Nonrectangular Windows, and Access to D-iNfEcT: -
Chapter 9
Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix Figure D - 3-25: Guidelines A window, for Developing with a flat Successful blue color Games to be used as a transparent texture. Index
We'll follow these steps for including our new transparent texture in the sample: List of Figures 1.Tables In the InitD3D routine, let's set the device parameters to indicate that we'll be using transparent textures. List of 2. Create a new function that will load the transparent texture. 3. Create a function to generate a new square in which we'll render the transparent texture. 4. Change the click button event in the main window to call this function. 5. Adjust the render procedure to show the transparent texture. 6. As defined in the game project, we must call the function that creates the square on the MouseMove event of the test window, so we can move the square with the transparent texture to different parts of the window and see the resulting effects. Let's start with the InitD3D function. All we need to do is to set three new parameters of the device: ObjDirect3DDevice.RenderState.SourceBlend = Blend.SourceAlpha ObjDirect3DDevice.RenderState.DestinationBlend = Blend.InvSourceAlpha ObjDirect3DDevice.RenderState.AlphaBlendEnable = True
These parameters tell how the rendering must blend together the source and the destination bitmaps to achieve the final transparency effect, and the last one informs the device where we want the blending to occur. The parameters shown in the preceding code must apply to almost all cases, and will be used throughout the rest of
this book.
.NET Game Programming with DirectX 9.0
by Alexandre Santos Lobão andperformance, Ellen Please note that the blending operation slows soISBN:1590590511 in our real games we'd only set the Hattonproperty to True just before drawing the transparent textures, and reset it after finish AlphaBlendEnable © 2003 pages) them. Since it's aApress test, let's just(696 leave it set all the time—performance is not our preoccupation here. The authors of this text show how easy it can be to produce interesting using Managed DirectX 9.0 the andone we saw in the previous The function for loading the multimedia transparentgames texture is slightly different from programming onneeds Everett, latest samples, as we can see in the with nextVisual code Basic piece,.NET which to the be included in the CreateTextures version of Microsoft's Visual Studio. procedure to add transparency support: Table of will Contents ' We use blue as the transparent color .NET DimGame ColorKeyVal ProgrammingAs with Integer DirectX 9.0 = Color.FromArgb(255, 0, 0, 255) Foreword
' Load the transparent texture Preface TranspTexture = TextureLoader.FromFile(objDirect3DDevice, _ Introduction Chapter 1
Application.StartupPath - .Nettrix: GDI+ and Collision Detection & "\..\TranspSample.bmp", _
Chapter 2
64, 64,Artificial D3DX.Default, 0,Sprites Format.Unknown, Pool.Managed, _ - .Netterpillars: Intelligence and
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Filter.Point, Filter.Point, colorKeyVal.ToARGB)
Chapter 5 - this RiverisPla.Net DirectInput and Writing Well, okay, VERY II: different. Although we canText loadtoanScreen opaque texture specifying only the device and the Chapter 6 the - Magic KindergarteN.: Games, and DirectShow filename, overloaded versionAdventure of the function to ADO.NET, load transparent textures will have a lot more features and Chapter 7 (but - Magic KindergarteN. II: Animation Techniques and Speech flexibility it'll have worse performance, too). We won't enter into API the details about every parameter, since we Chapter 8 most - .Netterpillars Multiplayer andtoDirectplay won't use of them inII:this book. AllGames we need know for now is the following: Chapter 9
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
The64, 64 parameters Nonmanaged Coderepresent the width and height of the texture being loaded. These must be values by the.Nettrix device,tousually power of 2 (16, 32, 64, 128, and so on, with some new boards going up Bonussupported Chapter Porting PocketaPC to 4096). These are automatically calculated in the simpler version of the function. Appendix A - The State values of PC Gaming Appendix B - Motivations in Games
The filter parameters presented here are the best performing ones. If you want a little more quality, you can change them from Filter.Point to Filter.Default.
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games
Index TheColorKey parameter receives the color that will be transparent. In this case, the alpha component of List ofthe Figures color is significant: If you are loading images from file formats that don't support transparency (such as List ofbitmaps), Tables this value will be always 255 (opaque).
The next step is to create a new square to load our transparent texture into. We can copy the functions used in our first sample, and adapt them to receive the x and y coordinates for the texture. Remember, we'll move the texture with the mouse, and the only way to do it (for now, since we haven't discussed transformation matrices yet) is updating the vertex positions, one by one. Dim TranspVertBuffer As VertexBuffer = Nothing Dim TranspTexture As Texture Public Function CreateTranspVertices(X As Single, Y As Single) As Boolean Dim verts As CUSTOMVERTEX() Try ' If the vertex buffer was previously created, dispose them If Not (TranspVertBuffer Is Nothing) Then TranspVertBuffer.Dispose() TranspVertBuffer = New VertexBuffer(GetType(CustomVertex), NUM_VERTS, _ objDirect3DDevice, Usage.WriteOnly, _ fvf_CUSTOMVERTEX, Pool.Default) verts = TranspVertBuffer.Lock(0, 0) verts = TranspVertices(X, Y) TranspVertBuffer.Unlock()
Return True .NET Game Programming with DirectX 9.0 Catch by Alexandre Return False Santos Lobão and Ellen Hatton End Try Apress © 2003 (696 pages) End Function
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and Function TranspVertices(X As Single, Single) As CUSTOMVERTEX() programming with Visual Basic .NETYonAs Everett, the latest Dim vertices CUSTOMVERTEX() versionAs of Microsoft's Visual Studio.
ReDim vertices(4) Table of' Contents Create a square, composed of 2 triangles. .NET Game Programming with DirectX 9.0 is 42 pixels wide and 60 long ' Our transparent texture Foreword vertices(0) = CreateFlexVertex(X, Y, 0, 1, 0, 0) Prefacevertices(1) = CreateFlexVertex(X + 42, Y, 0, 1, 1, 0) Introduction vertices(2) = CreateFlexVertex(X, Y + 60, 0, 1, 0, 1)
= CreateFlexVertex(X + 42, Y + 60, 0, 1, 1, 1) Chaptervertices(3) 1 - .Nettrix: GDI+ and Collision Detection = vertices ChapterTranspVertices 2 - .Netterpillars: Artificial Intelligence and Sprites End Function Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
To adjust the click event for the button on the main screen, all we need to do is call the preceding function, Magic KindergarteN. II: Animation Techniques and Speech API passing a -default position for the transparent window. The full procedure for the Click button is as follows:
Chapter 7 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Dim WinTransparentTest Nonmanaged Code As New TransparentTest()
WinTransparentTest.Show()
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
' Initialize Direct3D and the device object If Not (WinTransparentTest.InitD3D(WinTransparentTest.Handle)) Then Appendix C - How Do I Make Games? MessageBox.Show("Could not initialize Direct3D.") Appendix D - Guidelines for Developing Successful Games WinTransparentTest.Dispose() Index Exit Sub List Figures ' of Load the textures and create the square to show them List of Tables ElseIf Not (WinTransparentTest.CreateTextures() And _ WinTransparentTest.CreateTranspVertices(0, 0)) Then MessageBox.Show("Could not initialize vertices and textures.") WinTransparentTest.DisposeD3D() WinTransparentTest.Dispose() Exit Sub End If Appendix B - Motivations in Games
' If we have no errors, then enter the rendering loop Do While Not WinTransparentTest.EndTest WinTransparentTest.Render() ' Frame rate calculation WinTransparentTest.Text = "Transparency Test. Frame rate: " & _ CalcFrameRate.ToString Application.DoEvents() Loop ' Call the finalization routines and close the window WinTransparentTest.DisposeD3D() WinTransparentTest.Dispose()
Adjusting the rendering function is just as easy, since there's no difference in the rendering when displaying a simple texture or a transparent one. We can just add the following lines of code in the Render procedure, just
below the lines that draw our walking man:
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
ObjDirect3DDevice.SetTexture(0, TranspTexture) Hatton ObjDirect3DDevice.SetStreamSource(0, TranspVertBuffer, 0) Apress © 2003 (696 pages) ObjDirect3DDevice.DrawPrimitives(PrimitiveType.TriangleStrip, 0, NUM_VERTS - 2) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Since the background of our transparent bitmap is blue, maybe it's a good idea to change the window background to black, just to create a different look from the previous samples. We can do this by simply Table of Contents adjusting the call to the Clear method of the Device object to .NET Game Programming with DirectX 9.0 Foreword
ObjDirect3DDevice.Clear(ClearFlags.Target, Color.FromArgb(255, 0, 0, 0), 1.0F, 0)
Preface
Introduction Chapter 1 - .Nettrix: GDI+ and Collision Detectionevent to call CreateTranspVertices. Since we receive the All we need to do now is code the MouseMove Chapter - .Netterpillars: Artificial Intelligence Sprites mouse2x and y positions as arguments on theand event, all we need is this code: Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Sub TransparentTest_MouseMove(sender as object, e As MouseEventArgs) _ ChapterHandles 5 - RiverMyBase.MouseMove Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
-CreateTranspVertices(e.X, Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow e.Y)
Chapter End Sub 7 - Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -it. Running our sample will allow us to test our transparent window, moving it with the mouse over the And that's Nonmanaged Code
walking man,Porting as shown in Figure 3-26.PC Bonus Chapter .Nettrix to Pocket Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 3-26: Testing the transparent window
Fifth Step: Using Colored Lights We can use the same code we created for testing DirectX in windowed mode to also do our diffuse colored light test.
Although all we need to do to test the use of diffuse light is change the flexible vertex format to support a color Game Programming with DirectX 9.0 value per vertex, .NET and set such values for the vertices, we'll stick to our project and create a light control window ISBN:1590590511 by Alexandre Santos Lobão andfor Ellen in which we can choose the RGB components the light color on each vertex.
Hatton Apress © shown 2003 (696inpages) The light control window, Figure 3-18, is composed of four tabs, and each tab has three numeric upThe authors of this text show how with easyRed1, it can be to produce down controls. We named these controls starting Green1, Blue1 for the first vertex through to Red4, games Managed DirectX 9.0 and Green4, Blue4 forinteresting the fourthmultimedia vertex. We'll use using the values of each control directly on the color definition for the programming with Visual Basic .NET on Everett, the latest vertices. version of Microsoft's Visual Studio.
The steps for converting the first sample to implement light control are as follows: Table1.of Adjust Contents the flexible vertex format structure and constant used in the vertex buffer creation to accept the .NET Game Programming DirectX 9.0 color componentwith for each vertex. Foreword
2. Adjust the helper function CreateFlexVertex to accept the color parameter.
Preface
Introduction 3. Adjust the SquareVertices function to create the vertices using colors as defined by the numeric upChapter down 1 - .Nettrix: GDI+ and Collision Detection controls. Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites 4. Adjust the clickDirectX buttonFirst procedure to createBasics the control window the test window, and initialize the Chapter 3 - Managed Steps: Direct3D and DirectX vs.and GDI+
of the vertices colors. Chapter values 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
5. Create an event procedure that will update the vertex colors when any color component for any vertex Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow changes. Chapter 8 The - .Netterpillars II: Multiplayer Games andevery Directplay Note first two steps are very connected; time we change the structure we'll need to change the D-iNfEcT: Multithreading, Nonrectangular Windows, to when we'll deal with matrices). constant and our helper function (we'll do it again inand the Access next test, Chapter 9 Nonmanaged Code
The new codePorting for implementing light control is shown next; we present the updates in bold to illustrate how Bonus Chapter .Nettrix to Pocket PC simple the are: Appendix A -modifications The State of PC Gaming Appendix B - Motivations in Games Appendix PublicC Const - How Do FVF_CUSTOMVERTEX I Make Games? As VertexFormats = VertexFormats.Transformed _
Or VertexFormats.Texture1 Or VertexFormats.Diffuse Appendix D - Guidelines for Developing Successful Games Index
Private Structure CUSTOMVERTEX List of Figures List of TablesPublic X As Single
Public Public Public Public Public Public End Structure
Y As Single Z As Single rhw As Single color As Integer tu As Single tv As Single
Private Function CreateFlexVertex(X As Single, Y As Single, Z As Single, _ rhw As Single, Color As Integer, tu As Single, tv As Single) _ As CUSTOMVERTEX CreateFlexVertex.X = X CreateFlexVertex.Y = Y CreateFlexVertex.Z = Z CreateFlexVertex.rhw = rhw CreateFlexVertex.color = Color CreateFlexVertex.tu = tu CreateFlexVertex.tv = tv End Function
TheSquareVertices function will be the same used in the previous samples (except for the full screen one), with the solo update in passing the color parameter for the CreateFlexVertex helper function.
To define the color, we'll use Programming the Color.FromARGB function .NET Game with DirectX 9.0 we used before (when choosing a blue color for clearing the device). ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages) Private Function SquareVertices() As CUSTOMVERTEX() The authorsAs of this text show how easy it can be to produce Dim vertices CUSTOMVERTEX() multimedia games using Managed DirectX 9.0 and ReDim interesting vertices(4) programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
' Create a square, composed of 2 triangles vertices(0) = CreateFlexVertex(60, 60, 0, 1, _ Table of Contents Color.FromARGB(Red1.Value, Green1.Value, Blue1.Value), 0, 0) .NET Game vertices(1) Programming with 9.0 = DirectX CreateFlexVertex(240, 60, 0, 1, _ Foreword Color.FromARGB (Red2.Value, Green2.Value, BLue2.Value), 1, 0) vertices(2) = CreateFlexVertex(60, 240, 0, 1, _ Preface Color.FromARGB (Red3.Value, Green3.Value, Blue3.Value), 0, 1) Introduction vertices(3) 240, 0, 1, _ Chapter 1 - .Nettrix: GDI+ = andCreateFlexVertex(240, Collision Detection Color.FromARGB (Red4.Value, Green4.Value, Blue4.Value), 1, 1) Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites SquareVertices = vertices Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ End Function Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 start - Magic KindergarteN.: Games, and form, DirectShow The test procedure, definedAdventure in the Click buttonADO.NET, on the main will be very similar to the ones we saw Chapter 7 Magic KindergarteN. II: Animation Techniques and Speech API before: It follows the same structure, but creates both test and control windows, and takes special care in Chapter 8 -the .Netterpillars II:the Multiplayer andcontrols Directplay initializing values of all numeric Games up-down to 255 to fill the vertices with white light, so the walking D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to man image Chapter 9 - starts with no color distortion (the default value is zero, which would prevent us from seeing anything). Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Dim WinLightControl As New LightControl() Dim WinTestLight As New LightTest()
Appendix B - Motivations in Games
Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games WinLightControl.Show() Index WinTestLight.Show() List of Figures List Tables ' of Initialize Direct3D and the device object
If Not (WinLightControl.InitD3D(WinTestLight.Handle)) Then MessageBox.Show("Could not initialize Direct3D.") WinLightControl.Dispose() Exit Sub ' Load the textures and create the vertices ElseIf Not (WinLightControl.CreateTextures()) Then MessageBox.Show("Could not initialize the textures and vertices.") WinLightControl.DisposeD3D() WinLightControl.Dispose() Exit Sub End If ' Start with full white With WinLightControl .Red1.Value = 255 : .Red2.Value = 255 : .Red3.Value = 255 : .Red4.Value = 255 : End With
light in all vertices .Green1.Value .Green2.Value .Green3.Value .Green4.Value
= = = =
255 255 255 255
: : : :
.Blue1.Value .BLue2.Value .Blue3.Value .Blue4.Value
= = = =
255 255 255 255
' Ends the test if ESC is pressed in any of the 2 windows Do While Not WinLightControl.EndTest And Not WinTestLight.EndTest
WinLightControl.Render() .NET rate Game calculation Programming with DirectX 9.0 ' Frame ISBN:1590590511 by Alexandre Santos=Lobão and Ellen WinTestLight.Text "Light Test. Frame Rate: " & CalcFrameRate.ToString Hatton Application.DoEvents() Apress © 2003 (696 pages)
Loop The authors of this text show how it canthe be towindows produce ' Call the finalization routines and easy close interesting multimedia games using Managed DirectX 9.0 and WinLightControl.DisposeD3D() programming with Visual Basic .NET on Everett, the latest WinLightControl.Dispose() version of Microsoft's Visual Studio. WinTestLight.Dispose() Table of Contents .NET TheGame last step Programming to make our with code DirectX fully9.0 operational is including a call to update the vertex colors every time one
vertex color has changed. Since the values of the controls are being read directly in the CreateVertices Foreword procedure, we can simply call this procedure on an event that handles changing in all numeric up-down Preface controls: Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection Sub Color_TextChanged(sender As Object, Chapter 2 - .Netterpillars: Artificial Intelligence and Spritese As EventArgs) Handles _
Red1.TextChanged, Red3.TextChanged, Chapter 3 - Managed DirectXRed2.TextChanged, First Steps: Direct3D Basics and DirectX vs. GDI+ Red4.TextChanged, _ Blue1.TextChanged, Blue3.TextChanged, Blue4.TextChanged, _ Chapter 4 - River Pla.Net: TiledBLue2.TextChanged, Game Fields, Scrolling, and DirectAudio Green1.TextChanged, Green2.TextChanged, Green4.TextChanged Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Green3.TextChanged, Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
End Sub
CreateVertices()
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
NEW IN Appendix B .NET
In previous versions of Visual Basic, when we want to use the same event procedure for different controls, we were forced to give the controls the same name, and it wasn't possible to share event - procedures Motivations in Games across objects of different types. In Visual Basic .NET, the association of the event Appendix C - procedure How Do I Make Games? with the object is made using the Handles keyword, which can receive different commaAppendix D - separated Guidelines controls for Developing Successful Gamesends up with another old problem that occurred in Visual to handle. This feature Index Basic: If you changed the control name after creating the event procedures, they failed to handle the List of Figuresevent because the association was made using the event procedure names. In Visual Basic .NET, List of Tableswhen we alter any control name, the event procedure name remains the same, but the Handles clause is updated with the new control name. Appendix A - The State of PC Gaming
Just run our program now, and play a little with the vertex light colors. Figure 3-27 shows a sample color distorted window.
Figure 3-27: Our old friend walking man in a disco
Sixth Step: Testing Matrix Transformations
.NETtoGame Programming with DirectX 9.0 Adapting our sample test the matrix transformations, according to what we discussed earlier in this chapter, by hardest Alexandre Santos Lobão will be our last and challenge; but ifand youEllen missed some ISBN:1590590511 previous point, this is the perfect way to reinforce the concepts. Hatton Apress © 2003 (696 pages)
Since we're facing a lot of modifications in many let's all the code for this sample, starting with The authors of this text show howprocedures, easy it can be to see produce the flexible vertexinteresting format definition. multimedia Thegames FVF definition using Managed will beDirectX simpler9.0 now, andbecause we'll abandon the rhw programming Visualsamples Basic .NET onwe Everett, the lateston screen (already transformed) parameter that indicated in thewith previous that were working version of Microsoft's Visual Studio. coordinates. In this sample, we'll test all the transformations from world coordinates to screen coordinates. Table Public of Contents Const FVF_CUSTOMVERTEX As VertexFormats = VertexFormats.Position Or _ .NET Game Programming with DirectX 9.0 VertexFormats.Texture1 Foreword
Dim NUM_VERTS = 36 Preface Introduction
Private Structure Chapter 1 - .Nettrix: GDI+ andCUSTOMVERTEX Collision Detection X As Artificial SingleIntelligence and Sprites Chapter 2 Public - .Netterpillars: Chapter 3 Chapter 4 Chapter 5 Chapter 6
End
Chapter 7
Public Y As Single - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Public Z As Single - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Public tu As Single - River Pla.Net II: DirectInput and Writing Text to Screen Public tv As Single - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Structure - Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Nonmanaged CreateFlexVertex willCode be simpler:
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Function CreateFlexVertex(X As Single, Y As Single, Z As Single, _
Appendix B - Motivations in Games tu As Single, tv As Single) As CUSTOMVERTEX Appendix C -CreateFlexVertex.X How Do I Make Games? = X Appendix D -CreateFlexVertex.Y Guidelines for Developing Successful Games = Y Index
CreateFlexVertex.Z = Z
List of Figures CreateFlexVertex.tu = tu List of TablesCreateFlexVertex.tv = tv
End Function
Returning to our first example, note that we have an initialization function and a finalization function, which creates the objects we need and destroys them when the window is being closed. Although the DisposeD3D finalization procedure needs no modifications (it just disposes every object), the InitD3D procedure for this sample deserves a closer look, because we have some significant modifications, which appear in bold in the subsequent code: Public Function InitD3D(WinHandle As IntPtr) As Boolean Dim DispMode As DisplayMode Dim ObjDirect3Dpp As PresentParameters
DispMode = Manager.Adapters(_ Manager.Adapters.Default.Adapter).CurrentDisplayMode ' Define the presentation parameters ObjDirect3Dpp = New PresentParameters() ObjDirect3Dpp.Windowed = True ObjDirect3Dpp.SwapEffect = SwapEffect.Discard ObjDirect3Dpp.BackBufferFormat = DispMode.Format ObjDirect3Dpp.EnableAutoDepthStencil = True
ObjDirect3Dpp.AutoDepthStencilFormat = DepthFormat.D16 Programming with DirectX 9.0 ' Try.NET to Game create the device ISBN:1590590511 by Alexandre Santos Lobão and Ellen Try Hatton objDirect3DDevice = New Device(_ Apress © 2003 (696 pages) Manager.Adapters.Default.Adapter, _ The DeviceType.Hardware, authors of this text show how WinHandle, easy it can be to_produce interesting multimedia games using Managed DirectX 9.0 and CreateFlags.SoftwareVertexProcessing, programming with Visual Basic .NET on Everett, the latest objDirect3Dpp) 'version Turnofoff culling front and back of the triangles are visible Microsoft's Visual=> Studio. ObjDirect3DDevice.RenderState.CullMode = Cull.NONE ' Turn off D3D lighting Table of Contents ObjDirect3DDevice.RenderState.Lighting = False .NET Game Programming with 9.0 ' Turn onDirectX ZBuffer Foreword ObjDirect3DDevice.RenderState.ZBufferEnable = TRUE Preface ObjDirect3DDevice.VertexFormat = FVF_CUSTOMVERTEX Introduction ' Set the Projection Matrix to use a orthogonal view = _ Chapter 1 ObjDirect3DDevice.Transform.Projection - .Nettrix: GDI+ and Collision Detection Matrix.OrthoLH(300, Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites200, 0, 0) = True Chapter 3 -InitD3D Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ ChapterCatch 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio = II: False Chapter 5 -InitD3D River Pla.Net DirectInput and Writing Text to Screen End Try Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ' Dispose the used objects Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API DispMode = Nothing Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay ObjDirect3Dpp = Nothing D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 End Function Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The StateinofaPC Gaming Since we're working 3-D world now, we need to instruct Direct3D to calculate which drawing primitives are Appendix B Motivations in Games shown and which are not. This is made by setting the EnableAutoDepthStencil member of the Appendix C - How Do I Make Games? presentation parameter to True (yes, we want a depth stencil to be used) and setting the Appendix D - Guidelines for Developing Successful Games (16 bits will be used in the calculation, because this AutoDepthStencilFormat to DepthFormat.D16 Index value is the most commonly supported by the current 3-D boards). We'll also need to turn on the z-buffer List (another of Figures name for depth buffer or depth stencil) calculation for the device. List of Tables
There are two other important settings here: the one that disables the drawing primitives culling (so the textures will be drawn in the front face) and the one that turns off the lighting for our 3-D world (in other words, the one that tells the device to light everything equally, since we are NOT providing any light in our vertices). A nice test is to comment out each of these lines and see the resulting effects. The last bold line defines an orthogonal projection matrix to be used when converting the world coordinates to screen ones, with a viewport of 300 pixels wide and 200 pixels tall. This is the simplest projection type, but the zaxis translation will have no effect (we won't see the cube getting smaller when it's far from the screen). After initializing the objects, we need to start the drawing primitives and load the textures. Based on the CreateSquare function in the last samples, we can create a CreateCube function that will initialize and lock the vertex buffer, call a CubeVertices function that creates all the vertices, and unlock the vertex buffer. There's no difference (except for the name) between the CreateCube and the CreateSquare functions, but let's take a look at the code behind these functions once more to refresh our memories and compose the complete code for this sample: Public Function CreateCube() As Boolean Try Dim i As Integer For i = 1 To 10 Textures(i - 1) = TextureLoader.FromFile(ObjDirect3DDevice, _ Application.StartupPath + "\..\Walk" & CStr(i) & ".bmp")
Next .NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen vertBuffer = New VertexBuffer(GetType(CustomVertex), NUM_VERTS, _ Hatton objDirect3DDevice, Usage.WriteOnly, _ Apress © 2003 (696 pages) fvf_CUSTOMVERTEX, Pool.Default) authors of this text show how easy it can will be to produce 'The Lock the vertex buffer (which return the allocated memory) interesting multimedia games using Managed DirectX 9.0 and Dim verts As = vertBuffer.Lock(0, 0) programming with CUSTOMVERTEX() Visual Basic .NET on Everett, the latest 'version Set of the vertices our cube Microsoft's Visualfor Studio. CubeVertices(verts) ' Unlocking the buffer commits the data to the array Table of Contents vertBuffer.Unlock() .NET Game Programming with DirectX 9.0 Return True Foreword Catch Preface Return False Introduction End Try End Function Chapter 1 - .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
TheCubeVertices function will create each of the vertices of the cube, providing their 3-D coordinates. It's - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio always a good idea to have a paper and a pencil at hand when creating simple 3-D models, so we can draft the Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen figure and understand better how the vertices fit together. Just take a look at Figure 3-28 and compare it to the Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow first lines of the CubeVertices function; since the lines that created the other vertices are very similar, we are Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API showing here just the vertices for the first two facets. Chapter 4
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 3-28: The cube 3-D coordinates for the first two facets
Sub CubeVertices(verts As CUSTOMVERTEX()) ' 1st facet --------------------------------------------------------' triangle 1 verts(0) = CreateFlexVertex(0, 0, 0, 0, 0) verts(1) = CreateFlexVertex(90, 0, 0, 1, 0) verts(2) = CreateFlexVertex(0, 90, 0, 0, 1) ' triangle 2 verts(3) = CreateFlexVertex(0, 90, 0, 0, 1) verts(4) = CreateFlexVertex(90, 0, 0, 1, 0) verts(5) = CreateFlexVertex(90, 90, 0, 1, 1) ' 2nd facet --------------------------------------------------------' triangle 1 verts(6) = CreateFlexVertex(90, 0, 0, 0, 0) verts(7) = CreateFlexVertex(90, 90, 0, 1, 0) verts(8) = CreateFlexVertex(90, 0, 90, 0, 1) ' triangle 2 verts(9) = CreateFlexVertex(90, 0, 90, 0, 1)
verts(10) = CreateFlexVertex(90, 90, 0, 1, 0) .NET Programming with DirectX 9.0 1, 1) verts(11) = Game CreateFlexVertex(90, 90, 90, by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
. . . End Sub
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Tip Observe that we have many duplicated vertices in the previous sample code. We opted to use a triangle list, since it would be difficult (and a lot less clear for our purposes) to use a composition of triangle Table of Contents strips, but in a real game it's always good practice to try to reduce the number of vertices. .NET Game Programming with DirectX 9.0
Our render procedure will have no difference from the previous samples, except for the inclusion of an Foreword
automatic generation of a rotation matrix, as defined in the game project, which will move the cube around according to the processor clock tick:
Preface
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Public Sub Render() Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Static x As Integer = 0 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Dim Tick as integer Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio If (ObjDirect3DDevice Is Nothing) Then Return Chapter 3 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
' Move the cube automatically - Magic KindergarteN. II: Animation Techniques and Speech API If chkAuto.Checked Then Chapter 8 - .Netterpillars Multiplayer Games and Directplay Tick =II:Environment.TickCount D-iNfEcT: Multithreading, Nonrectangular Windows, and to ObjDirect3DDevice.Transform.World = Access Matrix.RotationAxis(New _ Chapter 9 Nonmanaged Code Vector3(Math.Cos(Tick / 550.0F), 1, _ Bonus Chapter Porting .Nettrix to Pocket PC Math.Sin(Tick / 550.0F)), Tick / 3000.0F) AppendixEnd A - The If State of PC Gaming Chapter 7
Appendix B - Motivations in Games Appendix C ObjDirect3DDevice.Clear(ClearFlags.Target - How Do I Make Games? Or ClearFlags.ZBuffer, _ Appendix D - GuidelinesColor.FromARGB for Developing Successful Games (0, 0, 255), 1.0F, 0) Index
ObjDirect3DDevice.BeginScene()
List of Figures ObjDirect3DDevice.SetTexture(0, Textures(x))
x += 1 List of Tables If x = 10 Then x = 0 ObjDirect3DDevice.SetStreamSource(0, vertBuffer, 0) ObjDirect3DDevice.DrawPrimitives(PrimitiveType.TriangleList, 0, _ NUM_VERTS / 3) ObjDirect3DDevice.EndScene() ObjDirect3DDevice.Present() End Sub
Note that the rest of the rendering code is exactly the same as that of the previous samples. The last part of our test is to update the Transform.World matrix device member to the values set in the numeric up-down controls, as defined in our visual prototype in the project phase. Using the trick we learned in the light sample, we can create a single procedure that will handle the events for all the controls. In order to make our code more understandable, let's create three helper functions that will add the rotation, translation, and scale transformations to the world matrix. Sub Transformations_ValueChanged(sender As Object, e As EventArgs) Handles _ RotationX.ValueChanged, RotationY.ValueChanged, RotationZ.ValueChanged, _ TranslationX.ValueChanged, TranslationY.ValueChanged, _
TranslationZ.ValueChanged, _ .NET Game Programming with DirectX 9.0 ScaleZ.ValueChanged ScaleX.ValueChanged, ScaleY.ValueChanged, ISBN:1590590511 by Alexandre Santos Lobão and Ellen If Not ObjDirect3DDevice Is Nothing Then Hatton ObjDirect3DDevice.Transform.World = Matrix.Identity Apress © 2003 (696 pages) RotationMatrices(RotationX.Value, RotationY.Value, RotationZ.Value) The authors of this text show how easy it can be to produce TranslationMatrices(TranslationX.Value, TranslationY.Value, _ interesting multimedia games using Managed DirectX 9.0 and TranslationZ.Value) programming with Visual Basic .NET on Everett, the latest ScaleMatrices(ScaleX.Value, version of Microsoft's Visual Studio. ScaleY.Value, ScaleZ.Value) End If End Sub Table of Contents .NET Programming functions with DirectX 9.0 ' Game The following create the transformation matrices Foreword ' for each operation Preface Sub RotationMatrices(x As Single, y As Single, z As Single) Introduction ObjDirect3DDevice.Transform.World = _ Chapter 1
Matrix.Multiply(ObjDirect3DDevice.Transform.World, _ - .Nettrix: GDI+ and Collision Detection
Chapter 2
Matrix.RotationX(x * Math.PI / 180)) - .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
_ -ObjDirect3DDevice.Transform.World Managed DirectX First Steps: Direct3D Basics and= DirectX vs. GDI+
Chapter 4
Matrix.Multiply(ObjDirect3DDevice.Transform.World, _ - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
Math.PI / 180)) - River Pla.NetMatrix.RotationY(y II: DirectInput and Writing*Text to Screen
ObjDirect3DDevice.Transform.World = _ Matrix.Multiply(ObjDirect3DDevice.Transform.World, _ Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Matrix.RotationZ(z * Math.PI / 180)) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Sub Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Sub TranslationMatrices(x As Single, y As Single, z As Single) ObjDirect3DDevice.Transform.World = _ Appendix A - The State of PC Gaming Matrix.Multiply(ObjDirect3DDevice.Transform.World, _ Appendix B - Motivations in Games Matrix.Translation(x, y, z)) Appendix C - How Do I Make Games? End Sub Appendix D - Guidelines for Developing Successful Games Sub ScaleMatrices(x As Single, y As Single, z As Single) Index ObjDirect3DDevice.Transform.World = _ List of Figures Matrix.Multiply(ObjDirect3DDevice.Transform.World, _ List of Tables Matrix.Scaling(x / 100, y / 100, z / 100)) End Sub Bonus Chapter Porting .Nettrix to Pocket PC
The most important part of this code is to remember that we can add transformations by multiplying the matrices (using the Multiply method of the Matrix object). In the Transformations_ValueChanged event procedure, we use the Matrix.Identity function to reset any transformations in the Transform.World matrix, so we can be sure that any matrix multiplication that occurred in the last call to this function is ignored and doesn't affect the current matrices. To finish our code and start the test, all we must take care of is to provide good starting values for our matrix transformations; setting the Scale up-down controls with the default value of zero, for example, will simply make our object disappear from screen. The code for the click event on the button of the main form is as follows: Dim WinMatrixControl As New MatrixControl() Dim WinMatrixTest As New MatrixTest() WinMatrixControl.Show() WinMatrixTest.Show() ' Initialize Direct3D and the device object If Not (WinMatrixControl.InitD3D(WinMatrixTest.Handle)) Then MessageBox.Show("Could not initialize Direct3D.")
WinMatrixControl.Dispose() .NET Game Programming with DirectX 9.0 Exit Sub ISBN:1590590511 by Alexandre Santos Lobão the and Ellen ' Load the textures and create cube to show them Hatton ElseIf Not (WinMatrixControl.CreateCube()) Then Apress © 2003 (696 pages) MessageBox.Show("Could not initialize geometry.") The authors of this text show how easy it can be to produce WinMatrixControl.DisposeD3D() interesting multimedia games using Managed DirectX 9.0 and WinMatrixControl.Dispose() programming with Visual Basic .NET on Everett, the latest Exit Sub version of Microsoft's Visual Studio. End If Table of Contents ' Start with a simple rotation, to position the cube more nicely; .NET Game Programming with (100% DirectX 9.0 ' and with no scale of the original size) Foreword With WinMatrixControl Preface.RotationX.Value = 45 : .RotationY.Value = 45 : .RotationZ.Value = 45 Introduction .ScaleX.Value = 100 : .ScaleY.Value = 100 : .ScaleZ.Value = 100
End With Chapter 1 - .Nettrix: GDI+ and Collision Detection ' Ends test if Artificial ESC isIntelligence pressedand inSprites any of the 2 windows Chapter 2 the - .Netterpillars: Do While Not WinMatrixControl.EndTest And WinMatrixTest.EndTest Chapter 3 - Managed DirectX First Steps: Direct3D Basics andNot DirectX vs. GDI+ Chapter 4 WinMatrixControl.Render() - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
rateII:calculation Chapter 5 ' -Frame River Pla.Net DirectInput and Writing Text to Screen Chapter 6 Chapter 7
WinMatrixTest.Text = "Matrix Test. Frame Rate: " & CalcFrameRate.ToString - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Application.DoEvents() - Magic KindergarteN. II: Animation Techniques and Speech API
Loop - .Netterpillars II: Multiplayer Games and Directplay ' Call the finalization routines and close the windows D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 WinMatrixControl.DisposeD3D() Nonmanaged Code WinMatrixControl.Dispose() Bonus Chapter Porting .Nettrix to Pocket PC WinMatrixTest.Dispose() Chapter 8
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Appendix - How Do run I Make Now we Ccan finally the Games? test. Modifying the values of numeric up-down controls in the control window will let Appendix D -transformation Guidelines for Developing Successful Games us see the occurring dynamically; choosing the Auto Move check box will make the cube Index perform some nice moves automatically on screen. Figure 3-29 shows an example result of this last test. List of Figures List of Tables
Figure 3-29: A moving cube with a walking man in each face
Game Programming with DirectX 9.0 Adding the .NET Final Touches by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Since this chapterHatton features no games, there's no such thing as "polishing the application." But there's at Apress © 2003 (696 least one thing we can improve in pages) our samples that will surely be useful in the next chapters: finding a way to create smoothThe animations. authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and with Visual Basic .NET onrunning Everett,atthe latest Although it is veryprogramming interesting seeing our walking man a 400 steps per second, in a real game this version of Microsoft's Visual Studio. kind of behavior will be, at a minimum, strange. So we'd better define a specific frame rate to improve our graphics animation. Table of Contents Including an if command in the loop that calls the Render procedure to check the processor clock and .NET Game DirectX 9.0defined intervals will suffice to give the desired effect in our test, and just renderProgramming a new scenewith at previously Foreword maybe even in some basic games. In more sophisticated ones, where different objects can have different Preface animations running at different speeds, the control of what image must be shown at a given time will be the Introduction responsibility of each game object. Chapter 1 - .Nettrix: GDI+ and Collision Detection
So let's2get- into a practicalArtificial example. Which frame rate would be nice? Well, the best cartoons use a 32 Chapter .Netterpillars: Intelligence and Sprites frames3per- second rateFirst of animation, but usually frames per Chapter Managed(fps) DirectX Steps: Direct3D Basics16 and DirectX vs.second GDI+ provides a good frame rate.
The actual- best frame rate must be calculated for each game (or each game object), because different River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio animations require different frame rates. For instance, we can do a walking man with 5, 10, or 20 frames. Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen The more frames, the smoother the final animation will be, and the higher the frame rate must be. For our Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow specific walking man animation, the rate to acquire the best results is only 10 frames per second. So let's Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API use it! Chapter 4
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, Access to In the following code sample, we define the frame rate for theand animation by setting the number of frames Chapter 9 Nonmanaged Code variable. with the DesiredFrameRate Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Dim LastTick As Integer, DesiredFrameRate As Integer = 10
Appendix . . . B - Motivations in Games Appendix C - How I Make Games? Do While NotDo WinTransparentTest.EndTest Appendix'D Force - Guidelines for Developing Successful Games to second on maximum a Frame rate of 10 frames Index If System.Environment.TickCount - LastTick >= 1000 / DesiredFrameRate Then List of Figures WinWindowTest.Render() List of Tables
' Frame rate calculation WinWindowTest.Text = "Window Test. Frame rate: " & _ CalcFrameRate.ToString LastTick = System.Environment.TickCount
End If Application.DoEvents() Loop
The result (a screen drawn at a fixed frame rate, and a man walking at normal speed) is shown in Figure 330.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Figure Our walking man, tired of Writing running,Text nowtowalks at a lazy rate of 10 fps. Chapter 5 - 3-30: River Pla.Net II: DirectInput and Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API Note that we still continue with the loop running at full speed. In our tests, all the loop does when it's not
Chapter 8 is - .Netterpillars Multiplayer Games and rendering process the II: application events, but weDirectplay could use an else clause with this if statement to D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to process9 any Chapter - internal calculation only when the screen is not being drawn. The basic idea is shown in the Nonmanaged Code
following code:
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
If System.Environment.TickCount - LastTick >= 1000 / DesiredFrameRate Then ' Do the game scene rendering Appendix C - How Do I Make Games? Else Appendix D - Guidelines for Developing Successful Games ' Do the game physics Index ' Calculate collisions List of Figures ' Initialize anything that can help the scene to draw faster List of Tables ' and etc ... End If Appendix B - Motivations in Games
Game Programming More About.NET DirectX and GDI+with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
After learning theHatton basics and seeing the power behind the DirectX word, it's time to think how GDI+ and Apress © 2003to(696 pages) each one (or both) as a basic technology for a game project. Of DirectX fit together and how choose course there are The other technologies, OpenGL (a standard library authors of this text show how easy it can be topresent producein many platforms) being the multimedia games using Managed DirectX 9.0 and most well-knowninteresting one, but we'll stick with DirectX and GDI+ here, as they are more easily available to programming with Visual Basic .NET on Everett, the latest Visual Basic programmers. version of Microsoft's Visual Studio.
In a general way, we can say that GDI+ Table of Contents
Is a technology to draw 2-D graphics.
.NET Game Programming with DirectX 9.0
Foreword Is the "native" library for working in Windows. Preface
Is more easily portable to other simpler devices (like Pocket PC).
Introduction
Chapter 1 -use .Nettrix: GDI+ andgraphics Collisionor Detection Won't any extended acceleration features, even when there's a hardware accelerator Chapter 2 .Netterpillars: Artificial Intelligence and Sprites present. Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Is easy to work with. Tiled Game Fields, Scrolling, and DirectAudio Chapter 4 - River Pla.Net: Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
And we can say that DirectX
Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API that can be used in 2-D graphics. Is mainly aimed at working with 3-D graphics, but has many features Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay
Has special requirements to runNonrectangular games (needsWindows, installation). D-iNfEcT: Multithreading, and Access to -
Chapter 9
Nonmanaged Code more easily portable fact, some of them already work with DirectX as the BonusIsChapter Porting .Nettrixto togame Pocketconsoles—in PC
base library, and usually C/C++ is the language of choice.
Appendix A - The State of PC Gaming
Appendix - Motivations in Games CanBuse all the power of graphics acceleration devices. Appendix C - How Do I Make Games?
Needs little more for the Successful starters. Games Appendix D-a Guidelines foreffort Developing Index List of Figures List of Tables
Summary
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton In many situations choosing DirectX is a must, such as when we are coding a tridimensional game engine, (696 pages)action game that will need to use hardware acceleration features. or when we want Apress to code© 2003 a fast-paced But there are other situations in which the decision is not see some examples. The authors of this text show how easy it clear. can beLet's to produce interesting multimedia games using Managed DirectX 9.0 and Visual Basic .NET onI Everett, latest Imagine that you programming are coding a with Sid Meyer's Civilization clone. Isthe there really a need to use DirectX? version of Microsoft's Visual Studio. Remember that, although many people have 3-D boards nowadays, not everyone has one, and creating a game that doesn't require such hardware will broaden your game audience. And since a game like this isn't graphics intensive (the graphics are not very sophisticated, and the frame rate is not a problem), it'll Table of Contents be better to center our efforts on creating more sophisticated algorithms, which can run faster and make .NET Game Programming with DirectX 9.0 better gameplay. No gamer likes to wait for the computer to "think" about a better move. Foreword
Preface When talking about simpler games, like Minesweeper or Solitaire, there's no need at all to use DirectX. A Introduction simpler solution, besides providing the benefits explained in the previous paragraph, will lead to a game Chapter 1 - .Nettrix: GDI+ Collision Detection that is easier to debug andand easier to maintain, maybe resulting in a more sophisticated version. Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites
Even when about arcade when weBasics deal and with DirectX games vs. withGDI+ few animations (Breakout-like Chapter 3 - talking Managed DirectX First games, Steps: Direct3D games are- aRiver goodPla.Net: example), we can stay with GDI+ without fear of choosing the wrong platform. Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4
Chapter DirectInput Writing Text to Screen Simply 5put,- River GDI+ Pla.Net is great,II:and not only and for card games, and DirectX is really a must to create sophisticated Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, DirectShow 3-D games. 2-D games will never die, and with some gamesand DirectX will just add complexity without any Chapter - Magic KindergarteN. II: Animation Techniques and Speech reward7in exchange. So before starting any new game project, think API carefully about which platform is the Chapter - .Netterpillars II: Multiplayer Games and Directplay best for8your goals. Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
And let's highlight Nonmanaged an important Code point: We can use both techniques in a game. All we need to do is isolate the GDI+ codePorting from the DirectX one, by Bonus Chapter .Nettrix to Pocket PCnot using any GDI+ code between the BeginScene and EndScene methods. The better approach is to create a separate function for any GDI+ code, which will be Appendix A - The State of PC Gaming called after the call to the Render procedure. In fact, in DirectX 7 we could even draw directly to Appendix B - Motivations in Games DirectDraw GDI commands (and maybe we can still do something like that, accessing Appendix C - surfaces How Do I using Make Games? some nonsupported feature); but as a rule, using both techniques usually leads to less organized code, so Appendix D - Guidelines for Developing Successful Games let's just keep this idea in mind for future use, if we need it. Index List of Figures In the rest of the chapters of this book, we'll be dealing mainly with DirectX, but we'll return to GDI+ in the List of Tables last chapters, when we create a multiplayer version of the .Netterpillars game, and then again when we
port our .Nettrix game to run on a Pocket PC.
Game Programming with DirectX 9.0 Chapter .NET 4: River Pla.Net: Tiled Game Fields, Scrolling, ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton and DirectAudio Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version Microsoft's Studio. In this chapter we'll applyofthe conceptsVisual learned in the previous chapter about Direct3D to implement
Overview
DirectX gaming classes (such as GameEngine and Sprite), so we'll easily be able to create high-speed graphics games. We'll also introduce basic DirectAudio concepts that will allow us to include sound effects Table of Contents and background music in our games. .NET Game Programming with DirectX 9.0
Foreword We'll also examine the concept of tiled game fields and scrolling in games, and start implementing a clone Preface of Activision's River Raid game, a popular title for Atari 2600 and VCS. Our sample game, shown in Figure Introduction 4-1, will be finished in the next chapter, where we'll introduce DirectInput and the use of force-feedback Chapter 1 - .Nettrix: GDI+ and Collision Detection joysticks. Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List ofFigure Tables 4-1: River Pla.Net, a River Raid clone, is this chapter's sample game
Scrolling games and tile-based games have been around since earlier video game consoles and home computers hit the shelves, and we often see games that use both techniques. We'll discuss some interesting points about each in the next sections.
.NET Game Programming with DirectX 9.0 Scrolling Games by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Although the basic concept of scrolling games is very simple, there are many interesting variations we Apress 2003creating (696 pages)a new game. We can define scrolling games as the games in which must consider when we ©start the background moves in a continuous a very but it'll suffice for our goals here. The authors of this text way. showIt's how easy loose it can definition, be to produce interesting multimedia games using Managed DirectX 9.0 and programming Visual Basic .NET on Everett, thegames latest are discussed next. Some of the typical choices wewith must make when coding scrolling version of Microsoft's Visual Studio.
Scrolling Direction Table of Contents
All scrolling games are with eitherDirectX vertical scrollers, horizontal scrollers, or full scrollers, meaning that the .NET Game Programming 9.0 background on these games scroll in a vertical direction, in a horizontal direction, or in any direction. We'll Foreword discuss some variations of these movements in this section. Preface Introduction
The most common choice is to implement vertical "up-down" scrollers (as does the sample game for this
Chapter 1 where - .Nettrix: GDI+ and Collision chapter), the background movesDetection from the top to the bottom of the screen, and horizontal "right-left" Chapter 2 .Netterpillars: Artificial Intelligence scrollers, where the background moves from and rightSprites to left. We don't see many scrolling games using the Chapter 3 direction - Managed DirectX because First Steps: Direct3D and DirectX vs. GDI+ opposite schemes using these Basics directions makes our games seem more natural to Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio players. Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Full scrollers are harder to implement and to play, ADO.NET, but when made correctly, they can lead to very Chapter 6 - Magic KindergarteN.: Adventure Games, and DirectShow interesting gameplay. Just imagine a game in which players can move Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech APItheir character in any direction: This might be an interesting feature, but the player could become disorientated, and the game objective would Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay be less clear. Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Parallax Scrolling
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
ParallaxBscrolling is an in ingenious Appendix - Motivations Games trick that gives players the feeling of being in a 3-D environment, even with flat C images. Appendix - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
The basic idea is to create different layers of background objects, each one moving at different speeds. For example, if we are controlling a monkey in a jungle, we can create some bushes and trees that scroll List of Figures at the same speed as the terrain, trees a little farther off that move a little slower, distant mountains that List of moveTables very slowly, and maybe a fixed moon in the sky. Index
This approach creates a more lifelike game, but must be used with care because it can lead to visual clutter and confusion for the player. A good tip is to make distant objects with less vivid colors. This adds to the ambience without distracting the player.
Player or Engine-Controlled Scrolling When coding the scrolling for our game, we need to decide whether the background will always be moving (except, perhaps, when facing some end-of-level bosses), if it will move depending solely on the player's input, or if the movement will be a combination of both. In some scrolling games, the player is always in the same position on the screen (usually the middle), and the background rolls according to the player's movement: When a player moves the joystick to the right, his or her character walks to the right (moving in a fixed position), while the background moves to the left. Many race games use this approach. Some games use a similar solution: A player walks freely in a restricted area, and when he or she gets near any border, the background starts to move until the player starts walking back toward the center of the screen. Some other games use a combination of automatic scrolling with player-controlled scrolling; the player controls scrolling right or left, but is always moving from the top to the bottom of the screen.
One last group of games comprises the auto-scrolling ones, such as the sample we'll code in this chapter: Game Programming with DirectX 9.0 The background .NET simply goes on scrolling without player intervention, creating a nonstop action game. by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Choosing the Scrolling Type
The authors of this text show how easy it can be to produce
Even a topic as simple as choosing thegames scroll type shouldDirectX use in our interesting multimedia usingwe Managed 9.0 game and may lead to extensive discussion. Of course programming there's awith lot more Visualwe Basic can.NET do when on Everett, codingthe scrolling latest games; don't be reluctant to try version of Visual Studio. new ideas. For example, weMicrosoft's can split the screen and make two areas with different scrolling behaviors, such as in the old arcade game Olympics, where the computer controls a character running in the upper middle of the screen and the player runs in the lower middle; each half-screen scrolls with its own speed.
Table of Contents
.NET withofDirectX 9.0will vary from game to game, and it will be up to us to make the TheGame most Programming appropriate type scrolling Foreword final choice between code complexity and game playability. Preface Introduction
Technical Tips for Scrolling Implementation - .Nettrix: GDI+ and Collision Detection
Chapter 1
Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites a "camera" moving over a big image through to Since there are many ways to implement scrolling—from Chapter 3 - Managed First Steps: Basicsno anduniversal DirectX vs. GDI+ However, keep in mind the the opposite extreme,DirectX scrolling based onDirect3D tiles—there's solution. Chapter 4 rules - River Tiled Game Fields, Scrolling, and DirectAudio following of Pla.Net: thumb as design goals: Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen
Avoid images from disk exactlyGames, when they are needed. Although it may not be practical to load Chapter 6 -loading Magic KindergarteN.: Adventure ADO.NET, and DirectShow all images at the start of the game, try to load the images before they're needed; never depend on - Magic KindergarteN. II: Animation Techniques and Speech API disk response time, or the game will probably lack smoothness.
Chapter 7 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Windows, and Access to for the game when it starts is On9the- other hand, loading everyNonrectangular image and creating every vertex buffer Chapter Nonmanaged Code
only practical in small game fields. In bigger games memory can run out in a short time; so balance memory use against the loading speed of the images. A simple technique to avoid memory shortage Appendix A - Thethe State of PC Gaming is dividing game into levels, and loading the images only for the current level. While the user is Appendix B Motivations in Games distracted with a screen with the current score or a short message, the next level can be loaded. Bonus Chapter Porting .Nettrix to Pocket PC
Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Tile-Based .NET Games by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton A tile is just a small piece of a graphic with a certain property that reveals its status for the game (a Apress ©an 2003 (696 pages) background, an enemy, obstacle, a ladder, etc.). Creating a tiled game field is simply a matter of putting the tiles together in a logical fashion. doitthis a level-map file with a level The authors of this text showWe howcan easy canby becreating to produce games using DirectX 9.0the andtile codes in the file to graphical designer or even interesting with a text multimedia editor; our game, when Managed running, translates tiles on screen. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
When coding tile-based games, the first question to ask is, Will our tiles be clearly visible, or will we try to hide the repetitive patterns? Table of Contents .NET Game with DirectX 9.0 There's noProgramming correct answer—it just depends on the game. Foreword
If we're working with a game that deals with visible blocks or bricks, there's no special trick to use when Preface creating the tiles: We can simply list the tiles we'll use and draw them. Drawing some extra tiles can help Introduction the game look more interesting to theDetection user. Chapter 1 to - .Nettrix: GDI+ and Collision Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
However, using seamless tiles is another matter. The following sections offer some practical tips for when - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ we need seamless tiles.
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Draw6 the Basic Tile Sets Chapter - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow When creating a new tile set, we first draw the basic tiles for each type of terrain: for example, one tile for .Netterpillars II: Multiplayer Games and Directplay water, one- tile for grass, one tile for sand, etc. An example of a basic set is show in Figure 4-2.
Chapter 8 Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List ofFigure Figures4-2: A basic set of tiles, comprising two terrain types List of Tables
With the tiles presented in Figure 4-2 and in other figures in this chapter, we include suggested filenames. Using a logical filenaming scheme for your tiles can help you easily find specific tiles when you need them. Keeping an eye on our "budget" of memory (how much memory we can use for textures), let's create some simple variations, such as adding different patterns to a sand tile, or some little bushes or small stones to a grass tile. We should review our basic set, using the game project as a guide, to be sure that we create a tile for every terrain or object we need. Once we are satisfied with our basic set, we can go on to the next step: creating border tiles.
Create Border Tiles To create border tiles, we must separate the tiles into groups that will have connections with each other, and then create the borders for the tiles in each group. We must do this because usually some tiles won't need to have borders with some of the others—for example, the tiles that will create internal parts of a building don't need to have any special border with the outside tiles. Within every group, create the border tiles between each type of terrain. There are basically three types of borders we can create, as shown in Figure 4-3: Border tiles: With this kind of tile, one terrain type occupies almost all of the area of each tile, leaving
just few pixels for the transition to the next terrain.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
3/4-to-1/4 tiles: Hatton One terrain occupies 3/4 of the tile and another terrain occupies the rest for this tile type. (Think about Apressthis © 2003 texture (696 pages) as cutting a tile in four equal-sized squares and filling three of them with one type of terrain, and one with another.) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Half-to-half tiles: this kind ofVisual tile, each type of terrain occupies half of the tile; the transition versionWith of Microsoft's Studio.
between terrain types can be on the vertical, horizontal, or diagonal axis. Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction
Figure Example border tilesDetection Chapter 1 - 4-3: .Nettrix: GDI+ of and Collision Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
These basic border tiles will suffice to create a continuous-looking terrain, but if we have many of these - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ transition tiles presented to the player on every screen, the set still won't suffice to create an illusion of a Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio nontiled terrain. That's why we need to create extra borders between the most-used terrain types. Chapter 3 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Include- Magic Extra Transition Tiles KindergarteN. II: Animation Techniques and Speech API
Chapter 7 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay For those transitions that will be presented most of the time to the player, include some different tiles for D-iNfEcT: Windows, and to Access each transition and forMultithreading, the basic set, Nonrectangular which will be used sparingly breaktodown the feeling of patterns of Chapter 9 Nonmanaged Code repetition. For example, when creating tiles between water and land, include some rocks, a bay, or a Bonus Chapter Porting .Nettrix to Pocket PC larger beach, so you can use them eventually to give more variation to the game visual. Examples of Appendix A - The State of PC Gaming simple variations are shown in Figure 4-4. Appendix B - Motivations in Games
Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 4-4: Simple variations of border tiles To create a better set of tiles, test if the transitions for each tile are seamless in every direction (when we rotate the tiles). An improved game engine can use the same tiles with various rotations to achieve better results. An easy way to do this is to create some tiles with only borders (and a flat color at the middle), and use them as "masks" over other tiles, employing any graphical editor to hide the transitions between the base tiles and the masks. Ensuring that the border pixels are always the same will allow smooth transitions. In Figure 4-5 we see part of a screen from Sid Meyer's Civilization. Although the terrain looks random at first glance, if we pay a little more attention we can see the same tiles used in different compositions, with great results.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction
Figure Civilization— successful example of a tile-based game Chapter 1 - 4-5: .Nettrix: GDI+ and aCollision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Game Programming Creating New Classes with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton amongst the test programs we did in Chapter 3, we can choose some parts of the Looking at the similarities code to create DirectX Apressversions © 2003 (696 forpages) the two basic game classes we created in Chapter 2: a GameEngine class, which will be responsible for initializing, andit managing the device operations, and a Sprite class, The authors of this text terminating, show how easy can be to produce multimedia games using Managed DirectX 9.0 and or otherwise) from image files. which will create interesting some vertices and load the images as textures (transparent programming with Visual Basic .NET on Everett, the latest of Microsoft's Visual Studio.used in Chapter 2, but since using Direct3D is very different Note We'll tryversion to maintain the class interfaces
from using GDI+, don't be surprised if we find new ways to do the same things. Table Contents We'llofalso extend our game class library by creating a GameMusic class according to the basic concepts we'll .NET Game Programming DirectX 9.0 interface. examine when studying with the DirectAudio Foreword Preface
The GameEngine Class
Introduction
Chapter 1 -the .Nettrix: GDI+ and Collision To create new GameEngine class,Detection we'll use the lessons learned in Chapters 1 and 2 about game engines, Chapter 2 .Netterpillars: Artificial Intelligence and Sprites plus the Direct3D concepts discussed in Chapter 3. The following sections present the concepts involved in the Chapter Managed creation3 of- this class.DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter The Class 5 - River Interface Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
To include- all we learned from the previous chapter, the GameEngine class must have some objects that will Magic KindergarteN. II: Animation Techniques and Speech API store references to Direct3D objects and a reference to the DirectAudio object (which controls the game music Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay and sound effects, as we'll see). Another common theme we can see in the samples of the previous chapter is D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter the use9of -flexible vertex formats to define figure vertices when creating a device, as well as the use of a Nonmanaged Code background color when clearing the Bonus Chapter Porting .Nettrix to Pocketdevice. PC Chapter 7
Appendix A - The State of PC Gaming
Looking to the game engines from the samples of Chapters 1 and 2, we can again see some common
Appendix B - such Motivations Gameshandle used for drawing, the width and height of the game field, and some flags properties, as the in window Appendix C How Do I Make Games? to control whether the game is over or paused. Appendix D - Guidelines for Developing Successful Games
Looking again at the samples in Chapter 3, we can see a repetitive pattern in every Direct3D application. This Index gives us some clues about possible methods to include in our new GameEngine class: List of Figures List of 1.Tables Initialize the various Direct3D objects.
2. Enter a loop that will call the Render procedure between BeginScene and EndScene methods. 3. Dispose all Direct3D objects created. With these ideas in mind, we can imagine three methods that can be called sequentially in a game, as shown in the pseudo-code here: Dim MyGameEngine as clsGameEngine ... ' Initialize Direct3D and DirectAudio objects MyGameEngine.Initialize ' Start the game loop, the procedure will only return when the game is over MyGameEngine.Run ' Dispose the Direct3D and DirectAudio objects MyGameEngine.Finalize
We'll need a fourth method: an empty Render method that will be called from within a loop on the Run method. Each game will create a new class, derived from the generic GameEngine class, that will implement theRender procedure and add any extra features to the Initialize and Finalize methods.
.NET Game Programming with DirectX Note For more information on flexible vertices and the9.0 objects and the methods mentioned in the preceding ISBN:1590590511 byChapter Alexandre text, see 3. Santos Lobão and Ellen Hatton
The suggested interface the GameEngine class is shown in Figure 4-6; when creating new games, we can Apress ©for 2003 (696 pages) improve the classThe as authors needed.of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List ofFigure Tables 4-6: The GameEngine class interface
The description of the interface members of the GameEngine class are shown in Table 4-1. Table 4-1: Interface Members of the DirectX GameEngine Class
TYPE
NAME DESCRIPTION .NET Game Programming with DirectX 9.0
Property
ObjDirect3DDevice Hatton
TheDevice object, used by all graphical operations.
Property
Apress © 2003 (696 pages) BackgroundColor
The color used when clearing the device.
by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Property
The authors of this text show how easy it can be to produce Width of theDirectX game 9.0 field. interesting multimedia games The usingwidth Managed and programming with Visual Basic .NET on Everett, the latest Height The height of the game field. version of Microsoft's Visual Studio.
Property
ScreenWinHandle
Property
Table of Contents GameOver
Property
.NET Game Programming with DirectX 9.0
Property Foreword
Paused
Preface Introduction
The window handle used by all drawing functions. If true, the game is over. If true, the game is paused. This flag and the preceding one store the current game status. Each game uses these flags to end or pause the game.
Chapter 1 - .Nettrix: GDI+ and Collision Detection FVF_CustomVertex Constant The constant that will define which flexible vertex format Chapter 2 - .Netterpillars: Artificial Intelligence and we'llSprites be using when creating the device and the vertices of Chapter 3
- Managed DirectX First Steps: Direct3D the Basics sprites.and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
IMAGE_PATH and SOUND_PATH
Constants
Chapter 6
The relative paths where the images and the sound files are stored.
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Initialize Method The procedure that willAPI initialize Direct3D. Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Method
Render
The rendering procedure. This procedure will be an empty
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to overrideable function that must be implemented in the Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix MethodA - TheFinalize State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Method
Run
derived classes.
This method will dispose any objects created in the initialize procedure. This method will simply have a BeginScene-EndScene block inside a loop, allowing the game programmer to start the game by calling the Run method.
Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
The next code listing shows the definition of the GameEngine class, including the proposed properties, methods, and constants: Imports Microsoft.DirectX.Direct3D Imports Microsoft.DirectX Public Class clsGameEngine Protected Shared objDirect3DDevice As Device = Nothing ' Simple textured vertices constant and structure Public Const FVF_CUSTOMVERTEX As VertexFormat = VertexFormat.Tex1 Or _ VertexFormat.Xyz ' defines the default background color as black Public BackgroundColor As Color = Color.FromArgb(255, 0, 0, 0) ' Images path, to be used by the child classes Protected Const IMAGE_PATH As String = "Images" Public Structure CUSTOMVERTEX Public X As Single Public Y As Single Public Z As Single
Public tu As Single .NET Programming with DirectX 9.0 Public tvGame As Single by Alexandre Santos Lobão and Ellen End Structure
ISBN:1590590511
Hatton Apress © 2003 (696 pages)
Public Width As Integer = 25 The authors this text show Public Height As of Integer = 25how easy it can be to produce
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Private ScreenWinHandle As System.IntPtr version of Microsoft's Visual Studio.
' Controls the game end Table ofPublic Contents Shared GameOver As Boolean .NET Game Programming DirectXAs 9.0Boolean Public Sharedwith Paused Foreword PrefaceSub Run() Introduction Public Overrideable Sub Render()
Function Initialize(Owner As windows.forms.control) As Boolean ChapterPublic 1 - .Nettrix: GDI+ and Collision Detection Overrides Finalize() ChapterProtected 2 - .Netterpillars: Artificial Sub Intelligence and Sprites End Class Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API NEW IN TheImports clause used in the beginning of the class is a new feature of Visual Basic .NET, and it allows us to use any of the objects of the imported namespace directly, without needing to inform D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - the full object hierarchy. For example, instead of creating a Microsoft.DirectX. Direct3.D .Device Nonmanaged Code object, we can simply use Device in our variable declarations. Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay .NET
Bonus Chapter Porting .Nettrix to Pocket PC
Appendix A - Thethe State of for PC the Gaming Before writing code class methods, let's ensure that we understand the scope modifiers used in the Appendix GameEngine B - Motivations class, asinexplained Games in the next section. Appendix C - How Do I Make Games?
Understanding the Modifiers Appendix D - Guidelines for Scope Developing Successful Games Index
Now is a good time to look at the scope keywords used before variable and method declarations, and used extensively in the GameEngine class:
List of Figures List of Tables
Private: Visible only inside the class Protected: Visible only to the class and its derived classes Public: Visible to any code outside and inside the class Other keywords used in this context are Shared: Any member declared with this keyword is shared with all the objects created for the class, and can be accessed directly by the class name (we don't need to create objects). Constants are shared by default, even when we don't use the shared keyword. Overrideable: This keyword indicates that a class member can be overridden by derived classes. In the preceding sample code, the Render procedure must be an overrideable function, since the code for it will be supplied by the derived classes, although it will be called by the Run method in the base class. Overrides: This keyword indicates that the class member is overriding a corresponding member of the base class. For example, to code a working Finalize event for any Visual Basic .NET class, we need to override the base class event Finalize. Shadows: When we want to redefine a function in a derived class, we can use this keyword. In this case, we aren't overriding a member from the base class, so when the method is called from the derived class, the method of this class will be called, and when a call is made from the base class, the method of the base class is called.
In the next section.NET we'llGame examine the code forwith eachDirectX method9.0 of the GameEngine class. Programming by Alexandre Santos Lobão and Ellen
Coding the Class Hatton Methods
ISBN:1590590511
Apress © 2003 (696 pages)
There are no newThe concepts in these methods, so we can simply copy the code from one of the samples in the authors of this text show how easy it can be to produce previous chapter interesting and organize it as methods the Managed GameEngine class. As previously explained, we have an multimedia games of using DirectX 9.0 and Initialize method to do thewith initialization (as.NET we saw in Chapter 3) for a full-screen application using an programming Visual Basic on Everett, the latest of Microsoft's Visual Studio. of the objects created, and the Run method has the orthogonal view. version The Finalize method disposes rendering loop, used in all programs in Chapter 3, that calls the empty Render method for each loop interaction. The Render method will be coded in the derived class, which will include specific features for each Table of Contents game. .NET Game Programming with DirectX 9.0 Foreword
Sub Run() Do While Not GameOver Introduction If (objDirect3DDevice Is Nothing) Then Chapter 1 - .Nettrix: GDI+ and Collision Detection GameOver = True Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Exit Sub Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ End If Chapter 4 -objDirect3DDevice.Clear(ClearFlags.Target, River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio BackgroundColor, 1.0F, 0) Chapter 5 -objDirect3DDevice.BeginScene() River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6 -'Magic KindergarteN.: Adventure andimplemented DirectShow Calls the Render sub, Games, whichADO.NET, must be on the derived classes Chapter 7 -Render() Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8 -objDirect3DDevice.EndScene() .Netterpillars II: Multiplayer Games and Directplay Try D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Nonmanaged Code objDirect3DDevice.Present() Bonus Chapter Porting .Nettrix to Pocket PC Catch Appendix A - The State of PCerror Gaming ocurred, possibly in the Render procedure ' Some Appendix B -End Motivations Try in Games Appendix C -Application.DoEvents() How Do I Make Games? Loop Appendix D - Guidelines for Developing Successful Games End Sub Index Public Overrideable Sub Render() List of Figures ' This sub is specific for each game, List of Tables ' and must be provided by the game engine derived class End Sub Preface
Public Function Initialize(Owner as Windows.Forms.Control) As Boolean Dim WinHandle As IntPtr = Owner.handle Dim objDirect3Dpp As PresentParameters Initialize = True Try DispMode = Manager.Adapters(_ Manager.Adapters.Default.Adapter).CurrentDisplayMode DispMode.Width = 640 DispMode.Height = 480 ' Define the presentation parameters objDirect3Dpp = New PresentParameters() objDirect3Dpp.BackBufferFormat = DispMode.Format objDirect3Dpp.BackBufferWidth = DispMode.Width objDirect3Dpp.BackBufferHeight = DispMode.Height objDirect3Dpp.SwapEffect = SwapEffect.Discard objDirect3Dpp.Windowed = True 'False ' Create the device objDirect3DDevice = New Device(_
Manager.Adapters.Default.Adapter, _ .NET Game Programming with DirectX 9.0_ DeviceType.Reference, WinHandle, ISBN:1590590511 by Alexandre Santos Lobão and Ellen CreateFlags.SoftwareVertexProcessing, objDirect3Dpp) Hatton Apress © 2003 (696 pages)
' Tells the device which is the format of our custom vertices The authors of this text show how easy=it FVF_CUSTOMVERTEX can be to produce objDirect3DDevice.VertexFormat interesting multimedia games using Managed DirectX 9.0 and ' Turn off culling => Basic front and back of programming with Visual .NET on Everett, the the latesttriangles are visible objDirect3DDevice.RenderState.CullMode = Cull.None version of Microsoft's Visual Studio. ' Turn off lighting objDirect3DDevice.RenderState.Lighting = False Table of Contents ' Turn on alpha blending, for transparent colors in sprites .NET Game Programming with DirectX 9.0 objDirect3DDevice.RenderState.SourceBlend = Blend.SourceAlpha Foreword objDirect3DDevice.RenderState.DestinationBlend = Blend.InvSourceAlpha Preface ' The sprite objects must turn on alpha blending only if needed, Introduction ' using the following line: objDirect3DDevice.RenderState.AlphaBlendEnable = True Chapter 1 -'.Nettrix: GDI+ and Collision Detection Set the Artificial Projection Matrix to use a orthogonal view Chapter 2 -'.Netterpillars: Intelligence and Sprites = vs. Matrix.OrthoOffCenterLH(0,_ Chapter 3 -objDirect3DDevice.Transform.Projection Managed DirectX First Steps: Direct3D Basics and DirectX GDI+ 0, DispMode.Height, 0.0F, 0.0F) Chapter 4 - RiverDispMode.Width, Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio de Pla.Net As DirectXException ChapterCatch 5 - River II: DirectInput and Writing Text to Screen MessageBox.Show("Could not initialize Direct3D. Error: " & _ Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow de.ErrorString, "3D Initialization.", MessageBoxButtons.OK, _ Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API MessageBoxIcon.Error) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Initialize = False D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterEnd 9 -Try Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
' Dispose the used objects DispMode = Nothing Appendix B - Motivations in Games objDirect3Dpp = Nothing Appendix C - How Do I Make Games? End Function Appendix A - The State of PC Gaming
Appendix D - Guidelines for Developing Successful Games Index Protected Overrides Sub Finalize() List of Figures On Error Resume Next ' We are leaving, ignore any errors List of Tables
If Not (objDirect3DDevice Is Nothing) Then objDirect3DDevice.Dispose() objDirect3DDevice = Nothing GC.Collect() MyBase.Finalize() End Sub
In the initialize procedure, we used a set of common parameters for the device creation; we can change it as needed for each application. In the next section we'll see the upgraded code for the second game class of our library: the Sprite class.
The Sprite Class Here we'll attempt to create a generic Sprite class, which can be improved upon as needed, and can be used to create derived classes that can hold specific properties and methods according to the game being created. We can use the basic interface for sprites defined in Chapter 2, with the New,Draw, and Load methods, and some simple properties. Looking back at Chapter 3, we can list some suggestions for other interface elements: values for the translation, scaling, and rotation operations in the x and the y axis, and a speed value for both axes (speed is just the counter to be used for the translation in every new frame drawn).
Because a sprite is drawn over a polygon, we'll need a property to store the vertex buffer and a helper function .NET Game Programming with DirectX 9.0 to create the flexible vertices. Because a sprite is a 2-D image, there's no need to store z values for the ISBN:1590590511 transformations. by Alexandre Santos Lobão and Ellen
Hatton Apress © 2003 (696 pages) Tip An important point of this new Sprite class is that we'll never need to change the vertex coordinates of authors of this text show or how easy it can touse produce the spriteThe to perform any translations rotations; webe can the matrix transformations as seen in interesting multimedia games using Managed DirectX 9.0 and Chapter 3 to do it faster. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Note For more information about flexible vertices, vertex buffers, and matrices, refer to Chapter 3. The complete interface for a Direct3D sprite is shown in Figure 4-7.
Table of Contents
.NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List ofFigure Figures4-7: The Sprite class interface List of Tables
TheSprite class members are described in Table 4-2. Table 4-2: Interface Members for the DirectX Sprite Class TYPE
NAME
DESCRIPTION
Properties
X and Y
The upper-left position of the sprite.
Properties
SizeX and SizeY
The size of the sprite, in the x and y axes.
Property
IsTransparent
If true, the Draw function will draw a transparent sprite, loaded in the Load function. We don't need to store a color key property to say which color will be transparent; such a color is used only when loading the textures.
Property
Direction
The current direction the sprite is moving in. This property can be used to choose which image must be drawn.
Constant
IMAGE_SIZE
The default size for a square sprite.
Property
ScaleFactor
Same as the GDI+ Sprite class, it holds a constant used when creating the sprite, indicating whether the x and y values are pixel values or based on IMAGE_SIZE. Useful for creating tiled game fields.
Properties
SpeedX and SpeedY The speed (translation increment per frame) of the sprite .NET Game Programming with DirectX 9.0 on the x and y axes. ISBN:1590590511 by Alexandre Santos Lobão and Ellen
Properties
TranslationX and Apress © 2003 (696 pages) TranslationY
Properties
interesting using Managed andsprite in each axis. ScaleX andmultimedia ScaleY gamesThe scale to be DirectX applied9.0 to the
Properties
RotationX version of Microsoft's and Visual Studio. The rotation in each axis. RotationY
Hatton
The current translation value in each axis, from the initial x,y position.
The authors of this text show how easy it can be to produce programming with Visual Basic .NET on Everett, the latest
SpriteImage Table Property of Contents .NET Game Programming with DirectX 9.0
Property
Foreword
Method Preface Introduction
Method
The sprite texture, loaded from an image file.
VertBuffer
The vertex buffer with the vertices of the sprite.
New
Method for creating a new sprite.
Load
Method for loading the image file from disk; it creates the vertices used to draw the image on the screen.
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
DrawDirectX First Steps: Direct3D Method Method thatand draws the vs. sprite. Chapter 3 - Managed Basics DirectX GDI+ Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Dispose Method Method that disposes of the texture and the vertex buffer Chapter 5 - River Pla.Net II: DirectInput and Writing Text Screen used by thetosprite. Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow CreateFlexVertex Method method when Chapter 7 - Magic KindergarteN. II: Animation Helper Techniques and used Speech API creating the sprite vertex buffer. Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Nonrectangular Windows, and Access to The interface code forMultithreading, the Sprite class is shown here: Chapter 9 Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
Imports Appendix A -Microsoft.DirectX.Direct3D The State of PC Gaming Public Class clsSprite Inherits clsGameEngine
Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index
Public IsTransparent As Boolean = False Public Direction As enDirection
List of Figures
List of Tables Public X As Single
Public Y As Single Public SizeX As Single = IMAGE_SIZE Public SizeY As Single = IMAGE_SIZE Public Const IMAGE_SIZE As Integer = 32 Public ScaleFactor As enScaleFactor = enScaleFactor.enScaleSprite ' speed used in translation Public SpeedX As Single = 0 Public SpeedY As Single = 0 ' Values used for the operations Public TranslationX As Single = 0 Public TranslationY As Single = 0 Public ScaleX As Single = 1 Public ScaleY As Single = 1 Public RotationX As Single = 0 Public RotationY As Single = 0 Protected SpriteImage As Texture Protected VertBuffer As VertexBuffer Public Enum enScaleFactor enScalePixel = 1
enScaleSprite = IMAGE_SIZE End Enum .NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen Public Enum enDirection Hatton North = 1 Apress © 2003 (696 pages) NorthEast = 2 East The = 3authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and SouthEast = 4 with Visual Basic .NET on Everett, the latest programming Southversion = 5 of Microsoft's Visual Studio. SouthWest = 6 West = 7 Table of Contents NorthWest = 8 .NET Game with DirectX 9.0 End Programming Enum Foreword Sub New(...) PrefaceFunction Load(...) As Boolean Introduction Private Function CreateFlexVertex(...) As CUSTOMVERTEX ChapterSub 1 -Draw() .Nettrix: GDI+ and Collision Detection Sub Dispose() ChapterPublic 2 - .Netterpillars: Artificial Intelligence and Sprites End Class Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 9
-
We must highlight two points in the preceding code: the use of default values for the properties (always use the Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow most common ones), and the use of the inherits clause. The Sprite class will be closely related to the Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API game engine, and it'll need to use some of the game engine properties to work properly, so we must create it as Chapter 8 - .Netterpillarsclass. II: Multiplayer Games and Directplay aGameEngine-derived D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Let's see theNonmanaged code for theCode methods, starting with the New method. We'll create two overrides for the function: Bonus Chapter Porting .Nettrix to Pocket PC one for creating opaque sprites, and another for creating transparent sprites. The following code sample depicts Appendix A - Thebetween State of these PC Gaming the difference two overrides: Appendix B - Motivations in Games Appendix C - How Do I Make Games? Sub New(strImageName As String, startPoint As POINT, _ Appendix D -Optional Guidelines forScale Developing Games As Successful enScaleFactor = enScaleFactor.enScaleSprite, _ Index Optional width As Integer = IMAGE_SIZE, _ List of Figures Optional
height As Integer = IMAGE_SIZE)
X = startPoint.x List of Tables Y = startPoint.y SizeX = width SizeY = height ScaleFactor = Scale If Not Load(strImageName) Then _ Err.Raise(vbObjectError + 1, "clsSprite", _ "Could not create the sprite textures") End Sub Sub New( strImageName As String, colorKey As Integer, startPoint As POINT, _ Optional Scale As enScaleFactor = enScaleFactor.enScaleSprite, _ Optional width As Integer = IMAGE_SIZE, _ Optional height As Integer = IMAGE_SIZE) ' When calling the New procedure with a colorKey, ' we want to create a transparent sprite IsTransparent = True X = startPoint.x Y = startPoint.y SizeX = width SizeY = height ScaleFactor = Scale If Not Load(strImageName, colorKey) Then _
Err.Raise(vbObjectError + 1, "clsSprite", _ .NET Game Programming with DirectX 9.0 "Could not create the sprite textures") by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
End Sub
ISBN:1590590511
The will authors of this showcolorKey how easy itparameter can be to produce TheLoad procedure receive an text optional that will be used to load a transparent interesting multimedia Managed DirectX 9.0the and texture if the IsTransparent propertygames is set using to true. Besides loading texture from an image file, the Load programming with Visual Basic .NET on Everett, the latest procedure must create the vertex buffer used to show the sprite in the draw procedure, using the version of Microsoft's Visual Studio. CreateFlexVertex helper procedure. Table of Contents ' Default colorKey is magenta .NET Game with DirectX 9.0 FunctionProgramming Load(strImageName As String, _ Foreword Optional colorKey As Integer = &HFFFF00FF) As Boolean PrefaceDim vertices As CustomVertex() Introduction Dim i As Integer Chapter 1 - .Nettrix: GDI+ and Collision Detection ChapterTry 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
IsTransparent ThenDirect3D Basics and DirectX vs. GDI+ -If Managed DirectX First Steps:
Chapter 4
texture - River 'Load Pla.Net: the Tiled transparent Game Fields, Scrolling, and DirectAudio
Chapter 5
= TextureLoader.FromFile(objDirect3DDevice, _ - RiverSpriteImage Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
Application.StartupPath & "\"and & DirectShow IMAGE_PATH & "\" & strImageName, _ - Magic KindergarteN.: Adventure Games, ADO.NET,
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
64, 64, D3DX.Default, 0, Format.Unknown, Pool.Managed, _ Filter.Point, Filter.Point, colorKey)
Else
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to SpriteImage = TextureLoader.FromFile(objDirect3DDevice, _ Nonmanaged Code
Application.StartupPath & "\" & IMAGE_PATH & "\" & strImageName)
Bonus Chapter Porting .Nettrix to Pocket PC
End If
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
VertBuffer = New VertexBuffer(GetType(CustomVertex), 4, _ objDirect3DDevice, Usage.WriteOnly, FVF_CUSTOMVERTEX, Pool.Default) Appendix D - Guidelines for Developing Successful Games vertices = VertBuffer.Lock(0, 0) Index ' CreateFlags a square, composed of 2 triangles in a triangle strip List of Figures vertices(0) = CreateFlexVertex(X * ScaleFactor, Y * ScaleFactor, 1, 0, 1) List of Tablesvertices(1) = CreateFlexVertex(X * ScaleFactor + SizeX, _ Y * ScaleFactor, 1, 1, 1) vertices(2) = CreateFlexVertex(X * ScaleFactor, _ Y * ScaleFactor + SizeY, 1, 0, 0) vertices(3) = CreateFlexVertex(X * ScaleFactor + SizeX, _ Y * ScaleFactor + SizeY, 1, 1, 0) ' Release the vertex buffer and commits our vertex data VertBuffer.Unlock() Return True Catch de As DirectXException MessageBox.Show("Could not load image file " & strImageName & _ ". Error: " & de.ErrorString, "3D Initialization.", _ MessageBoxButtons.OK, MessageBoxIcon.Error) Return False End Try End Function Appendix C - How Do I Make Games?
Function CreateFlexVertex( X As Single, Y As Single, Z As Single, _ tu As Single, tv As Single) As CUSTOMVERTEX CreateFlexVertex.X = X CreateFlexVertex.Y = Y CreateFlexVertex.Z = Z CreateFlexVertex.tu = tu
CreateFlexVertex.tv = tv End Function .NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton 2003 (696 pages) TheDraw methodApress is very© straightforward: It simply sets the texture and draws the rectangle defined by the The authors of this text show using how easy it can be to produce vertex buffer created in the Load procedure, the concepts shown in the previous chapter. interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Sub Draw() version of Microsoft's Visual Studio.
' Turn on alpha blending only if the sprite has transparent colors If IsTransparent Then Table of Contents objDirect3DDevice.RenderState.AlphaBlendEnable = True .NET Game with DirectX 9.0 End Programming If Foreword Try Preface objDirect3DDevice.SetTexture(0, SpriteImage) Introduction objDirect3DDevice.SetStreamSource(0, VertBuffer, 0) Chapter 1 -objDirect3DDevice.DrawPrimitives(PrimitiveType.TriangleStrip, .Nettrix: GDI+ and Collision Detection 0, 2) de As DirectXException ChapterCatch 2 - .Netterpillars: Artificial Intelligence and Sprites not draw Chapter 3 -MessageBox.Show("Could Managed DirectX First Steps: Direct3D Basics sprite. and DirectXError: vs. GDI+ " & de.ErrorString, _ "3D Pla.Net: Initialization.", MessageBoxIcon.Error) Chapter 4 - River Tiled Game Fields, MessageBoxButtons.OK, Scrolling, and DirectAudio ChapterEnd 5 -Try River Pla.Net II: DirectInput and Writing Text to Screen off alpha blending the ADO.NET, sprite and hasDirectShow transparent colors Chapter'6 Turn - Magic KindergarteN.: Adventureif Games, If IsTransparent Then Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API objDirect3DDevice.RenderState.AlphaBlendEnable = False Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End If D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 End Sub Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix - Motivations in Games The lastBmethod, Dispose, will only dispose of the texture and the vertex buffer created in the Load procedure. Appendix C How Do I Make Games? Calling the Collect method of the garbage collector will ensure a faster disposal of memory; and calling the Appendix D - Guidelinesmethod for Developing Successful Games errors that can arise if the default finalizer is called before SupressFinalize of this class will prevent Index the objects are freed from memory. The Dispose method is shown in the next code sample: List of Figures List ofPublic Tables Sub Dispose()
On Error Resume Next ' We are leaving, ignore any errors SpriteImage.Dispose() VertBuffer.Dispose() GC.Collect() GC.SuppressFinalize(Me) End Sub
DirectAudio Classes There are two different sets of components for audio input and output: DirectMusic, for background music playback, and DirectSound, for sound effects. These two sets together are sometimes called DirectAudio, although they are separate things. DirectMusic doesn't have a managed version, but we can access its features through COM interoperability. NEW IN .NET is kind of an evolution from COM architecture; but we still can use COM objects from .NET .NET programs, and more: The .NET programs generate COM wrappers, so COM-based languages (such as the previous version of Visual Basic) can access .NET components too. To use nonmanaged DirectX features, we must include in our projects a reference to the VBDX8.DLL. Besides the components for audio playback, DirectAudio includes DirectMusic Producer, which can be used to create new music based on chord maps, styles, and segments. We'll not enter into any details about
DirectMusic Producer here, but if you want to exercise your composing skills, you'll find a lot of relevant material in DirectX SDK. .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton The main distinction between background music and sound effects is related to the file types used by each one. © 2003 pages) Sound effect filesApress are MIDI or (696 WAV files that store a single piece of sound that is usually played when a specific authors this show how aeasy it can to produce action occurs in aThe game (suchofas a text player getting bonus or be dying). Background music can be produced using usingsegment Managed(SGT) DirectXfiles. 9.0 SGT and files have a main piece of music a MIDI file playinginteresting in a loop, multimedia but it's bestgames done with programming with Visual Basic .NET on Everett, the latest and one or more version motifs (or waves) that can be played any time, as the program commands, so the music can of Microsoft's Visual Studio. change subtly from time to time.
A special music generation program is included with DirectX SDK, and it allows professional Table Note of Contents to create segment .NET Game musicians Programming with DirectX 9.0 files by connecting the computer to a music device (like a keyboard), or composing the music directly on the computer using instruments from the predefined libraries or even creating new ones. It's beyond the scope of this book to enter into details about the creation of Preface segment files, but those who want to get a deeper knowledge of this subject will find many samples in Introduction the DirectMusic help feature on the DirectX SDK. Foreword
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter - .Netterpillars: Artificial Intelligence and Sprites A lot of2theory and technical details are connected to DirectAudio, but we'll stick here to the simplest ways of Chapter 3 - sound Managed First Steps: Direct3D Basics and DirectX vs. GDI+ generating for DirectX our application. Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio There aren't many steps II: weDirectInput must followand to play sound, we'll enclose these steps in two classes so every Chapter 5 - River Pla.Net Writing Text but to Screen
application need to include these initialization details.and To play sounds using managed DirectSound, we Chapter 6 - doesn't Magic KindergarteN.: Adventure Games, ADO.NET, DirectShow need to perform the following four steps: - Magic KindergarteN. II: Animation Techniques and Speech API 1. Create the DirectSound device object. Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Chapter 7
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 2. Create the DirectSound Nonmanaged Code buffer object. Bonus Chapter Porting .Nettrix to Pocket PC
3. Load the WAV sound file into the buffer.
Appendix A - The State of PC Gaming
Appendix B - Motivations in Games 4. Play the sound using the buffer. Appendix C - How Do I Make Games?
As we can only two are involved in Games playing sound through DirectSound: Appendix D -see, Guidelines forobjects Developing Successful Index Device: Responsible for any generic operation regarding the sound device List of Figures List ofBuffer: Tables Loads the sound files, sets specific properties, and plays the sounds
When playing files through DirectMusic, we'll have to implement some extra steps and different objects, due to the different nature of the sound files controlled. The steps to play any MIDI or SGT file using DirectMusic are as follows: 1. Create the Performance and Loader objects. 2. Initialize the Performance object. 3. Set the search directory from which the Loader object will load the sound files. 4. Load the file with the sound information of a Segment object. 5. If the file is an SGT file, download band and wave information for the file to the Performance object. 6. Play the sound from the segment object, choosing the audio path to play it in (primary or secondary). 7. If the file is an SGT file, play any included motifs as needed. From these steps, we can see that there are three main objects we'll need to handle when playing sounds though DirectMusic: Performance,Loader, and Segment. These objects are described in more detail in the following list: Performance: Responsible for the management of all music playback. This object controls a set of instruments, with their special characteristics, and maps them to specific audio paths. It controls the music
tempo, handles messages and events, and sets the music parameters. The performance mixes all sounds Game Programming with DirectX 9.0 from primary.NET and secondary audio paths seamlessly. by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Loader: Loads sound files, including instrument data, styles, bands, and collections. When we load a Apress © 2003file (696ispages) sound file, every related loaded too. The authors of this text show how easy it can be to produce
Segment: Stores interesting and plays multimedia each music gamespiece usingas Managed it is loaded DirectX from 9.0the and sound file. programming with Visual Basic .NET on Everett, the latest version of Microsoft's VisualtoStudio. With these concepts in mind, we are ready define the basic audio classes' interface, as shown in Figure 4-8.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
Figure 4-8: The audio classes
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
We can Cadd newDo properties and methods as needed when implementing audio management for our games. Appendix - How I Make Games? Appendix D - Guidelines for Developing Successful Games
In the next sections, we discuss the details for each game audio class.
Index
List of Figures
The GameSound Class
List of Tables
As we can see in our class definition, to play a sound through managed DirectSound, we must load the buffer with the sound file and then play the sound. This way of working gives us two choices for playing multiple sounds in our games: Create one single GameSound object and call Load and Play methods for every sound to be played. Create a GameSound object for each sound to be played, load each sound once, and call the Play method for the specific object that holds the sound to be played. For sounds that are constantly playing throughout the game, the second approach is better, because it won't waste time reloading the sounds. The interface for the class will be as follows: Imports Microsoft.DirectX.DirectSound Public Class ClsGameSound Protected Const SOUND_PATH As String = "Sounds" Dim DSoundBuffer As SecondaryBuffer = Nothing Public Looping As Boolean = False Private Shared SoundDevice As Device = Nothing Sub New(WinHandle As Windows.Forms.Control) Function Load(strFileName As String) As Boolean) As Boolean
Sub StopPlaying() .NET Game Programming with DirectX 9.0 Sub Play() by Alexandre Santos Lobão and Ellen End class
ISBN:1590590511
Hatton Apress © 2003 (696 pages)
Thewe'll authors show easyfor it can to produce In the next sections, lookofatthis thetext code andhow details eachbeclass method.
The New
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Method version of Microsoft's Visual Studio.
On the New method we must initialize the sound device. Since we only need one device initialization for all the sounds we want to play, we must define the device object as shared (as we already did in the class definition), Table of Contents and include code in the with NewDirectX method9.0 to initialize the device only if it's not already initialized. The code for this .NET Game Programming method is presented in the following listing: Foreword Preface
Sub New(WinHandle As System.Windows.Forms.Control) Introduction Is Nothing Then ChapterIf 1 SoundDevice - .Nettrix: GDI+ and Collision Detection Chapter 2
= NewIntelligence Device() -SoundDevice .Netterpillars: Artificial and Sprites
SoundDevice.SetCooperativeLevel(WinHandle, CooperativeLevel.Normal) - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ End If Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio End Sub Chapter 3 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter - Magic the KindergarteN. Techniques and Speech API the device of the appropriate Besides7 creating device, we II: canAnimation see a specific initialization to inform Chapter 8 - .Netterpillars II: words, Multiplayer and device Directplay cooperative level—in other howGames the sound object will interact with other applications that may be using the device. D-iNfEcT: The Multithreading, possible valuesNonrectangular for the SetCoopLevel Windows, and enumeration Access to follow: Chapter 9 Nonmanaged Code
Specifies the device be used BonusNormal: Chapter Porting .Nettrix to Pocket PC in a way that allows the smoothest multithreading and multitasking (multiple application) Appendix A - The State of PCoperation. Gaming Using this setting will force us to only use the default buffer and output formats, but this willinsuffice Appendix B - Motivations Gamesfor our samples. Appendix C - How Do I Make Games?
Priority: Sets a priority level on the device, so we can change buffer and output formats. This member doesn't behave well with other applications trying to share the device, so we must use it only if we don't Index expect concurrency from other applications. Appendix D - Guidelines for Developing Successful Games List of Figures
List ofWrite Tables Only: Specifies that the application plays only on primary buffers. This enumeration member will
work only on real hardware devices; if DirectSound is emulating the device, the call to SetCooperativeLevel will fail. Once we've created the device, we can load the sounds into a sound buffer, as described in the next section.
The Load Method TheLoad method will be mainly based on the CreateSoundBufferFromFile function, which requires the following parameters: <Buffer object>.CreateSoundBufferFromFile(FilePath, BufferDescription)
The first parameter is the path from which we want to load the sound file. The second is a description of specific properties we'll need for the buffer, from the capabilities we'll have (control volume, frequency, etc.) to how the device must act when playing this buffer, when another application gets the focus. In our sample, we'll only set one flag, GlobalFocus, which tells the device to continue playing the buffer even if other DirectSound applications have the focus. The full code of the Load function is shown in the following sample: Function Load(strFileName As String) As Boolean Try
Dim Desc As BufferDesc = New BufferDesc() .NET Game Programming with DirectX 9.0 Desc.Flags = New BufferCapsFlags() = BufferCapsFlags.GlobalFocus Or _ ISBN:1590590511 by Alexandre Santos Lobão and Ellen BufferCapsFlags.LocSoftware Hatton Apress © 2003 (696 pages)
DSoundBuffer = _ The authors of this text show how easy it can be to produce SoundDevice.CreateSoundBufferFromFile(Application.StartupPath & _ interesting multimedia games using Managed DirectX 9.0 and SOUND_PATH & "\" programming with Visual"\" Basic&.NET on Everett, the latest& strFileName, Desc) Catch de version As Exception of Microsoft's Visual Studio. MessageBox.Show("Could not load the sound file. Error: " & de.Message, _ "Music Initialization", MessageBoxButtons.OK, MessageBoxIcon.Error) Table ofEnd Contents Try .NET Game LoadProgramming = True with DirectX 9.0 Foreword End Function Preface Introduction
In the next discuss the lastDetection two methods of the GameSound class, Play and StopPlaying. Chapter 1 -section .Nettrix:we'll GDI+ and Collision Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
The Play- Managed and StopPlaying Methods DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 3
Chapter 4 and - River Pla.Net: Tiled methods Game Fields, and DirectAudio ThePlay StopPlaying will Scrolling, use the Play and Stop methods belonging to the Buffer object, Chapter 5 River Pla.Net II: DirectInput and Writing Text to Screen as shown in the next code listing. Similarly to the CreateSoundBufferFromFile function, the Play method Chapter 6 -a Magic KindergarteN.: Adventure Games, and use DirectShow will receive structure with the playing flags; in ourADO.NET, sample we'll the default settings, and include an extra Chapter Magic KindergarteN. II: Looping Animation property Techniques Speech setting 7for -looping the sound if the of and the class is API set. Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Sub Play() Chapter 9 Nonmanaged Code
Dim PlayFlags As BufferPlayFlags = BufferPlayFlags.Default If Looping Then PlayFlags = BufferPlayFlags.Looping
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Appendix - Motivations in Games Is Nothing) Then IfB Not (DSoundBuffer Appendix C -Try How Do I Make Games? Appendix D - Guidelines for Developing SuccessfulPlayFlags) Games DSoundBuffer.Play(0, Index
Catch de As Exception MessageBox.Show("Error playing sound file. Error: " & de.Message, _ MessageBoxButtons.OK, MessageBoxIcon.Error) List of Tables End Try End If End Sub List of Figures
Sub StopPlaying() If Not (DSoundBuffer Is Nothing) Then DSoundBuffer.Stop() DSoundBuffer.SetCurrentPosition(0) End If End Sub
In the next section we'll discuss the second DirectAudio class, GameMusic.
The GameMusic Class The basic class interface to access DirectMusic features is shown in the next code listing. The first line imports the library created by Visual Basic as a wrapper to the VBDX8.DLL file, used for COM access to all DirectX features, including DirectMusic. Imports DxVBLibA Public Class clsGameMusic
Private Private Private
Shared DMusicPerf As DirectMusicPerformance8 = Nothing .NET Game Programming DirectX 9.0 Shared DMusicLoad Aswith DirectMusicLoader8 = Nothing ISBN:1590590511 by Alexandre Santos Lobão and Ellen DMusicSegment As DirectMusicSegment8 = Nothing Hatton Apress © 2003 (696 pages)
' Background music is looped by default The authors this text show how easy it can be to produce Public looping AsofBoolean = True
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest ' Defaultversion sound files path of Microsoft's Visual Studio.
Private Const SOUND_PATH As String = "Sounds" Table of Contents Sub SetVolume(intVolume As Integer) .NET Game Programming with DirectX 9.0 Function Initialize(WinHandle As IntPtr) As Boolean Foreword PrefaceFunction Load(strFileName As String, bolLooping As Boolean = True) As Boolean Introduction Sub Play()
PlayMotif(strMotifName ChapterFunction 1 - .Nettrix: GDI+ and Collision Detection As String) As Boolean ChapterSub 2 -StopPlaying() .Netterpillars: Artificial Intelligence and Sprites ChapterProtected 3 - ManagedOverrides DirectX First Sub Steps:Finalize() Direct3D Basics and DirectX vs. GDI+
End Class Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow In this code sample, we can see that DirectMusic defined the Performance and Loader objects as private so Magic KindergarteN. II: Animation Techniques and Speech API they'll only-be accessible to the class. This will prevent us from having to know internal details of the class when Chapter - .Netterpillars II: Multiplayer Games and Directplay playing8music from our games. Chapter 7
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
The Initialize Method
Bonus Chapter Porting .Nettrix to Pocket PC Appendix In the Initialize A - The Statefunction, of PC Gaming we need to create and initialize the class objects with the most commonly used Appendix values. The B - Motivations next code sample in Games shows a possible implementation for this method: Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Function Initialize(WinHandle As IntPtr) As Boolean Index' CreateFlags our default objects List ofDim Figures AudioParams As DMUS_AUDIOPARAMS List of Tables
DMusicPerf = DX8.DirectMusicPerformanceCreate() DMusicLoad = DX8.DirectMusicLoaderCreate() Try ' Initialize our performance object to use reverb DMusicPerf.InitAudio(WinHandle.ToInt32, _ CONST_DMUS_AUDIO.DMUS_AUDIOF_ALL, AudioParams, , _ CONST_DMUSIC_STANDARD_AUDIO_PATH. DMUS_APATH_SHARED_STEREOPLUSREVERB, 128) ' Turn on all auto download DMusicPerf.SetMasterAutoDownload(True) ' Set our search folder DMusicLoad.SetSearchDirectory(Application.StartupPath & "\" & SOUND_PATH) Initialize = True Catch de As Exception MessageBox.Show("Could not initialize DirectMusic. Error: " & de.Message, _ "Music Initialization.", MessageBoxButtons.OK, MessageBoxIcon.Error) Initialize = False End Try End Function
Some of the key functions used in the Initialize method deserve a better explanation. Let's start by taking a closer look at the InitAudio method and its possible values:
.NET Game Programming with DirectX 9.0
.InitAudio(hWnd, Flags, AudioParams, DirectSound, _ ISBN:1590590511 by Alexandre Santos Lobão and Ellen DefaultPathType, ChannelCount) Hatton Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce The first parameter, HWnd, receives the window handle. This will usually be the same window used for Direct3D interesting multimedia games using Managed DirectX 9.0 and device object creation. If we specify a window don't the need to specify the DirectSound object, so programming with Visual Basichandle, .NET onwe Everett, latest DirectMusic creates version a private of Microsoft's one for its Visual personal Studio. use, making our code simpler.
The second parameter, Flags, specifies a member of the CONST_DMUS_AUDIO enumeration that will state the Table of Contents requested features for the performance. Although you can specify different values, such as BUFFERS to fully .NET support Game audio Programming path buffers, with or DirectX 3D for9.0 supporting 3-D sounds, using ALL, as in the sample code, will prepare
Performance to handle any kind of loaded sounds. Foreword Preface
The third parameter, AudioParams, allow us to specify the desired control parameters for the sound synthesizer, and to be notified of which requests were granted. We can specify details such as the frequency of Chapter 1 - .Nettrix: GDI+ and Collision Detection the sample and the number of voices used; but since we are using only the simplest features from DirectMusic, Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites we'll let all flags remain set to their default values. Introduction
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 - River Pla.Net: Scrolling, and DirectMusic DirectAudio features to support DirectSound with The DirectSound object isTiled usedGame whenFields, we are employing Chapter 5 River Pla.Net II: DirectInput and Writing Text to Screen playing WAV files; since we are dealing with separate classes for each one, we can simply omit this parameter. Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
The next parameter, DefaultPathType, receives a member of the DMUS_APATH enumeration, which - Magic KindergarteN. II: Animation Techniques and Speech API specifies the default audio path type, as described in the following list: Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Chapter 7
D-iNfEcT: Multithreading, Nonrectangular and Access to DYNAMIC_3D: Indicates the audio path will playWindows, to a 3-D buffer (the sounds are distributed on the speakers Chapter 9 Nonmanaged Code
in order to create the illusion of a 3-D environment). For more information on 3-D sounds, refer to the DirectX SDK.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Appendix DYNAMIC_MONO: B - MotivationsUsed in Games for creating an audio path with mono buffering (all music sounds are of equal Appendix volume C - How in each Do Ispeaker). Make Games? Appendix D - Guidelines for Developing Successful Games
DYNAMIC_STEREO: Specifies the sounds be played in a stereo environment (the sounds are distributed on the speakers according to how they were recorded—for example, if the percussion instruments were more List of Figures to the left, the left speaker will have a louder percussion sound). Index
List of Tables
SHARED_STEREOPLUSREVERB: Indicates the buffer created for the audio path has all the features of the stereo buffer, plus an environmental reverb (echo in music). TheChannelCount parameter specifies the number of performance channels allocated to the audio path. In the code sample, we have 128 performance channels, which means that we can play up to 128 different sounds within the same Performance object. A second function in the preceding sample that deserves a more detailed explanation is SetMasterAutoDownload: . SetMasterAutoDownload(value)
This method is one of many used to set global parameters for the performance object, passing a single value as a parameter. The following lists a few more of the methods in this category: SetMasterVolume: Sets the volume, measured in hundreds of decibels, ranging from +20 (amplification) to -200 (attenuation). Values below -100 or above +10 will result in no audible difference, so the useful values are up to 10 times the default volume to 1/100 of it. SetMasterAutoDownload: Turns on and off automatic loading of instruments when loading the segment files that use them. We'll always want this parameter set to on.
SetMasterTempo: Represents the "scale factor" for the tempo of the music. The default value is 1, so you .NET Game Programming with DirectX 9.0 can set this to 0.5 and have music playing at half the normal speed, or set this to 2 and double the speed (if ISBN:1590590511 by Alexandre you want to hear, say, LouSantos Reed Lobão singingand likeEllen Madonna). Valid values range from 0.01 to 100.
Hatton Apress © 2003 (696 pages) There are other methods of this type, but these are the ones we'll most commonly want to set. We can create of thisclass text show easy it can be tosuch produce new methods for The the authors GameMusic to sethow these parameters, as a SetVolume method to set the interesting multimedia games DirectX 9.0 and current volume for the performance object, asusing in theManaged following code sample: programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Sub SetVolume(intVolume As Integer) If Not (DMusicPerf Is Nothing) Then Table of Contents Try .NET Game Programming with DirectX 9.0 DMusicPerf.SetMasterVolume(intVolume) Foreword Catch de As Exception Preface MessageBox.Show("Could not set the master volume. Error: " & _ Introduction de.Message, MessageBoxButtons.OK, MessageBoxIcon.Error) Chapter 1 -End .Nettrix: TryGDI+ and Collision Detection ChapterEnd 2 -If .Netterpillars: Artificial Intelligence and Sprites End Sub Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Note As you can imagine, there are complementary methods with the GetMaster prefix that are used to - Magic KindergarteN. II: Animation Techniques and Speech API retrieve the value of a specific configuration parameter from the Performance object. It's beyond the Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay scope of this book to explain every one of them; refer to DirectX SDK help for a comprehensive list. Chapter 7
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to The last newNonmanaged function weCode saw in the sample, SetSearchDirectory, simply informs the Loader object of the Bonus Chapter Porting to Pocket PCbe loaded, so we won't need to give the path for every sound loaded. directory from which .Nettrix the sound files will Chapter 9
-
Appendix A - The State of PC Gaming Appendix B - Motivations The Load Methodin Games Appendix C - How Do I Make Games?
TheLoad will be based on the LoadSegment function, which receives the file and path from Appendix D method - Guidelines for mainly Developing Successful Games which we want to load the sound file (MIDI or SGT). Since we already gave the search path for the Loader Index object, we can pass only the filename to the function. List of Figures List of full Tables The code for a first version of the Load function is shown in the following sample:
Function Load(strFileName As String, Optional bolLooping As Boolean = True)_ As Boolean ' Backgound music loops by default looping = bolLooping ' Load the music file Try DMusicSegment = DMusicLoad.LoadSegment(strFileName) ' If it's a segment file, we have some special treatment If strFileName.EndsWith(".sgt") Then If Not (DMusicSegment Is Nothing) Then '// Download the segment DMusicSegment.Download(DMusicPerf.GetDefaultAudioPath) End If Else If strFileName.EndsWith(".mid") Or strFileName.EndsWith(".rmi") Then DMusicSegment.SetStandardMidiFile() End If End If Catch de As Exception DMusicSegment = Nothing MessageBox.Show("Could not load the sound file. Error: " & de.Message, _
"Music Initialization", MessageBoxButtons.OK, MessageBoxIcon.Error) Game Programming with DirectX 9.0 Load .NET = False ISBN:1590590511 by Alexandre Exit Function Santos Lobão and Ellen Hatton End Try Apress © 2003 (696 pages) Load = True End Function The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
NEW
In VB .NET, every data type corresponds to a class definition, with its own set of properties and
Table IN of Contents methods, so we can use these methods and properties as we would do with any kind of objects. In .NET Game .NET Programming the preceding with sample DirectXcode, 9.0 EndsWith() is a method of the string data type, corresponding to the
Right method in previous versions of Visual Basic, with the only difference being that we don't need to pass the number of characters to check.
Foreword Preface Introduction
NEW IN Another interesting point about the preceding code is the use of the Try-Catch block with a - .Nettrix: GDI+ and Collision Detection .NET specific type of exception. This structured error block, new in Visual Basic .NET, allows the Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites programmer to catch generic errors or errors from a specific set (such as Exception). Chapter 1 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter - River the Pla.Net: Tiled Game Fields, Scrolling, DirectAudio We can4 improve music played from segment filesand using styles and motifs that are stored in those files by the Chapter 5 River Pla.Net II: DirectInput and Writing Text to music author. In the next section we'll examine what these Screen are and how to apply them to our audio class. Chapter 6 Chapter Styles7 Chapter 8
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow - Magic KindergarteN. II: Animation Techniques and Speech API and Motifs - .Netterpillars II: Multiplayer Games and Directplay
Styles and motifs are Multithreading, intrinsic parts ofNonrectangular a segment file, and theyand allow us totochoose from a set of previously D-iNfEcT: Windows, Access Chapter 9 created compositions to play at any time during music execution. Each segment file can have one or more Nonmanaged Code styles recorded within it, and every style can have one or more motifs. Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Astyle is a collection of instruments and music patterns or motifs (sequences of music values for each instrument present in the style). To read a specific style from a music segment, we use the GetStyle method. Appendix C - How Do I Make Games? There are various Get methods in the Segment object, similar to the GetMaster methods present in the Appendix D - Guidelines Successful Gamesa style, we must pass the style number, from 0 to the Performance object,for asDeveloping we saw before. To retrieve Index number of styles present minus 1. Passing an invalid value will generate an error. Appendix B - Motivations in Games
List of Figures
After choosing a specific style, we can retrieve its number of motifs using the GetMotifCount function. List of Tables Based on these two functions, we can extend our Load method to retrieve the number of styles and the number of motifs, setting new properties that will allow the game to retrieve the information from the GameMusic class. To do so, we must include the following new properties in the class: Private DMusicStyle As DirectMusicStyle = Nothing Public MotifCount As Integer = 0 Public StyleCount As Integer = 0
And we need to include the following lines in the Load method. Read the following code carefully so you understand the mechanism of reading styles and motifs. Dim strMotifName As String Dim bolLoopStyles As Boolean = True Dim bolLoopMotifs As Boolean = True Do While (bolLoopStyles) ' Count the styles Try DMusicStyle = DMusicSegment.GetStyle(StyleCount) StyleCount += 1
' Count the motifs of the style .NET Game Programming bolLoopMotifs = Truewith DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen MotifCount += DMusicStyle.GetMotifCount Hatton Catch Apress © 2003 (696 pages) ' The GetParam will throw an exception if there are no more styles. The authors of this text show how easy it can be to produce bolLoopStyles = False interesting multimedia games using Managed DirectX 9.0 and End Try programming with Visual Basic .NET on Everett, the latest Loop version of Microsoft's Visual Studio. ' We start counting from zero, so add 1 to have the real Style count value StyleCount += 1 Table of Contents .NET Game Programming with DirectX 9.0
In the next section we'll discuss the methods for playing and stopping the audio. Foreword Preface
The Play Introduction Chapter 1
and StopPlaying Methods
- .Nettrix: GDI+ and Collision Detection
Once the styles have been read, we can code the Play and StopPlaying methods, which will use the - .Netterpillars: Artificial Intelligence and Sprites PlaySegmentEx and StopEx methods belonging to the Performance object, as shown in the following code Chapter 3 - Managed DirectX First Direct3D Basics and DirectX vs. GDI+ sample. Both methods receive theSteps: segment object (created in the Load method) used to play or stop playing. Chapter 2 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Sub Play() Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow If Not (DMusicSegment Is Nothing) Then Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Try Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay If Looping Then D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to DMusicSegment.SetRepeats(CONST_DPNWAITTIME.INFINITE) Chapter 9 Nonmanaged Code Else Bonus Chapter Porting .Nettrix to Pocket PC DMusicSegment.SetRepeats(0) Appendix A - The State of PC End IfGaming Appendix B - Motivations in Games DMusicPerf.PlaySegmentEx(DMusicSegment, 0, 0) Appendix C -Catch How Do de I Make As Games? Exception Appendix D - Guidelines for Developing Successful Games MessageBox.Show("Error playing music file. Error: " & de.Message, _ Index MessageBoxButtons.OK, MessageBoxIcon.Error) List of Figures End Try End If List of Tables End Sub Sub StopPlaying() If Not (DMusicSegment Is Nothing) Then DMusicPerf.StopEx(DMusicSegment, 0, 0) End If End Sub
In the next section, we look at how to play motifs, and create two new methods to add this feature to our GameMusic class.
Playing Motifs To finish our GameMusic class, it'll be interesting to have one function to play a motif from the current music segment. We can use such a function to add some subtle variations to our background music, making it a little more exciting. We can simply do this by using the same PlaySegmentEx function. Instead of using the entire sound loaded as a segment object as the first parameter, we'll load the motif from the segment object (using theGetMotif function) and pass the motif as a parameter for that function. We can create an analogous method that receives a number and plays the associated motif; such a method would be useful if we don't previously know the motif names, but do know how many there are (as calculated in theLoad method).
The two overloaded methods are shown in the next listing, and it's up to each game to choose which one best .NET Game Programming with DirectX 9.0 suits its needs. ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Function PlayMotif(strMotifName Apress © 2003 (696 pages) As String) As Boolean
Dim Motif As of DirectMusicSegment8 The authors this text show how easy it can be to produce Try interesting multimedia games using Managed DirectX 9.0 and Visual Basic .NET on Everett, the latest 'programming Get the with motif version of Microsoft's Visual Studio. Motif = DMusicStyle.GetMotif(strMotifName) DMusicPerf.PlaySegmentEx(Motif, _ CONST_DMUS_SEGF_FLAGS.DMUS_SEGF_DEFAULT Or _ Table of Contents 0) .NET Game ProgrammingCONST_DMUS_SEGF_FLAGS.DMUS_SEGF_SECONDARY, with DirectX 9.0 PlayMotif = True Foreword Catch Preface PlayMotif = False Introduction End Try Chapter 1 - .Nettrix: GDI+ and Collision Detection End Function Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Function PlayMotif(intMotifIndex As Integer) As Boolean Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Dim strMotifName As String Chapter 4 -Try River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5 - River'Pla.Net DirectInput Get II: the motif and Writing Text to Screen Chapter 6 - MagicstrMotifName KindergarteN.: Adventure Games, ADO.NET, and DirectShow = DMusicStyle.GetMotifName(intMotifIndex) Chapter 7 - Magic'KindergarteN. Animation Techniques Speech API Call the II: overloaded method and which receives a string Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay PlayMotif = PlayMotif(strMotifName) Catch D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Nonmanaged Code = False PlayMotif Bonus Chapter Porting End Try .Nettrix to Pocket PC Appendix A - The State of PC Gaming End Function Appendix B - Motivations in Games Appendix C - How Do I Make Games?
TheGetMotifName method, listed in the previous code sample, receives the motif number (ranging from one toGetMotifCount) and returns the motif name (as informed by the composer when creating the segment) as Index the second parameter. Calling this function with an invalid index will generate an error. Appendix D - Guidelines for Developing Successful Games List of Figures
List of Tables In the next section we'll discuss the final method of our class.
The Finalize Method The last class method, Finalize, simply destroys the audio objects, making sure that the Performance object is closed before destroying it, using the CloseDown method. Protected Overrides Sub Finalize() ' The object is being destroyed, so ignore any errors On Error Resume Next MyBase.Finalize() 'Clean up DMusicSegment If Not (DMusicSegment Is Nothing) Then DMusicPerf.StopEx(DMusicSegment, 0, 0) End If DMusicSegment = Nothing DMusicStyle = Nothing DMusicLoad = Nothing If Not (DMusicPerf Is Nothing) Then DMusicPerf.CloseDown() End If DMusicPerf = Nothing End Sub
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Now that this class is finished, we have a complete set of classes to help us to include audio capabilities in our Hatton games. The mostApress important point to note when using this kind of approach is that when coding a game, we © 2003 (696 pages) need to be concerned with the game goals, theeasy lessitimportant The authors of this text shownot how can be to details producesuch as how to load music or initialize a device. interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
In the next sectionversion we'll discuss of Microsoft's the proposal Visual Studio. for the sample game used in this chapter and the next, which will allow us to test, in a practical way, our gaming class library. Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Game Proposal by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton We are going to do an Activision's River Raid (an old Atari console game) clone, but in this chapter we'll © 2003features. (696 pages)Since not everyone will remember the original River Raid game create only half ofApress the game features (or will have ever played it),text let'sshow introduce the itpoints we'll want to cover in our first version of the The authors of this how easy can be to produce interesting multimedia games using Managed DirectX 9.0 and game.
programming with Visual Basic .NET on Everett, the latest version of will Microsoft's Studio. In River Pla.Net the player control Visual a plane that is flying over a top-to-bottom scrolling river. Even when
the player isn't moving the plane, the ground beneath it will be moving. As far as we know, the river goes on forever, so the main goal of the game is to live for as long as possible. Table of Contents .NET Programming with DirectX 9.0 game: HereGame are some more details about the Foreword
The plane will be controlled by keyboard arrows. Preface Introduction
There will be some obstacles along the river: ships, planes, and bridges. The ships and planes won't - .Nettrix: GDI+ and Collision Detection move in the first version of the game.
Chapter 1 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 plane - Managed DirectX be First Steps: Direct3D Basics DirectX vs.over GDI+ The must always flying over water; if it fliesand over land or an obstacle (bridges, planes, or Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio ships), it will be destroyed. Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
To6make the level design easier, the game map will be aand textDirectShow file, in which each character will Chapter - Magic KindergarteN.: Adventure Games, ADO.NET, represent a different tile when the game field is created. Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay There'll be some gas barrels on the river, which will be collected by the player's plane when it flies D-iNfEcT: Windows, and Access to over In the Multithreading, first version of Nonrectangular the game, we won't create a fuel counter. Chapter 9 them. Nonmanaged Code
BonusAfter Chapter Porting .Nettrixthe to player's Pocket PC being destroyed, plane will be invincible for a few seconds. Appendix A - The State of PC Gaming
TheBgame must have background music and different sound effects for each player action: upon Appendix - Motivations in Games being whenGames? in invincible mode, and while filling the gas tank. Appendix C -destroyed, How Do I Make Appendix D - Guidelines for Developing Successful Games
When a team of developers creates a "real" game, the game proposal is normally followed by some drafts showing details about the game (like screen layout and some artwork samples), and must be refined until List of Figures everyone in the team has a clear understanding of what the game will be. The game proposal goal is to List of Tables answer the question: What are we doing? Index
Once everyone agrees about the game proposal, it's time to answer the next question we need to ask: How will we do it? The game project presents the technical details to answer this question, but both documents aren't static; they can (in fact, they must) be revised every time a new point of view arises and is agreed upon by the game development team. Care must be taken not to include every suggestion, or the planning stage will simply never end. The last two important questions in a "real" game development are mainly targeted to commercial games (How long will it take to finish the project? How much will it cost?), and won't be discussed here.
.NET Game Programming with DirectX 9.0 The Game Project by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Looking back at the project proposal, before starting anything else, we need to decide some higher level Apress 2003 (696 pages) to think about how things will work before writing down any class details for the game. It's©good practice diagrams or pseudo-code. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming .NET points on Everett, the latest are the following: In our specific case, maybe thewith twoVisual most Basic important on the proposal version of Microsoft's Visual Studio.
The player will control a plane that is flying over a top-to-bottom scrolling river. Table of To Contents make the level design easier, the game map will be a text file, where each character will represent .NET Game Programming DirectX a different tile whenwith creating the9.0 game field. Foreword
How do we really make scrolling games? How can we design a level with Notepad? Preface Introduction
In our game, these questions are very much related. First, let's figure out the creation of the game field,
Chapter 1 think - .Nettrix: and Detection and then aboutGDI+ how to doCollision the translation and implementation of the other features described in the Chapter 2 .Netterpillars: Artificial Intelligence and Sprites game proposal. Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Defining the Game Tiles - River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 5
Chapter 6 - Magic KindergarteN.: Adventure Games, DirectShow River Pla.Net is one of those games that allows us ADO.NET, to design and the whole game field based on tiles. We can Chapter 7 -game Magicfield KindergarteN. II: Animation Techniques Speech API to translate the set of characters create the map file with a text editor, using theand game program Chapter 8 to - .Netterpillars in the file a set of tiles II: on Multiplayer screen. Games and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Maybe the first Nonmanaged thing we must Code think about when creating a tile-based game is what size our tiles will be.
They Chapter aren't required to be square ones, Bonus Porting .Nettrix to Pocket PCbut using squares is the best approach, since we can put the tiles togetherAin- any without any problems. Appendix The direction, State of PC Gaming Appendix B - Motivations in Games
To define the number of tiles, we must first decide the resolution for our game. A higher resolution will allow us to use more tiles, if the tiles are a fixed size, or force us to have larger images. Either approach Appendix D - Guidelines for Developing Successful Games can lead to a reduction in performance because they'll both use more memory than lower resolutions, so Index let's keep our sample to a 640×480 resolution to make it as fast as possible. With this resolution, if we List of Figures have square tiles that are 32-pixels wide, we can have 15 tiles for the height and 20 tiles for the width. Appendix C - How Do I Make Games?
List of Tables
Looking at the game proposal, we can list a basic set of tiles to fill the game goals: Land Water Ship Enemy plane Gas barrel Bridge This reduced set of tiles is probably very close to the one used by the original River Raid, but using just these tiles will result in a very "blocky" game. In Figure 4-9 we see a basic set of tiles.
Figure 4-9: A basic set of tiles Let's create a game field using any graphical tool (Microsoft's Paint will suffice) to cut and paste the tiles
shown in Figure 4-9 so we can see a first "visual prototype" of our game, giving us a better idea about how .NET Game Programming with DirectX 9.0 it'll look. Figure 4-10 shows a screen drawn with these tiles. by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Figure first screen based on tiles Chapter 6 - 4-10: Magic A KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 -see .Netterpillars Multiplayer andset Directplay As we can in this firstII: screen, usingGames only this of tiles will result in a flat block game: All river D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to "curves" Chapter 9 are - straight, and we can barely see the border between land and water. Creating borders is just a Nonmanaged Code
matter of drawing a new set of tiles that can be used to generate an island and a lake, and all river curves
Bonus Chapter Porting .Nettrix Pocket PC shows such a set of tiles. can be derived from this set. to Figure 4-11 Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 4-11: The border tiles It's important to adopt tile names that will help us to find them easily. For the border tiles, we suggest giving all tiles the "border" prefix and a direction indicator. For example, for the border where the water meets the land to the north, the name would be "borderN", and for a Southwest border the name would be "borderSW". Take a closer look at Figure 4-12 to understand this naming convention and all the border tile names.
Figure 4-12: The names of the border tiles The N, S, W, and E borders are used as island borders and as lake borders by just exchanging positions. We can remake the screen from Figure 4-10 to add the borders, resulting in the screen shown in Figure 4-
13.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Figure- 4-13: A second screen, based on a larger set of tiles River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 5 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Initially it may seem as though these are the only tiles we'll ever need, but just imagine if the plane flies
Chapter 7 - Magic KindergarteN. II: with Animation Techniques and Speech over a straight section of the river, no bridges or opponents: TheAPI player would barely see the scrolling Chapter 8 .Netterpillars II: Multiplayer Games and Directplay movement-the only tip would be the water movement. So we can add some "final touch" tiles, such as D-iNfEcT: (at Multithreading, Windows, Access to trees and least two of Nonrectangular each, to give some visualand variation), and maybe create a bridge tile Chapter 9 mountains Nonmanaged Code
different from the road one, to give the game a nicer look and feel. Figure 4-14 shows the "final touch"
Bonus tiles. Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 4-14: The "final touch" set of tiles Creating a bridge with borders forces us to change the road tile and make it thin, and we have to add two new tiles to use when the road is over the river border. Our final screen, using all tiles, is shown in Figure 4-15.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 - 4-15: .Netterpillars: andof Sprites Figure The finalArtificial screen,Intelligence using all sets tiles Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Of course, canPla.Net: go on creating new tiles. Scrolling, For example, a diagonal border for the river would be Chapter 4 -we River Tiled Game Fields, and DirectAudio interesting, wePla.Net can break the "blocky" visual thatText still to persists. Chapter 5 - so River II: DirectInput and Writing ScreenWe can add different borderlines, with beaches or- Magic little bays; and we can add more "final touch" objects, such as houses, buildings, or even KindergarteN.: Adventure Games, ADO.NET, and DirectShow animals or people, to arrange around the screen.
Chapter 6 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 -tiles .Netterpillars II:the Multiplayer Games the andlevel Directplay The more we include, more flexibility designer will have to create our groundbreaking D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to levels. 9But-for our purpose here, the tiles we've already created will suffice. Chapter Nonmanaged Code Bonus Chapter .Nettrix towe Pocket Before going Porting to the next topic, shallPC define the char codes corresponding to each tile. Doing this at Appendix game project A - The phase Statewill of PC allow Gaming the level designer to start writing the levels at the same time the
programmers start coding. Then again, there's no rule for choosing the chars. A good approach is to Appendix B - Motivations in Games choose chars that give Games? a visual clue about how the level will look; and as for the borders, we can Appendix C - How Dowill I Make simply choose North as and go on Successful sequentially in a clockwise direction. The characters chosen are Appendix D - Guidelines for1Developing Games shown in Table 4-3. Index List of Figures
Table 4-3: The Tile Codes List of Tables CODE
TILE
1
borderN
2
borderNE1
3
borderNE2
4
borderE
5
borderSE1
6
borderSE2
7
borderS
8
borderSW1
9
borderSW2
A
borderW
B
borderNW1
C
borderNW2
T
Tree
M
Mountain .NET Game Programming with DirectX 9.0
S
ISBN:1590590511 by Alexandre Santos Lobão and Ship Ellen Hatton Apress © 2003 (696 pages) EnemyPlane
P
The authors of this text show how easy it can be to produce GasManaged DirectX 9.0 and interesting multimedia games using programming with Visual Basic .NET on Everett, the latest BridgeBorderW version of Microsoft's Visual Studio.
G ( )
BridgeBorderE
Table - of Contents .NET Game Programming with DirectX 9.0
=
Foreword Preface .
Bridge Land
Introduction
_
Road
Water
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter -2
- .Netterpillars: Artificial Intelligence and -- Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
We have decided to create one single char for both types of trees and another one for both mountain - River Pla.Net II: DirectInput and Writing Text to Screen types, so the game can randomly choose the image to use and have some subtle visual variations every Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow time it's played. Chapter 5 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 - codes, .Netterpillars II:look Multiplayer and Directplay With these we can again atGames our first test screen and create a corresponding map of it, as show D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to in the following code listing: Chapter 9 Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
.....4____A......T.. .M...4____A..T...M.. Appendix B - Motivations in Games ...975____876...M..T Appendix C - How Do I Make Games? .T.4P_______A....... Appendix D - Guidelines for Developing Successful Games ...4___B2__G86..M.T. Index ...4___AC2___A....T. List of Figures T..4___864===(-----List of Tables ...4____85___A....T. ...4___S_____A.976.. ..M4________B3.4_A.. ...C11112___A..C13.. ..T.....4___A....... ..M....95___86...... ....T..4_____A....TT T..M...4_____A..T... .......4_____A...... Appendix A - The State of PC Gaming
Scrolling Games When talking about translation, remember that we have already made a scrolling object-our walking-man cube in Chapter 3, when performing translations on it. Since we already have a set of features in Direct3D that allow us to scroll an object without having to move every vertex of it, we can use the same idea here: Simply change the Transform.World matrix of the device object to do the translation. So all we need to do is create the game field and perform small translations on it, for each time frame, to make it scroll. But will we scroll the entire game field? Will moving all the tiles of the game field result in prolonged calculations? Looking again at the samples in the last chapter, we see that setting the world matrix will only define the
transformations to be applied to the vertex buffer when we call the DrawPrimitivesUP function; so .NET Game Programming with DirectX 9.0 there's no performance difference when setting the matrix for a scene with a few dozen vertices or for a ISBN:1590590511 bythousand. Alexandre Santos Lobão and Ellen scene with several
Hatton 2003 (696 the pages) So what we wantApress to do is© to draw minimum number of vertices possible. Remember, our game field authors of this text show how easy we it can be load to produce will be defined byThe a text file. For performance reasons must it only once, when starting the game, interesting using DirectX and depending on the position of converting each char in the multimedia text file to agames tile that will Managed be in a fixed (x,y)9.0 position, programming with Visual Basic .NET on Everett, the latest the char in the map text file. The tiles will be Studio. fixed throughout the game, and we'll scroll over them, version of Microsoft's Visual
changing the translation value of the world matrix, to "move the camera" over the game field. Just like a plane moving over a real river, the river is fixed on the ground, and we move over it. Table of Contents
So to minimize the vertices .NET Game Programming withdrawn, DirectXwe 9.0can store the current line from the bottom of the screen, and draw the 15 next lines-as mentioned in the previous section, our visual game field will be 20 tiles wide and 15 Foreword
tiles tall. Since we won't be performing translations on the objects the size of a tile, we'll need to draw an extra line to avoid the top of the screen not being drawn appropriately. It's like being in The Matrix (the Introduction movie): The world will exist only when we are looking at it. Preface
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter - .Netterpillars: Artificial Sprites Another2 good idea to minimize theIntelligence number ofand vertices being drawn is simply remove the Land tile from our Chapter - Managed DirectX First Steps: Direct3D Basics To andmake DirectX GDI+ set, and3 draw the other sets over a green background. thevs. background green, all we need to do Chapter is to use 4 the - River green Pla.Net: color as Tiled a parameter Game Fields, of the Scrolling, Clear and method DirectAudio of the device object. Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Class Diagram by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Since we alreadyHatton have all base classes for the game engine, sprite, game music, and sound, all we need 2003 (696 that pages) to do is to create Apress derived© classes will supply specific characteristics, according to the game's special needs. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
Looking at the game programming proposal,with we can Visual only Basic see.NET two on candidates Everett, the for latest new classes: Player and Tile, which version of Microsoft's Studio.we'll need a class derived from the game engine, too will be derived from the Sprite class.Visual Of course, (let's call it the RiverEngine class), to implement the game code. Table of Contents
After a little brainstorming over the game proposal, we have come up with the class diagram shown in
.NET Game Programming with DirectX 9.0 Figure 4-16. Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 4-16: The River Pla.Net game class diagram The following tables describe the properties and methods for each of the game classes, starting with the Tile class in Table 4-4. Table 4-4: The Tile Class
TYPE
NAME DESCRIPTION .NET Game Programming with DirectX 9.0
Property
Type HattonA member of an internal enumeration that should store the type of the tile enemies, etc.) Apress(land, © 2003 water, (696 pages)
Method
of this text show how easy itNew canmethod be to produce NewThe authors An overloaded method for each of the Sprite class that interesting multimedia gamesparameter using Managed DirectX and simply adds an extra for the Type 9.0 property
by Alexandre Santos Lobão and Ellen
ISBN:1590590511
programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table 4-5 shows the description of the methods and properties for the Player class. Table of 4-5: Contents Table The Player Class .NET Game Programming with DirectX 9.0
TYPE Foreword
NAME
DESCRIPTION
Preface Property
Status
The current status for the player: flying, dying, or starting a new life
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Property The fuel tank by percentage Chapter 2 - .Netterpillars: Artificial Intelligence and value Sprites Gas
Chapter 3 - Managed DirectX First Steps: Direct3D and DirectX vs. textures) GDI+ DyingImage Property Image (imageBasics file loaded to create to show when the Chapter 4 - River Pla.Net: Tiled Gameplayer Fields,dies Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Property
StartingImage
Image to show when the player is in invincible mode (starting a new life)
DyingSound Chapter Property 8 - .Netterpillars II: Multiplayer Object Games thatand stores Directplay the sound to be played when the player dies Chapter 9 Property
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to StartingSound Object that stores the sound to be played when the player is in Nonmanaged Code
invincible mode (starting a new life)
Bonus Chapter Porting .Nettrix to Pocket PC
Appendix A - The State of PC Gaming Object that will initialize the sound components and make them GameSound Property Appendix B - Motivations in Games ready to play sounds Appendix C - How Do I Make Games?
Method
New
An overloaded method that will load all player images
Draw
An overloaded method that will draw the player image based on the current status
Appendix D - Guidelines for Developing Successful Games Index Method List of Figures List of Tables
TheRiverEngine class includes members that are additions to the GameEngine class to make it fit our needs. In Table 4-6 we present the descriptions for each class member. As we discussed in earlier chapters, this class interface is a result of many interactions over game project refinements. Table 4-6: The RiverEngine class
PROPERTY
NAME .NET Game Programming DESCRIPTION with DirectX 9.0
Property
Lifes Hatton
Specifies the number of lives of the player.
Property
Apress © 2003 (696 pages) GameSpeed
Indicates the scrolling speed of the game.
by Alexandre Santos Lobão and Ellen
ISBN:1590590511
The authors of this text show how easy it can be to produce Tiles Represents an array with9.0 all and the tiles of the game. interesting multimedia games using Managed DirectX programming with Visual Basic .NET on Everett, the latest CurrentLineNumber version of Microsoft's Visual Specifies Studio. the number of the current line at the bottom
Property Property
of the screen. This property is used to control the tiles we should draw. Table of Contents
Player Property .NET Game Programming with DirectX 9.0
Indicates an object of the Player class.
Foreword Property
Indicates an object of the GameSound class, which will be played when the player passes over a gas barrel.
GasSound
Preface Introduction
BackgroundMusic Indicates an object of the GameMusic class, which will Property - .Nettrix: GDI+ and Collision Detection play the game's background music.
Chapter 1 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 - Managed Initialize DirectX First Steps: Direct3D Calls Basics the Initialize and DirectX vs. method GDI+ of the base class, Method Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, loads theand game DirectAudio map, and creates all game objects
Chapter 5
(Player, GasSound, - River Pla.Net II: DirectInput and Writing Text to Screen and BackgroundMusic).
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Method Method
Chapter 9
LoadGameMap
-
Loads the game map text file and populates the Tiles array.
Render Overrides the Render emptytomethod from the base D-iNfEcT: Multithreading, Nonrectangular Windows, and Access class, and will be called in the game loop (on the Run Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
base class method). All the drawing functions, physics tests, and sound-playing functions should be called from here.
Appendix Do I Make Games? MethodC - How Scroll Scrolls the game field by calculating the game world Appendix D - Guidelines for Developing Successful Games matrix. translation Index ListMethod of Figures
Draw
Draws the visible tiles of the game field, based on the CurrentLineNumber property and the Height of the screen.
Method
MovePlayer
Moves and draws the player, based on the input received from the keyboard.
Method
TestCollisions
Tests the collision of the player against the obstacles of the game field.
Method
PlayMotifs
Plays the random motifs over the background music to add a little variance to it.
List of Tables
.NET Game Programming with DirectX 9.0 The Main Program by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton This main program will show the splash screen and, after closing it, execute the steps we saw before when presenting Apress the GameEngine © 2003 (696 pages) class. The pseudo-code for this will be very simple, as shown in the following sample:The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Create objectversion fromofRiverPlanet Microsoft's Visualclass Studio.
Create a window to be the game screen Show splash screen Table of Contents Initialize RiverPlanet object .NET Game with DirectX 9.0 Show theProgramming game window Foreword Run the game (execute method RUN from RiverEngine object) ' The Run is a synchronous method, it will return when the game ends Preface Destroy the RiverEngine object Introduction Dispose game window Chapter 1 -the .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
And now we are ready to start looking at the code details.
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 The Coding.NET Phase by Alexandre Santos Lobão and Ellen
ISBN:1590590511
In order to follow Hatton a "progressive disclosure" technique, let's do the coding in discrete steps, so we can better Apress 2003 (696 test and understand our©code. Thepages) functionalities of each step will be as follows: authors of this text show howthe easy it canmap be to produce 1. First draft:The Code the Tile Class and load game and the Draw method to draw the tiles in the interesting multimedia games using Managed DirectX 9.0 and Render method. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
2. Second draft: Make the game field scroll.
3. Third draft: Create the Player class to draw the player's plane, and make it move according to the keyboard input. .NET Game Programming with DirectX 9.0
Table of Contents
Foreword 4. Fourth draft: Code the collision detection. Preface
5. Final version: Play background music and sound effects. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
In the next section we start coding the first draft of our game.
First Draft: Loading andFields, Drawing Game Field - River Pla.Net: Tiled Game Scrolling,the and DirectAudio
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Our main objective in this first draft is to load the text file and convert it into a graphical game field. For this, we'll Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow code the Tile class, some basic methods of the RiverEngine class, and our main program. Chapter 8 class, - .Netterpillars II: in Multiplayer Directplay TheTile as we saw the gameGames projectand phase, will be very simple and will only add a specific Type D-iNfEcT: Multithreading, Nonrectangular Windows, and to attribute to the base class Sprite, as shown in the following codeAccess sample: Chapter 9 Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
Imports Microsoft.DirectX.Direct3D Public Class ClsTile Appendix B - Motivations in Games Inherits clsSprite Appendix A - The State of PC Gaming
Appendix C - How Do I Make Games? Appendix D - Guidelines Enum enType for Developing Successful Games Index
Background = 0
List of Figures Water = 1 List of TablesLand = 2
Gas = 3 Ship = 4 Plane = 5 Bridge = 6 End Enum Public Type As enType Sub New(strImageName As String, startPoint As POINT, intType As enType) MyBase.New(strImageName, startPoint) Type = intType End Sub Sub New(strImageName As String, colorKey As Integer, _ startPoint As POINT, intType As enType) MyBase.New(strImageName, colorKey, startPoint) Type = intType End Sub End Class
As for the RiverEngine class, let's define the whole interface and then code only the functions we need at the moment:
Imports System.IO .NET Game Programming with DirectX 9.0 Imports Microsoft.DirectX ISBN:1590590511 by Alexandre Santos Lobão and Ellen Imports Microsoft.DirectX.Direct3D Hatton Public Class Apress ClsRiverEngine © 2003 (696 pages) Inherits The clsGameEngine authors of this text show how easy it can be to produce Private BackgroundMusic ClsGameMusic interesting multimedia As games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest versionAs of Microsoft's Studio. Public Lifes Integer Visual = 5463
Public gameSpeed As Integer = 10 Table of Contents
' Define the array that will store the reference to the tiles on the game ' field. Since we don't know its size a priori, we'll REDIM it when reading Foreword ' the game map file Preface Private tiles As ClsTile(,) Introduction Private CurrentLineNumber As Int32 = 0 Chapter 1 - .Nettrix: GDI+ and Collision Detection Public Player As ClsPlayer ChapterPrivate 2 - .Netterpillars: Artificial Intelligence and Sprites GasSound As ClsGameSound .NET Game Programming with DirectX 9.0
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
ChapterOverrides 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Sub Render() ChapterSub 5 -Scroll() River Pla.Net II: DirectInput and Writing Text to Screen ChapterSub 6 -Draw() Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ChapterSub 7 -MovePlayer() Magic KindergarteN. II: Animation Techniques and Speech API ChapterSub 8 -PlayMotifs() .Netterpillars II: Multiplayer Games and Directplay
Function TestCollision() As Boolean D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Public ShadowsCode Function Initialize(Owner as Windows.Forms.Control) As Boolean Bonus Chapter Function Porting LoadGameMap() .Nettrix to PocketAs PC Boolean Protected Overrides Sub Finalize() Appendix A - The State of PC Gaming End Class Appendix B - Motivations in Games Chapter 9
Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
TheImports clause in the header of the class file allows us to include a namespace reference to the current file so we can use its members directly. In the preceding sample code, we import the System.IO namespace, List of Figures which includes classes and enumerations for manipulating files. Index
List of Tables
NEW IN The fastest way to read and write text files in Visual Basic .NET is to use the StreamReader and .NET StreamWriter classes. We'll use the first one, which has some methods dedicated to reading files, including the ReadLine method, which reads one text line until the new line char (just what we'll need here). The files are opened when creating the object (in the New method), and closed using the Close method.
Coding the LoadGameMap Method The first problem that comes to mind when we start thinking about how the LoadGameMap function will be implemented is that we read a text file from the first line to the last, but our game field needs to be presented to the player in the reverse order. So, if we open the game map file in Notepad, the last line of the file will be the first one to be drawn at the bottom of the screen, and then we'll draw the next ones over it, to make the game scroll until we reach the first line of the file. A possible approach to solving this problem is to read the entire file to a string array and then run through this array to create the Tiles array. We'll include a first line in the text file with the number of lines of the array, so we can Redim it accordingly. It's a good idea to create a separate function for translating the chars of each line, so we can isolate the code that is responsible for accessing the file and read lines from the code that will be creating the tiles. So let's see the code for the LoadGameMap function and the helper function LoadLine:
Function LoadGameMap(strGameMapFileName As String) As Boolean Programming withwill DirectX 9.0 the lines read from the map file ' Define .NET the Game string array that store ISBN:1590590511 by Alexandre Santos Lobão and Ellen Dim GameMap As String() Hatton ' Define the streamreader to read the game map file Apress © 2003 (696 pages) Dim GameMapFile As StreamReader The authors of this text show how easy it can be to produce Dim strLine As String interesting multimedia games using Managed DirectX 9.0 and Dim i As programming Int32 with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
LoadGameMap = True Try Table of Contents ' Opens the game map text file .NET Game Programming with =DirectX GameMapFile New 9.0 StreamReader(Application.StartupPath & "\" & _ Foreword strGameMapFileName) Preface ' reads the first line of the game map, which holds the size of the map Introduction GameMapSize = Convert.ToInt32(GameMapFile.ReadLine()) Creates array, including tiles and active objects Chapter 1 -'.Nettrix: GDI+the and game Collisionmap Detection GameMap(GameMapSize) Chapter 2 -ReDim .Netterpillars: Artificial Intelligence and Sprites GameMapSize) Chapter 3 -ReDim Managedtiles(Width, DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
Load theII:game map array -'River Pla.Net DirectInput and Writing Text to Screen
For i = 1 To GameMapSize GameMap(GameMapSize - i) = GameMapFile.ReadLine() Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API ' The game map file ends within the FOR loop Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay ' if the game map size read from the file is wrong D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 If GameMap(GameMapSize - i) Is Nothing Then Nonmanaged Code MessageBox.Show("Incorrect game map size in " & _ Bonus Chapter Porting .Nettrix to Pocket PC strGameMapFileName & _ Appendix A - The State of PC Gaming " - Expected size: " & GameMapSize & " / Real Size: " & i, _ Appendix B - Motivations in Games "Critical error in game map") Appendix C - How Do I Make Games? LoadGameMap = False Appendix D - Guidelines Exit for Developing Successful Games Function Index End If List of Figures Next List of Tables' Checks to see if there are more lines in the game map file strLine = GameMapFile.ReadLine() If Not (strLine Is Nothing) Then ' Informs the user that we missed the last line(s) MessageBox.Show("Incorrect game map size in " & strGameMapFileName _ & " - One or more lines after the " & GameMapSize & _ "th line were ignored.", "Critical error in game map") LoadGameMap = False Exit Function End If GameMapFile.Close() Catch LoadGameMap = False Exit Function End Try Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
' Load all the game map lines from the GameMap array into the Tiles array For i = 0 To GameMapSize - 1 If Not LoadLine(GameMap(i)) Then LoadGameMap = False Exit Function End If Next
' frees the memory used by the game map Game Programming with DirectX 9.0 GameMap =.NET Nothing by Alexandre Santos Lobão and Ellen End Function Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Function LoadLine(strLine As String) As Boolean authors of this text show how easy it can be to produce Dim x As The Integer interesting multimedia games using Managed DirectX 9.0 and Dim strSpriteFileName As String programming with Visual Basic .NET on Everett, the latest Dim Type version As ClsTile.enType of Microsoft's Visual Studio. Static LineNumber As Integer = 0 LoadLine = True Table of Contents For x = 0 To Width - 1 .NET Game Programming with strLine.Chars(x) DirectX 9.0 Select Case Foreword Case "1" Preface strSpriteFileName = "borderN" Introduction Type = ClsTile.enType.Land Case "2" Chapter 1 - .Nettrix: GDI+ and Collision Detection strSpriteFileName = Sprites "borderNE1" Chapter 2 - .Netterpillars: Artificial Intelligence and Type First = ClsTile.enType.Land Chapter 3 - Managed DirectX Steps: Direct3D Basics and DirectX vs. GDI+ < CASES forFields, the Scrolling, other borders > ... Chapter 4 - River... Pla.Net: Tiled Game and DirectAudio Chapter 5 - RiverCase Pla.Net"T" II: DirectInput and Writing Text to Screen If Rnd() * 10 < 5 Then Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow strSpriteFileName = "Tree1" Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Else Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay strSpriteFileName = "Tree2" D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 End If Nonmanaged Code Type = ClsTile.enType.Land Bonus Chapter Porting .Nettrix to Pocket PC Case "M" Appendix A - The State of PC Gaming If Rnd() * 10 < 5 Then Appendix B - Motivations in Games strSpriteFileName = "Mountain1" Appendix C - How Do I Make Games? Else Appendix D - Guidelines for Developing Successful Games strSpriteFileName = "Mountain2" Index End If List of Figures Type = ClsTile.enType.Land List of Tables Case "S" strSpriteFileName = "Ship" Type = ClsTile.enType.Ship Case "P" strSpriteFileName = "EnemyPlane" Type = ClsTile.enType.Plane Case "G" strSpriteFileName = "Gas" Type = ClsTile.enType.Gas Case "(" strSpriteFileName = "BridgeBorderW" Type = ClsTile.enType.Land Case ")" strSpriteFileName = "BridgeBorderE" Type = ClsTile.enType.Land Case "-" strSpriteFileName = "Road" Type = ClsTile.enType.Land Case "=" strSpriteFileName = "Bridge" Type = ClsTile.enType.Bridge Case "." ' Green background ' Do nothing
strSpriteFileName = "" .NET Type Game = Programming with DirectX 9.0 ClsTile.enType.Background ISBN:1590590511 by Alexandre Case "_" Santos Lobão and Ellen Hatton strSpriteFileName = "Water" Apress © 2003 (696 pages) Type = ClsTile.enType.Water The authors Case Elseof this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and ' Should happen programming with never Visual Basic .NET on Everett, the latest strSpriteFileName = "InvalidTile" version of Microsoft's Visual Studio. Type = ClsTile.enType.Land End Select Table of Contents Try .NET Game Programming with 9.0 If Type <>DirectX ClsTile.enType.Background Then Foreword tiles(x, LineNumber) = New ClsTile(strSpriteFileName & ".bmp", _ Preface New POINT(x, LineNumber), Type) Introduction Else tiles(x, LineNumber) Chapter 1 - .Nettrix: GDI+ and Collision Detection = Nothing End If Artificial Intelligence and Sprites Chapter 2 - .Netterpillars: e As Exception Chapter 3 Catch - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ LoadLine = False Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio MessageBox.Show("Unpredicted when loading game sprites: " & _ Chapter 5 - River Pla.Net II: DirectInput and Writing Text Error to Screen e.Message, "River Pla.Net", MessageBoxButtons.OK, _ Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow MessageBoxIcon.Stop) Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Exit Function Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Try D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterNext 9 Nonmanaged Code ' Increments the line number counter Bonus Chapter Porting .Nettrix to Pocket PC LineNumber += 1 Appendix A - The State of PC Gaming End Function
Appendix B - Motivations in Games
Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games IndexNEW IN Visual Basic .NET is far stricter for automatic conversions between data types than the previous List of.NET Figures versions. To support conversions between types, each data type is treated as a class and has a set List of Tables of converting methods; but we also have a Convert class in the System namespace that has
many conversion methods, such as the ToInt32 method used in the previous code sample. As we can see, the LoadGameMap function simply uses the StreamReader methods to run through the text file, just checking the number of lines against the informed game map size (first line). The LoadLine function is just a big Select Case, which will set the image filename to be loaded and the tile type, which will be used to create the Tiles array elements. Each time we call the LoadLine function, we process a full line read from the file and create a new line on the array, composed of a set of 20 tiles (the width of the game field, as expressed in the next code listing). The LineNumber static variable, incremented at the end of the function, controls the number of lines already read to index the Tiles array properly. As mentioned before, there'll be two types of mountains and trees, so we add a rnd function that will choose one image name or another, with a 50 percent chance for each. Roads, bridge borders, trees, and mountains are all defined as Land tile types, because we don't have any special treatment in code for them. To allow us to see the map loaded, we have to code the Initialize,Render, and Draw methods, as presented in the next sections.
Coding the Initialize Method In the Initialize method, we'll call the LoadGameMap function and the base class Initialize method, which will initialize Direct3D. Private Const GAME_MAP As String = "GameMap.txt"
Public Shadows Function Initialize(Owner As Windows.Forms.Control) _ .NET Game Programming with DirectX 9.0 As Boolean ISBN:1590590511 by Alexandre Santos Lobão and Ellen Dim WinHandle As IntPtr = Owner.Handle Hatton Dim i As Integer Apress © 2003 (696 pages) Randomize() The = authors Initialize Trueof this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest ' Sets the background color to green version of Microsoft's Visual Studio.
BackgroundColor = Color.FromArgb(255, 0, 255, 0) ' Sets the width and height of the game field Table of Contents Width = 20 .NET Game Programming Height = 15 with DirectX 9.0 Foreword Preface' Loads the game map (into GameMap array) Introduction If Not LoadGameMap(GAME_MAP) Then Chapter 1
-Initialize .Nettrix: GDI+ = andFalse Collision Detection
Chapter 2
Function -Exit .Netterpillars: Artificial Intelligence and Sprites
ChapterEnd 3 -If Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio the Pla.Net game II: map was loaded without start Direct3D Chapter'5 If- River DirectInput and Writing Text toerrors, Screen
If Not MyBase.Initialize(WinHandle) Then - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Initialize = False Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Exit Function Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End If D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 End Function Nonmanaged Code Chapter 6
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Coding the Render Method
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Gamesmethod. This function will be called from the base class TheRender function will, for now, only call the Draw Index Run method. List of Figures List of Tables Public Overrides Sub Render()
Draw() End Sub
Coding the Draw Method TheDraw method will be very simple too, because all the complexity for loading textures, initializing Direct3D, and manipulating vertex buffers is in the base classes. All we need to do is call the Draw method for each member of the Tiles array, starting from the line prior to the current line (which must have a default value of 1) and going through the height of the screen plus 1, so that we'll draw only the visible tiles, with a little margin to avoid any problems. Public Sub Draw() Dim x As Integer, y As Integer Dim LineCount As Integer = 0 ' Draw the game field y = CurrentLineNumber - 1 ' We will draw a line below the current line number and a line above ' the last line on screen (CurrentLineNumber + Height) Do While LineCount < Height + 2
For x = 0 To Width - 1 .NET Game Programming withNothing) DirectX 9.0Then If Not (tiles(x, y) Is ISBN:1590590511 by Alexandre Santos Lobão and Ellen tiles(x, y).Draw() Hatton End If Apress © 2003 (696 pages) Next The authors LineCount += of 1 this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and y += programming 1 with Visual Basic .NET on Everett, the latest Loop End Sub
version of Microsoft's Visual Studio.
Table of Contents .NET TheGame last thing Programming we must do with is DirectX code the 9.0main procedure. Foreword
We'll be following the guidelines of the pseudo-code written in the game project, and adding a splash screen (just a screen with a nondynamic image) that will close when the player presses any key, as shown in the Introduction following code: Preface
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Sub frmSplash_KeyDown(sender As Object, e As KeyEventArgs) Handles MyBase.KeyDown - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Me.Dispose() Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio End Sub Chapter 3 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 screen - MagicisKindergarteN. II: Animation Techniques and Speech API The intro shown in Figure 4-17. Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 4-17: The game splash screen The final code for the main program is as follows: Public RiverPlanet As ClsRiverEngine Sub main() Dim winGameWindow As New GameWindow() Dim winSplash As New frmSplash() winSplash.ShowDialog() RiverPlanet = New ClsRiverEngine() If Not RiverPlanet.Initialize(winGameWindow) Then MessageBox.Show("Error initializing the game", "Critical Error", _ MessageBoxButtons.OK, MessageBoxIcon.Stop)
Exit Sub End If .NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen winGameWindow.Show() Hatton ' The run procedure will return only when the game is over Apress © 2003 (696 pages) RiverPlanet.Run() The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and ' Destroying the object calls the on finalize method programming with Visual Basic .NET Everett, the latest RiverPlanet = of Nothing version Microsoft's Visual Studio.
winGameWindow.Close() End Sub Table of Contents .NET Game Programming with DirectX 9.0
We can run our game now, and see the resulting screen, which is exactly the same as our visual prototype, Foreword shown in Figure 4-15. Preface Introduction
In the next section we'll implement the scrolling of our game field.
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Second Draft:DirectX Scrolling - Managed First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
To see our game field scrolling, all we need to do is to add code to the Scroll method and call it on the - River Pla.Net II: DirectInput and Writing Text to Screen Render procedure before calling the Draw method.
Chapter 5 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 Render - Magic KindergarteN. II:as Animation The new method will be follows: Techniques and Speech API Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Public Sub Render() Chapter 9 Overrides Nonmanaged Code
Scroll() Draw() Appendix A - The State of PC Gaming End Sub
Bonus Chapter Porting .Nettrix to Pocket PC Appendix B - Motivations in Games Appendix C - How Do I Make Games?
To appropriately control scrolling,Successful the Scroll function must store Matrix as a static variable that will Appendix D - Guidelines forthe Developing Games maintain the current translation to be applied to the Transform.World matrix of the objDirect3DDevice, Index created in the base class. To implement the translation, we must use the concept we learned in Chapter 3: List of Figures Multiplying List of Tablesmatrices has the same effect as adding the transformations of each one. Since the base GameEngine class uses an orthogonal view of the textures, everything is automatically translated to pixel coordinates, so we can control the current line number by simply counting the number of pixels translated and, when the sum of pixels exceeds the tile size (the clsSprite.IMAGE_SIZE constant), add 1 to the current line property. To avoid our game running at full (and unplayable) speed, we must control the frame rate using the technique we learned in Chapter 3 to control the walking man's speed: We store the system time using System.Environment.TickCount and only do the scroll processing when a given time has passed. Taking all this into consideration, we can code a fully working scroll routine. Spend some time analyzing the following code to make sure you understand the basic concept here, which will be used later to move the player's plane. Public Sub Static Static Static
Scroll() ScrollMatrix As Matrix = Matrix.Identity LastTick As Integer PixelCount As Integer
' Force a Frame rate of 'GameSpeed' frames to second on maximum If System.Environment.TickCount - LastTick >= 1000 / gameSpeed Then LastTick = System.Environment.TickCount ' Scrolls the game field (translation on the Y axis)
' since the Y axis increases when going up on the screen, Programming with DirectX 9.0 to make the tiles scroll down ' we.NET useGame a negative transation value ISBN:1590590511 by Alexandre Santos Lobão and Ellen ScrollMatrix = _ Hatton Matrix.Multiply(ScrollMatrix, _ Apress © 2003 (696 pages) Matrix.Translation(0, -gameSpeed, 0)) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and ' updates the current line.NET number, used control the screen drawing programming with Visual Basic on Everett, the to latest PixelCount PixelCount + gameSpeed version of=Microsoft's Visual Studio.
If PixelCount > clsSprite.IMAGE_SIZE Then CurrentLineNumber += 1 Table of Contents PixelCount -= clsSprite.IMAGE_SIZE .NET Game Programming with DirectX 9.0 End If Foreword End If PrefaceobjDirect3DDevice.Transform.World = ScrollMatrix Introduction End Sub Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
A set of scrolling images is shown in Figure 4-18. - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
Figure 4-18: Testing the scrolling game field
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
In the next code the player's plane, including the controls for using the keyboard. Appendix C -section How Dowe'll I Make Games? Appendix D - Guidelines for Developing Successful Games
Third Draft: Coding the Player
Index
List of Figures
To of add a player to our scrolling game field, we'll need to follow four steps: List Tables 1. Code the Player class. 2. Code the keyboard event of the game window to gather the player's input and set the appropriate values for doing the translations (moving) the player's plane. 3. Code the MovePlayer method of the RiverEngine class. 4. Call the MovePlayer method from within the Render procedure. We won't code the collision detection now, but we can already include the images for dying and starting a new life in the Player class, as defined in the game project and shown in the next sample. Imports Microsoft.DirectX.Direct3D Public Class ClsPlayer Inherits clsSprite Public Status As enPlayerStatus Enum enPlayerStatus Flying = 0 Dying = 1 Starting = 2 Shooting = 3 End Enum
Protected.NET DyingImage As Direct3DTexture8 Game Programming with DirectX 9.0 Protectedby StartingImage As Direct3DTexture8 ISBN:1590590511 Alexandre Santos Lobão and Ellen Hatton Private DyingSound As ClsGameSound Apress © 2003 (696 pages) Private StartingSound As ClsGameSound The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and Public Gas As Single = 100 programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Sub New() Shadows Sub Draw() End Class Table of Contents
.NET Game Programming with DirectX 9.0 Foreword
The images for the player's plane are shown in Figure 4-19.
Preface
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Figure Images Tiled usedGame for theFields, player's plane and DirectAudio Chapter 4 - 4-19: River Pla.Net: Scrolling, Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Coding -the New Method Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 7
Chapter 8 -method, .Netterpillars Multiplayer Games and Directplay In the New we'll II: have to initialize the game variables. Calling the Load method of the base class, we D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to can load Chapter 9 the - default Image property for the Player class, and we'll have to add special code for loading the Nonmanaged Code DyingImage and StartingImage properties. We can simply copy and paste the code from the previously Bonus Chapter Porting .Nettrix Pocket PC to a texture. defined Sprite class, whichto loads a file Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Sub New() Dim colorKey As Integer
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index colorKey = Color.FromArgb(255, 255, 0, 255) List of Figures IsTransparent = True List of Tables X = 0 : Y = 0
If Not Load("plane.bmp", colorKey.ToArgb) Then _ Err.Raise(vbObjectError + 1, "clsPlayer", _ "Could not create the player textures") Try DyingImage(i - 1) = TextureLoader.FromFile(objDirect3DDevice, _ Application.StartupPath & "\" & IMAGE_PATH & _ "\dyingPlane" & i & ".bmp", _ 64, 64, D3DX.Default, 0, Format.Unknown, Pool.Managed, _ Filter.Point, Filter.Point, colorKey.ToArgb) StartingImage(i - 1) = TextureLoader.FromFile(objDirect3DDevice, _ Application.StartupPath & "\" & IMAGE_PATH & _ "\startingPlane" & i & ".bmp", _ 64, 64, D3DX.Default, 0, Format.Unknown, Pool.Managed, _ Filter.Point, Filter.Point, colorKey.ToArgb) Catch MsgBox("Could not create the player textures", MsgBoxStyle.Critical) End Try End Sub
In the next section we'll code the Draw method, which will enable us to see on screen the images loaded by the New method.
Coding the Draw Method .NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre andthe Ellen As for the Draw method, we'll Santos have toLobão shadow base property Draw, including a select Case that will Hatton choose which image must be drawn based on the current player status. This player status must be set to Apress © 2003 (696 pages) Dying by the game engine when a collision occurs or when the plane runs out of fuel.
The authors of this text show how easy it can be to produce
interesting multimedia games using Managed DirectX and a new life on screen; for this we'll We'll need to control the time for displaying the images for dying and9.0 starting programming with Visual Basic .NET on Everett, the latest employ the sameversion technique we have used of Microsoft's Visualbefore Studio.for controlling the frame rate (getting the current clock tick and controlling the milliseconds for each image).
The of next code sample shows our Draw procedure, including a Gas property that is decremented as the plane Table Contents flies.Game If we Programming run out of gas, theDirectX player9.0 status will be automatically set to Dying. .NET with Foreword
Shadows Sub Draw() Preface Static LastTick As Integer = 0 Introduction on GDI+ alpha only if the sprite has transparent colors Chapter'1 Turn - .Nettrix: andblending Collision Detection ThenIntelligence and Sprites ChapterIf 2 IsTransparent - .Netterpillars: Artificial objDirect3DDevice.RenderState.AlphaBlendEnable = True - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ End If
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Select Case Status Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Case enPlayerStatus.Flying Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API objDirect3DDevice.SetTexture(0, SpriteImage) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay objDirect3DDevice.SetStreamSource(0, VertBuffer, 0) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to objDirect3DDevice.DrawPrimitives(PrimitiveType.TriangleStrip, 0, 2) Chapter 9 Nonmanaged Code ' when flying, subtracts the gas counter every half second Bonus Chapter Porting .Nettrix to Pocket PC If System.Environment.TickCount - LastTick >= 500 Then Appendix A - The State of PC Gaming = System.Environment.TickCount LastTick Appendix B - MotivationsGas in Games -= 0.5 Appendix C - How Do I Make ' ifGames? the tank is empty, destroy the plane Appendix D - Guidelines If for Developing Games Gas < 0 Successful Then Index Status = enPlayerStatus.Dying List of Figures End If End If List of Tables LastTick = System.Environment.TickCount Case enPlayerStatus.Dying DyingSound.Play() objDirect3DDevice.SetTexture(0, DyingImage) objDirect3DDevice.SetStreamSource(0, VertBuffer, 0) objDirect3DDevice.DrawPrimitives(PrimitiveType.TriangleStrip, 0, 2) ' start a new life after 2 seconds If System.Environment.TickCount - LastTick >= 3000 Then LastTick = System.Environment.TickCount Status = enPlayerStatus.Starting End If Case enPlayerStatus.Starting objDirect3DDevice.SetTexture(0, StartingImage) objDirect3DDevice.SetStreamSource(0, VertBuffer, 0) objDirect3DDevice.DrawPrimitives(PrimitiveType.TriangleStrip, 0, 2) ' restore the flying status after 3 seconds If System.Environment.TickCount - LastTick >= 3000 Then Status = enPlayerStatus.Flying End If End Select ' Turn off alpha blending if the sprite has transparent colors If IsTransparent Then
objDirect3DDevice.RenderState.AlphaBlendEnable = False End If .NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen End Sub Hatton Apress © 2003 (696 pages)
The authors of this easy itthe can be to object produce That's all for the Player class. Nowtext weshow wanthow to create player on the GameEngine class, and code multimedia games Managed 9.0 and theMovePlayerinteresting method, which will move theusing player across DirectX the screen, as described in the next sections. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Creating the Player Object
We'llofcreate the player object inside the Initialize method of the GameEngine class. Since the New Table Contents method ofProgramming the Player class takes no .NET Game with DirectX 9.0parameters, all we need to do is create the object and check if this has been done correctly. Foreword Preface
Player = New ClsPlayer() If Player Is Nothing Then Chapter 1 - .Nettrix: GDI+ and Collision Detection Initialize = False Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Exit Function Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ End If Introduction
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 -section Magic KindergarteN.: Adventure ADO.NET, and DirectShow In the next we'll include the code forGames, the GameEngine class that will call the Draw method of the Chapter 7 class, - Magic KindergarteN. II:the Animation andscreen Speechand APImove it. Player allowing us to see player'sTechniques plane on the Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Coding the D-iNfEcT: MovePlayer Multithreading, Method Nonrectangular Windows, and Access to Chapter 9 -
Nonmanaged Code Before codingPorting the keyboard and Bonus Chapter .Nettrix control to Pocket PCthe MovePlayer procedure, let's take a step back and review the
conceptsA for applying transformations to objects. Appendix - The State of PC Gaming Appendix B - Motivations in Games
As we were reminded when coding the scrolling feature of the game, to perform transformations on an object defined by its vertices stored in the vertex buffer, all we need to do is set the Transform.World property of the Appendix D - Guidelines for Developing Successful Games device object. Appendix C - How Do I Make Games? Index
List Figures Butofwhat if we want to apply different transformations to a certain object? In our specific case, we want the List game of Tables field to scroll and the player's plane to move according to the keys pressed by the player.
In such a case, all we need to do is to set different world matrices for each object according to the effect we want to have. For this example, we'll loop through the following steps: 1. Set the world matrix to perform the translation to implement the scrolling. 2. Draw the tiles. 3. Set the world matrix to perform the translation, according to the keys pressed, to implement the player's movements (overwriting the previous world matrix). 4. Draw the player. As we did in the Scroll procedure, to control the player we'll use a static Matrix to store the player's movements. Looking at the New procedure shown previously, we can see that the player coordinates were set to (0,0); and although the vertices will all stay in the position in which they were first created, we'll see the player's plane moving if we set the correct translations. The value for the translations to be applied in each direction will be set at the KeyDown event of the game window, by simply setting the SpeedX or SpeedY properties (defined in the base class Sprite) to the current game speed using negative values where appropriate. Sub GameWindow_KeyDown(sender As Object, e As KeyEventArgs) _ Handles MyBase.KeyDown
Select Case e.KeyCode Game Programming with DirectX 9.0 Case.NET Keys.Right ISBN:1590590511 by Alexandre Santos Lobão and Ellen = RiverPlanet.gameSpeed RiverPlanet.Player.SpeedX Hatton Case Keys.Left Apress © 2003 (696 pages) RiverPlanet.Player.SpeedX = -RiverPlanet.gameSpeed authors of this text show how easy it can be to produce CaseTheKeys.Up interesting multimedia games using Managed DirectX 9.0 and RiverPlanet.Player.SpeedY RiverPlanet.gameSpeed programming with Visual Basic .NET on=Everett, the latest Caseversion Keys.Down of Microsoft's Visual Studio. RiverPlanet.Player.SpeedY = -RiverPlanet.gameSpeed End Select Table Contents End ofSub .NET Game Programming with DirectX 9.0 Foreword
TheMovePlayer method will follow the basic structure of the Scroll method, but it'll use the properties set Preface for the player in the preceding code to build the translation matrix. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection Public MovePlayer() Chapter 2 Sub - .Netterpillars: Artificial Intelligence and Sprites
theFirst player position in and the middle of screen (x-axis) Chapter'3 Initializes - Managed DirectX Steps: Direct3D Basics DirectX vs. GDI+ Chapter'4
tilesTiled upGame (y-axis) -and River 3Pla.Net: Fields, Scrolling, and DirectAudio
PlayerMatrix As MATRIX = Matrix.Translation(_ ChapterStatic 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
10 * clsSprite.IMAGE_SIZE, 3 *and clsSprite.IMAGE_SIZE, 0) - Magic KindergarteN.: Adventure Games, ADO.NET, DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
If Player.Status = Player.enPlayerStatus.Flying Or _ - .Netterpillars II: Multiplayer Games and Directplay Player.Status = Player.enPlayerStatus.Starting Then D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 '- Draw the player sprite, moving acording to the arrow keys pressed Nonmanaged Code If Player.SpeedX <> 0 Or Player.SpeedY <> 0 Then Bonus Chapter Porting .Nettrix to Pocket PC PlayerMatrix = Matrix.Multiply(PlayerMatrix, _ Appendix A - The State of PC Gaming Matrix.Translation(Player.SpeedX, Player.SpeedY, 0)) Appendix B - Motivations in Games End If Appendix C - How Do I Make Games? ' Reset the speed of the sprite to prevent the plane from moving Appendix D - Guidelines for Developing Successful Games ' after the player releases the arrow keys Index RiverPlanet.Player.SpeedX = 0 List of Figures RiverPlanet.Player.SpeedY = 0 List of Tables End If objDirect3DDevice.Transform.World = PlayerMatrix Player.Draw() End Sub Chapter 8
All we need to do now is include a call to the MovePlayer method in the Renderprocedure, and we are ready to test our plane by moving it around the screen. By this stage, our game designer should have developed a larger game field, so we can fly around over whole new backgrounds, as shown in Figure 4-20.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface
Figure 4-20: Our plane flying over trouble waters
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection If you were test this game at thisIntelligence point, one and thingSprites you'd discover is that you can drive your plane off the Chapter 2 - to .Netterpillars: Artificial
screen.3Although youDirectX can come later, it's not a good practice. So we'd better include some testing Chapter - Managed Firstback Steps: Direct3D Basics andgame DirectX vs. GDI+ on our 4movement procedure avoidFields, this, just after the in which we set the PlayerMatrix variable, inside Chapter - River Pla.Net: TiledtoGame Scrolling, andline DirectAudio theif command: - River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 5 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ' the m41 KindergarteN. element represents translation Chapter 7 - Magic II: Animationthe Techniques and Speechon APIthe X axis
If PlayerMatrix.m41 clsSprite.IMAGE_SIZE Chapter 8 - .Netterpillars II: < Multiplayer Games and DirectplayThen _ PlayerMatrix.m41 = clsSprite.IMAGE_SIZE D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 If PlayerMatrix.m41 > (Width - 1) * clsSprite.IMAGE_SIZE Then _ Nonmanaged Code PlayerMatrix.m41 (Width Bonus Chapter Porting .Nettrix to=Pocket PC - 1) * clsSprite.IMAGE_SIZE Appendix A - The State of PC Gaming
' the m42 element represents the translation on the Y axis Appendix B - Motivations in Games If PlayerMatrix.m42 < clsSprite.IMAGE_SIZE Then _ PlayerMatrix.m42 = clsSprite.IMAGE_SIZE Appendix D - Guidelines for Developing Successful Games If PlayerMatrix.m42 > (Height - 1) * clsSprite.IMAGE_SIZE Then _ Index PlayerMatrix.m42 = (Height - 1) * clsSprite.IMAGE_SIZE Appendix C - How Do I Make Games?
List of Figures List of Tables
We can now control the plane within the screen limits. In next section we'll code the collision detection functions, so the first version of our game will be almost finished.
Fourth Draft: Collision Detection The collision detection in our game will be fairly simple: We'll use an algorithm that will provide approximate results to make the code simpler. Although it's not very accurate, it'll suffice for fair game play. The basic idea here is to check the current player position, convert it to (x,y) coordinates of the Tiles array, and then check the tile array element we are over, to see if we are colliding. There'll be three types of collisions: If we are over water, we aren't colliding. If we are over a gas barrel, we aren't colliding, but we'll need to destroy the gas barrel tile, fill our tank with some gas, and create a new tile (with water) to replace the gas tile. If we are over a bridge, a ship, or a plane, we are colliding. TheTestCollision method will return a Boolean indicating if we are colliding or not, so the Render procedure will deal with the collision as appropriate. One last point before looking at the code for this procedure: As mentioned in the previous draft, when coding
the player's movements, the player vertices will always be at the original positions they were created; what we'll with DirectX 9.0 do is change the .NET worldGame matrixProgramming to see the player in different positions. So, to allow the TestCollision ISBN:1590590511 by Alexandre Santos Lobão and Ellen procedure to get the current player position, we'll need to update the X and Y properties of the player as he or Hatton she moves. All we need to do is to add the next lines of code to the MovePlayer method, just before the lines Apress © 2003 (696 pages) in which we set the PlayerMatrix transformation matrix: The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and ' Updates programming the player with Visual location Basic .NET (used on Everett, in collision the latest detection) version of Microsoft's Visual Studio. Player.X = PlayerMatrix.m41
Player.Y = PlayerMatrix.m42 Table of Contents .NET Programming withTestCollision DirectX 9.0 TheGame complete code for the procedure is shown in the following sample: Foreword Preface
Private Function TestCollision() As Boolean Dim x As Integer, y As Integer Chapter 1 -Dim .Nettrix: GDI+ and Collision Detection i As Integer Introduction Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
-xManaged DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ = Player.X / 32
Chapter 4
-yRiver Pla.Net: Tiled + Game and DirectAudio = (Player.Y 16)Fields, / 32Scrolling, + CurrentLineNumber
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
-'Magic If KindergarteN.: we are overAdventure water or Games, over ADO.NET, a gasand barrel, DirectShow we are not colliding
Chapter 7
Not (tiles(x, Is Nothing) -If Magic KindergarteN. II: y) Animation TechniquesThen and Speech API
Chapter 8
If tiles(x, y).Type = and ClsTile.enType.Water Then - .Netterpillars II: Multiplayer Games Directplay
Chapter 9
-
TestCollision = False Windows, and Access to D-iNfEcT: Multithreading, Nonrectangular Nonmanaged ElseIfCode tiles(x, y).Type = ClsTile.enType.Gas Then
' Remove thePCgas barrel from screen Bonus Chapter Porting .Nettrix to Pocket tiles(x, Appendix A - The State of PC Gaming y).Dispose() Appendix B - Motivationstiles(x, in Games y) = New ClsTile("water.bmp", _
New POINT(x, y), ClsTile.enType.Water) Appendix C - How Do I Make Games? = False Appendix D - Guidelines TestCollision for Developing Successful Games Player.Gas = Player.Gas + 30 If Player.Gas > 100 Then Player.Gas = 100
Index List of Figures List of Tables
Else ' If we collide with a ship or a plane, destroy it... If tiles(x, y).Type = ClsTile.enType.Plane Or _ tiles(x, y).Type = ClsTile.enType.Ship Or _ tiles(x, y).Type = ClsTile.enType.Bridge Then tiles(x, y).Dispose() tiles(x, y) = New ClsTile("water.bmp", _ New POINT(x, y), ClsTile.enType.Water) End If TestCollision = True End If
Else TestCollision = True End If End Function
The code for the Render procedure will have to deal with the results of the TestCollision procedure, changing the player status and removing one life from the game's Lifes property, as shown in the following code sample: Public Overrides Sub Render() ' Scrolls the game field and moves the player Scroll()
Draw() .NET Game Programming with DirectX 9.0 MovePlayer() by Alexandre Santos Lobão and Ellen Hatton ' Only tests for collision if flying Apress © 2003 (696 pages)
ISBN:1590590511
If Player.Status = Player.enPlayerStatus.Flying Then authors a of this text show how it can be to produce ' If The there's collision, seteasy player status to dying interesting multimedia games using Managed DirectX 9.0 and If TestCollision() Then programming with Visual Basic .NET on Everett, the latest Player.Status = Visual Player.enPlayerStatus.Dying version of Microsoft's Studio. Lifes -= 1 If Lifes = 0 Then Table of Contents GameOver = True .NET Game Programming with DirectX 9.0 End If Foreword End If PrefaceEnd If Introduction End Sub Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
We can now run the game's new version, flying more carefully because now we are flying at lower altitude, as - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ shown in Figure 4-21.
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 4-21: The plane now collides with any solid obstacles-in this case, a bridge
Final Version: Music and Sound Effects Since our base sound manipulation library is coded, the task of including sounds in our application is very simple. All we need to do is to create the sound objects and call them as appropriate. Since we want to play some motifs randomly over the background music, we'll code the PlayMotifs method, as defined in the game project, to do so. TheBackgroundMusic object and the GasSound object must be created in the Initialize method of the RiverEngine class, so they'll be accessible to all other methods. As for the background music, we can start playing it right after the object creation; it'll be looping until the game end. ' Start the background music BackgroundMusic = New ClsGameMusic() BackgroundMusic.Initialize(WinHandle) If Not BackgroundMusic.Load("boidsd.sgt") Then MessageBox.Show("Error loading background music", "River Pla.Net") End If BackgroundMusic.Play()
' Initializes the gas filling sound effect .NET Game Programming with DirectX 9.0 GasSound = New ClsGameSound(Owner) ISBN:1590590511 by Alexandre Santos Lobão and Ellen If Not GasSound.Load("FillGas.wav") Then Hatton MessageBox.Show("Error loading Gas sound effect", "River Pla.Net") Apress © 2003 (696 pages) End If The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
As for the player game effects, we need to add the object creation to the New procedure of the Player class: Table of ' Contents Initializes the sound effects .NET Game Programming with DirectX 9.0 DyingSound = New ClsGameSound(Owner) Foreword If Not DyingSound.Load("explosion.wav") Then Preface MessageBox.Show("Error loading explosion sound effect", "River Pla.Net") Introduction End If ChapterStartingSound 1 - .Nettrix: GDI+=and New Collision ClsGameSound(Owner) Detection
If Not
StartingSound.Load("init.wav") Then Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
loading effect", "River Pla.Net") -MessageBox.Show("Error Managed DirectX First Steps: Direct3D Basicsstarting and DirectXsound vs. GDI+
ChapterEnd 4 -If River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Once we have created the sound objects, all we need to do is call the Play method of each object where - Magic KindergarteN. II: Animation Techniques and Speech API appropriate.
Chapter 7 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
In the TestCollision D-iNfEcT: Multithreading, procedure, Nonrectangular when the player Windows, collides and with Access a gas to barrel, we'll play the "gas bonus" Chapter 9 sound. Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
GasSound.Play()
Appendix B - Motivations in Games Appendix C - How Do I Make Games?
In the method the Player class, we'll play the "dying" sound every time the player has a status of Appendix D -Draw Guidelines for of Developing Successful Games Index Dying. List of Figures List ofDyingSound.Play() Tables
In this same method, we'll play the "starting a new life" sound every time the player has a status of Starting. StartingSound.Play()
This will suffice to add music and sound effects to our game. And to add that little bit extra, for subtle variations in the background music from time to time, we'll code the PlayMotifs function. This function will be called with every frame that's drawn on the Render method, so we'll include two random choices: first, choosing a random time (let's say, between 5 and 15 seconds) to wait for the next motif to play, and choosing a random motif to play, using the PlayMotif method of our GameSound class and passing an index between zero and the value of the MotifCount property, as shown in the next code sample: Sub PlayMotifs() Dim MotifIndex As Integer Static LastTick As Integer Static Interval As Integer ' Plays a random motif every 5 to 15 seconds If System.Environment.TickCount - LastTick >= Interval Then
LastTick = System.Environment.TickCount Game Programming with DirectX(in 9.0 miliseconds) to play the next motif '.NET Gets a new random interval ISBN:1590590511 by Alexandre Santos Lobão and Ellen Interval = (Rnd() * 10 + 5) * 1000 Hatton MotifIndex = Rnd() * BackgroundMusic.MotifCount Apress © 2003 (696 pages) BackgroundMusic.PlayMotif(MotifIndex) End If End Sub
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
And that's all for this chapter. The game is up to the standard described in the game project. But there are a lot Table of Contents we can make, as shown in the next section and in the next game version, in Chapter 5, when of improvements .NET we'llGame introduce Programming DirectInput with and DirectX joystick 9.0 control. Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Adding the .NET Final Touches by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton We'll code a second version of our game in the next chapter, with many improvements, but there is already Apress 2003 (696now, pages)as shown in the next sections. some upgrading we can©do right The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Including Player Animations
A good improvement would be to include some player animations for dying and starting a new life. Animations are only a set of images that are presented, one at a time, using specific time intervals. To define an Table of Contents animation, we should take account .NET Game Programming withinto DirectX 9.0 the total time we'll have to play the animation and the number of frames we want to display. Foreword Preface
For the total time for each animation, we can simply check the duration of each sound effect: about 1 second for the explosion sound, and about 2 seconds for the sound of starting a new life.
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter To create 2 -an .Netterpillars: interesting explosion Artificial Intelligence animation, and we'llSprites need as many images as possible. Figure 4-22 shows a
minimal3 set for an explosion animation. Chapter - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Figure 4-22: Explosion images for dying animation
Appendix B - Motivations in Games
Appendix - Howseven Do I Make Games? Since weC have images, we can calculate the desired interval between each image: about 0.15 seconds. Appendix D - Guidelines for Developing Successful Games
Figure 4-23 shows a second set of images that will be used to give the player a visual clue that the plane is Index invincible when starting a new life. List of Figures List of Tables
Figure 4-23: Flashing planes for starting a new life animation In this case, we can use a different approach: Let's simply show the images from the first to the fourth, and then from the fourth down to the first, so the animation will appear to be flashing to the player. To implement the animations, we'll need to change the Player class as follows: Change the DyingImage and the StartingImage properties from variables to arrays. Adjust the New method to dimension the arrays to the appropriated values. On the New method, load each of the images to the corresponding array position. On the Draw method, include the code for displaying the images one at a time, taking into account the specified interval between images. The modifications of the Player class are shown in the following code listing: Protected DyingImage() As Direct3DTexture8 Protected StartingImage() As Direct3DTexture8 Sub New()
ReDim DyingImage(7) .NET Game Programming with DirectX 9.0 ReDim StartingImage(4) by Alexandre Santos Lobão and Ellen Dim colorKey As Integer Hatton Dim i As Integer
ISBN:1590590511
Apress © 2003 (696 pages)
authors of this text show how easy it0, can255) be to produce colorKey The = Color.fromARGB(255, 255, interesting multimedia games using Managed DirectX 9.0 and . . . programming with Visual Basic .NET on Everett, the latest Try version of Microsoft's Visual Studio. For i = 1 To 7 DyingImage(i - 1) = TextureLoader.FromFile(objDirect3DDevice, _ Table of Contents Application.StartupPath & "\" & IMAGE_PATH & _ .NET Game Programming with DirectX"\dyingPlane" 9.0 & i & ".bmp", _ Foreword 64, 64, D3DX.Default, 0, Format.Unknown, Pool.Managed, _ Preface Filter.Point, Filter.Point, colorKey.ToArgb) IntroductionNext i = GDI+ 1 Toand 4 Collision Detection Chapter 1 For - .Nettrix: StartingImage(i - 1) =and TextureLoader.FromFile(objDirect3DDevice, _ Chapter 2 - .Netterpillars: Artificial Intelligence Sprites Application.StartupPath "\" & IMAGE_PATH & _ Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs.& GDI+ "\startingPlane" & i & ".bmp", _ Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio 64, and 64,Writing D3DX.Default, Chapter 5 - River Pla.Net II: DirectInput Text to Screen 0, Format.Unknown, Pool.Managed, _ Filter.Point, Filter.Point, colorKey.ToArgb) Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Next Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Catch Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay MsgBox("Could not create the player textures", MsgBoxStyle.Critical) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterEnd 9 -Try Nonmanaged Code . . . Bonus Chapter Porting .Nettrix to Pocket PC End Sub Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Shadows Sub Draw() Static CountAnim As Integer = 0 AppendixStatic D - Guidelines for Developing Successful Games LastTick As Integer = 0 Index Static IncAnim As Integer = 1 List of Figures . . . List of Tables Select Case Status Case enPlayerStatus.Flying . . . Case enPlayerStatus.Dying If CountAnim = 0 Then DyingSound.Play() End If ' Each frame will be shown for .15 seconds, ' the 7 frames of the explosion in about 1 second If System.Environment.TickCount - LastTick >= 150 Then LastTick = System.Environment.TickCount CountAnim += 1 End If objDirect3DDevice.SetTexture(0, DyingImage(_ IIf(CountAnim - 1 < 0, 0, CountAnim - 1))) objDirect3DDevice.SetStreamSource(0, VertBuffer, 0) objDirect3DDevice.DrawPrimitives(PrimitiveType.TriangleStrip, 0, 2) ' The dying animation is 7 frames long If CountAnim = 6 Then CountAnim = 0 Status = enPlayerStatus.Starting End If Case enPlayerStatus.Starting Appendix C - How Do I Make Games?
If CountAnim = 0 Then .NET Game Programming with DirectX 9.0 StartingSound.Play() ISBN:1590590511 by Alexandre Santos Lobão and Ellen End If Hatton objDirect3DDevice.SetTexture(0, StartingImage(CountAnim)) Apress © 2003 (696 pages)
objDirect3DDevice.SetStreamSource(0, VertBuffer, 0)
The authors of this text show how easy it can be to produce objDirect3DDevice.DrawPrimitives(PrimitiveType.TriangleStrip, 0, 2) interesting multimedia games using Managed DirectX 9.0 and ' The starting animation isEverett, 4 frames long, programming with Visual Basic .NET on the latest ' and must run inStudio. a reverse loop version of Microsoft's Visual
If CountAnim = 3 Then IncAnim = -1 If CountAnim = 0 Then IncAnim = 1 Table of Contents .NET Game Programming with frame DirectX 9.0 ' Each will show a different frame of the animation Foreword CountAnim += IncAnim Preface Introduction
' restore the flying status after 4 seconds
Chapter 1
IfGDI+ System.Environment.TickCount - LastTick >= 4000 Then - .Nettrix: and Collision Detection
Chapter 2
CountAnim = 0 - .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
Status = enPlayerStatus.Flying - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
' Tiled We have a newScrolling, plane, fill the tank! - River Pla.Net: Game Fields, and DirectAudio
Chapter 5
= 100 and Writing Text to Screen - River Pla.NetGas II: DirectInput
End If - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow End Select Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API . . . Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Sub Chapter 6
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Implementing a Neverending Game Map
Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
So we managed to define a map with several hundreds of tiles. And what happens when the user reaches the end of the game map?
Appendix D - Guidelines for Developing Successful Games Index
List of Figures Since we'll have no ending screen, we can use a little trick to make our game field infinite in length. List of Tables
Adding some code to reset the scroll translation matrix to the beginning of the game map when we reach the end will make the player loop forever on our game. To allow a smooth transition, we can copy the first 15 lines of the game to the end of the game map, so when we return to the beginning the player won't notice a difference. We can add an extra degree of playability to our game by including the concept of different phases: Every time the player reaches the end of the map, we can increase the game speed, so that even though he or she starts the same game field, the game increases in difficulty. To do this we'll need to change the code for the Scroll method, including a new test within the if command that increments the current line number counter, to reset the scroll matrix and increase the game speed (using a new constant, gameSpeedIncrease), as shown in the next code lines: Private gameSpeedIncrease As Single = 1.3 . . . ' If we ended our game map, start it all over again, but with increasing speed If CurrentLineNumber + Height = GameMapSize Then gameSpeed = gameSpeedIncrease * gameSpeed ' The maximum gameSpeed will be the size of a tile per frame If gameSpeed > 32 Then gameSpeed = clsSprite.IMAGE_SIZE ScrollMatrix = Matrix.Identity CurrentLineNumber = 0 End If
.NET Game Programming with DirectX 9.0 ISBN:1590590511 by we'll Alexandre Santos Lobão and Ellen In the next chapter see some more improvements when we code the second version of River Pla.Net.
Hatton Apress © 2003 (696 pages)
Improving the Performance The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
Taking our sample game as anwith example, we can see we are a lot of time drawing each tile by programming Visual Basic .NET onthat Everett, thespending latest itself. Looking at the Draw of the Tile class, we can see that for every tile we are calling three version of method Microsoft's Visual Studio. functions: Table of Contents
objDirect3DDevice.SetTexture(0, SpriteImage) objDirect3DDevice.SetStreamSource(0, VertBuffer, 0) objDirect3DDevice.DrawPrimitives(PrimitiveType.TriangleStrip, 0, 2)
.NET Game Programming with DirectX 9.0 Foreword Preface Introduction
Chapter 1 - .Nettrix: GDI+ Collision Detection In commercial games we'lland usually want a higher frame rate, so we need to set aside the simplicity and use Chapter higher performance 2 - .Netterpillars: algorithms. Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
A simple way to speed up the game is to group equal tiles together, in a big vertex buffer, so we could call these - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio three functions only once for each texture. Since the DrawPrimitives function can receive the first vertex to Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen draw and the number of primitives (triangle strips, in our case), all we need do is store a vertex number in the Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Tile class, so we can pick the first tile and the last tile of each type on screen and calculate the values for the Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API DrawPrimitives function. Chapter 4
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular to Since our goal here is to introduce the gamingWindows, concepts,and weAccess didn't spend time on optimizations; in the next Chapter 9 main chapter we'llNonmanaged include extraCode features in our game, such as joystick control, but the game engine will remain Bonus Chapter Porting .Nettrix to Pocket PC basically the same. Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Summary
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton In this chapter, we managed to use the Direct3D concepts discussed in the previous chapter to create an ApressRiver © 2003Pla.Net. (696 pages) interesting new game, Among the many new points learned are the following: The authors of this text show how easy it can be to produce
An introduction to DirectAudio library, including the basicDirectX concepts interesting multimedia games using Managed 9.0about and music and sound with Visual Basic on Everett, the latest reproductionprogramming through the DirectSound and .NET DirectMusic interfaces. version of Microsoft's Visual Studio.
The creation of a new game library, including two graphic classes (Sprite and GameEngine) and two audio classes (GameSound and GameMusic).
Table of Contents
.NET Game Programming with DirectX 9.0 How to employ some advanced object-oriented concepts in programming, like the use of overrideable Foreword functions. Preface
The introduction of two new game concepts, tile-based game fields and scrolling games, and a practical example of their use.
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 -chapter, .Netterpillars: Artificialsome Intelligence and Sprites In the next we'll include enhancements in our game, introducing two new concepts Chapter 3 Managed DirectX First Steps: Direct3D and DirectX including vs. GDI+ the use of force feedback in indispensable in every game: input device controlBasics with DirectInput, Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio joysticks, and the practice of writing text on the device context screen used by Direct3D. Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Chapter .NET 5: River Pla.Net II: DirectInput and Writing ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Text to Screen Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's VisualRiver Studio. In this chapter, we'll improve the Activision Raid clone, River Pla.Net, by including some extra
Overview
features, such as proper input device controls and force-feedback joystick control (see Figure 5-1). Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix Figure C - 5-1: How River Do I Make Pla.Net Games? II, this chapter's sample game Appendix D - Guidelines for Developing Successful Games
The implementation of appropriate handling for input devices is crucial to guarantee a smooth, playable Index
game and to get the user's attention. In this chapter, we'll examine the DirectInput set of components, which deals with collecting player input from various devices and returning feedback when the peripherals List of Tables have a purpose for this. List of Figures
We'll also extend the use of matrices for moving objects, as we saw in the last chapter, to implement moving enemies and bullets. Another new technique we'll discuss in this chapter is how to write text directly to a given position of our device. We'll apply all the concepts explained in the next sections in the second version of our game.
.NET Game Programming with DirectX 9.0 The GameFont Class by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Writing text on screen isn't difficult, but we can make it even simpler by creating a specific class to handle text Apress © 2003 (696 pages) output to the current device. The authors of this text show how easy it can be to produce
Since we'll have to access the device object in the GameEngine class, we should derive our new interesting multimedia gamescreated using Managed DirectX 9.0 and GameFont class programming from it, so thewith device Visual object Basicwill .NET always on Everett, be encapsulated the latest and hidden from our eyes when we are creating new version games.of Microsoft's Visual Studio. TheGameFont class will be very simple, with only five properties and two methods, as shown in Table 5-1.
Table of Contents
.NET Game Programming with DirectX 9.0
Table 5-1: The GameFont Class Members
Foreword
TYPE Preface Introduction
Property
Chapter 1
NAME
DESCRIPTION
Font
The D3DFont object used for writing on screen.
- .Nettrix: GDI+ and Collision Detection
LocationArtificial Intelligence Property The (x,y)and point from the top-left position from which to draw the Chapter 2 - .Netterpillars: Sprites Chapter 3
font. - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 - River Pla.Net: Tiled Scrolling, BoxWidth andGame Fields, Properties The size of the and box DirectAudio that will contain the text to be drawn. Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen BoxHeight Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Property The textTechniques to be drawn. Chapter 7 - Magic KindergarteN. II: Animation and Speech API Text
Chapter 8 - .Netterpillars Games Directplay Color II: MultiplayerThe Property colorand used for the text. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 New Method Nonmanaged The class constructor, which will receive the text, position on Code
and font characteristics. Bonus Chapter Porting .Nettrix to Pocketscreen, PC Appendix State of PC Gaming MethodA - The Draw Appendix B - Motivations in Games Appendix C - How Do I Make Games?
As with the New method, creating some overloaded functions with different parameters will give us the flexibility necessary to cover each game's needs.
Appendix D - Guidelines for Developing Successful Games Index Here is the code for the class interface: List of Figures List of Tables Public Class ClsGameFont
Inherits clsGameEngine Public D3DFont As Font Private BoxWidth As Integer, BoxHeight As Integer Public Location As Point Public Text As String ' Default color: Yellow color Public Color As Integer = Color.FromARGB(255, 255, 255, 0) Sub New(strName As String, intSize As Integer, _ strText As String, startPosition As Point) Public Sub Draw() End Class
The DirectX Font data type, used to define the D3DFont object, has the usual parameters we would expect for font objects: size, font name, style (italic, bold, etc.), and others. To create this object, we'll use a regular systemFont object, setting its properties and then passing the handle of such an object to the creator of the DirectXFont. Once created, we'll use three simple methods of the Font object to draw the font: Begin: Informs the device that we are going to write something on screen
.NET Game Programming with DirectX 9.0 Draw: Receives the text to be drawn, the text color, the containing box, and the text alignment to be used, ISBN:1590590511 Alexandre Santos Lobão and Ellen and does theby writing Hatton Apress © 2003 (696 pages)
End: InformsThe theauthors device we have finished writing of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and with Visual Basic .NET on the latest We need to use aprogramming block with these three commands forEverett, every piece of text we want to write at a minimum, version have of Microsoft's Visual Studio. since we can effectively many Draw calls between Begin and End. These commands will be encapsulated inside the Drawmethod of our GameFont class. Table ofnext Contents In the sections we'll see the code for the GameFont'sNew and Draw methods. .NET Game Programming with DirectX 9.0 Foreword
Coding the New Method
Preface
Introduction TheNew method is very straightforward; we simply create the Font object according to the parameters Chapter 1 create - .Nettrix: and Collision received, the GDI+ DirectX Font, andDetection set some of the class properties. Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Sub New(strName As String, intSize As Integer, _ - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio strText As String, startPosition As Point) Chapter 5 Dim - River Pla.Net II: DirectInput and Writing Text to Screen SystemFont As System.Drawing.Font Chapter 6 SystemFont - Magic KindergarteN.: Games, ADO.NET, and DirectShow = New Adventure System.Drawing.Font(strName, intSize, _ Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API FontStyle.Bold, GraphicsUnit.Pixel) Chapter 8 '- .Netterpillars II: Multiplayer Games and Directplay Creates the Font object D-iNfEcT:=Multithreading, Nonrectangular Windows, and AccessSystemFont) to D3DFont D3DX.CreateFont(objDirect3DDevice, Chapter 9 Code ' Nonmanaged Sets the class properties Bonus Chapter Porting .Nettrix Pocketof PC a char is less than the height so using the height ' Usually the to width Appendix A '- The State of PC Gaming will provide us with a reasonable approach Appendix B BoxWidth - Motivations=inSystemFont.Height Games * strText.Length Appendix C BoxHeight - How Do I Make = SystemFont.Height Games? Appendix D Location - Guidelines = for startPosition Developing Successful Games Text = strText Index SystemFont.Dispose() List of Figures End Sub List of Tables Chapter 4
In the next section, we'll look at the Draw method implementation.
Coding the Draw Method TheDraw method, as we expect, will draw specific text, using the chosen font, on the screen. We can think of a dozen possible overloads for the Draw method, receiving one or more of the following parameters: the text color, the text position, any of the font style properties, etc. However, we're going to create only three overloads: one with no parameters (which will use the default values when creating the font), one that will receive the text to be drawn, and one that will receive the text and position on screen. If we think other overloads will be useful in future games, we can add these one at a time, as they are needed. The next code listing presents these three overloads: Public Sub Draw() D3DFont.Begin() D3DFont.DrawText(Text, New Rectangle(Location.X, _ Location.Y, BoxHeight, BoxWidth), 0, Color) D3DFont.End() End Sub
Public Sub Draw(Text As String) .NET Game Programming with DirectX 9.0 D3DFont.Begin() by Alexandre Santos Lobão New and Ellen D3DFont.DrawText(Text, Rectangle ISBN:1590590511 (Location.X, _ Hatton Location.Y, BoxHeight, BoxWidth), 0, Color) Apress © 2003 (696 pages) D3DFont.End() The authors of this text show how easy it can be to produce End Sub interesting multimedia games using Managed DirectX 9.0 and Public Sub Draw(Text String, Location As POINT) programmingAs with Visual Basic .NET on Everett, the latest D3DFont.Begin() version of Microsoft's Visual Studio. D3DFont.DrawText(Text, New Rectangle (Location.X, _ Location.Y, BoxHeight, BoxWidth), 0, Color) Table ofD3DFont.End() Contents .NET EndGame Sub Programming with DirectX 9.0 Foreword Preface
In the next sections we'll discuss the classes employed for gathering user input through the keyboard, mouse, Introduction or joystick. Chapter 1 - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Game Input Classes by Alexandre Santos Lobão and Ellen
ISBN:1590590511
DirectX provides Hatton a specific set of objects to handle input from the various input devices. These objects are 2003 (696 pages) flexible enough toApress allow ©the game to use any advanced game device. This set of objects is called DirectInput. The authors of this text show how easy it can be to produce
DirectInput basically deals with three different input Managed devices: keyboard, and joystick—everything that is interesting multimedia games using DirectX 9.0mouse, and programming with Basic game .NET on Everett, the latestwheels) is grouped into this last type. neither a mouse nor a keyboard (forVisual example, pads and steering version of Microsoft's Visual Studio.
Note It makes sense that DirectInput is used for controlling joysticks, but why use it as the handler for the mouse and keyboard, instead of using the default windows handler? There are two main reasons for Table of Contents this: speed and control. DirectInput gives much greater control over the data gathered from the .NET Game device, Programming so youwith canDirectX include9.0 in your program exactly what you want to; and as for the speed, maybe a Foreword simple example may clarify this point: If you use DirectInput to gather input from the keyboard, a Preface simple "Hello" entered by the user would appear as Introduction"HHHHHHHHHHeeeeeeeeeellllllllllooooooooooo". Got it? Chapter 1
- .Nettrix: GDI+ and Collision Detection Although can include the device state polling the main game loop, this isn't a good practice, since we want Chapter 2 we - .Netterpillars: Artificial Intelligence and in Sprites
a loop that result DirectX in a very tight device state, and is as independent from the other game routines as Chapter 3 - will Managed First Steps: Direct3D Basics and DirectX vs. GDI+ possible. - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4
Chapter 5 - River Pla.Net DirectInput and Writing to Screen To accomplish this goal, II: we'll use a different threadText to pool the devices, creating one extra thread for each Chapter - Magic KindergarteN.: Adventure Games, and DirectShow device 6type. We present the threads concept in theADO.NET, next section. Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay Threading Basic Concepts D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Chapter 9
-
Nonmanaged Code
We won't go into great detail about threads here, since we'll see them in a future chapter, but you have to know Bonus Chapter Porting .Nettrix to Pocket PC enough about them to understand the code in this section. Appendix A - The State of PC Gaming
Appendix B - Motivations Games NEW With .NET, in Visual Basic finally has true multithreading. A thread can be thought of as a unit of Appendix IN C - How execution Do I Make insideGames? our program (or process). We usually have only one thread per program, which
.NET means that we'll have only one code sequence (defined by an instruction pointer of the operating Appendix D - Guidelines for Developing Successful Games system) being executed at any one time. Creating additional threads, we can have two or more List of Figuresinstruction pointers for our program, which means parallel execution of different code sequences. Index
List of Tables
To create a thread, all we need to do is create an object of the Thread class, which receives a function address as the constructor parameter, and call its Start method to begin thread execution, as shown in the following lines of code: Dim NewThread as Thread NewThread = New Thread(AddressOf Me.MyFirstThread) InputThread.Start() . . . Sub MyFirstThread () ' Do something End Sub
When dealing with threads, we can encounter some problems, usually called race conditions, when two threads of the same process try to update the same variable or structure. This can lead to corruption of structures and losing values of variables. To avoid this, we must use the Synclock method, which forces a given block of code to be thread safe. This prevents two threads from executing the same block at the same time. In the next section, we'll see how we can use threads with DirectInput to gather user data.
DirectInput Basics
Getting back to DirectInput, basic routinewith to initialize and .NET Gamethe Programming DirectX 9.0get data from input devices is very simple, and can be expressed in the following steps: ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton 1. Initialize DirectInput.
Apress © 2003 (696 pages)
2. Create theThe input authors deviceofobject, this text according show howtoeasy the input it candevice be to produce desired. interesting multimedia games using Managed DirectX 9.0 and programming with Visual onobject. Everett, the latest 3. Set the data format to be read fromBasic the .NET device version of Microsoft's Visual Studio.
4. Set the cooperative level for the device (how our application will interact with other applications, in regard to the input device).
Table of Contents
.NET5. Game Programming with DirectX 9.0 that will check if the application can access the input device and get the Enter a loop (in an extra thread) Foreworddata from it. Preface
Most of the code is the same for any device, but since the data structures are very unique, let's create three Introduction classes for handling the input: Mouse,Keyboard, and Joystick.
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter .Netterpillars: Artificial interface Intelligence In order2 to-provide a higher-level for and the Sprites game engine, we'll create specific events for each class, Chapter 3 Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+as stated here: which will translate the input device data into more meaningful information, Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Keyboard Keypress eventand Writing Text to Screen Chapter 5 - Riverclass: Pla.Net II: DirectInput Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Mouse class: MouseMove,MouseUp, and MouseDown events
Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Joystick class: JoystickMove and JoystickButtonPressed events D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Nonmanaged In the following sections, Code we'll discuss the details of each input class and the corresponding code. Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Defining the Input Classes
Appendix B - Motivations in Games
Appendix C - Howwe'll Do Idefine Make Games? All the classes to encapsulate the features of DirectInput will have similar structures: Each of them must have two properties to store theSuccessful InputObject, Appendix D - Guidelines for Developing Games a reference to the input device, and a method that runs
in a separated thread and is used to pool the device. Index List of Figures
TheInputObject is a reference to the main DirectInput object, which allows us to perform generic DirectInput operations, such as creating a reference to the input device in order to control and get information about a specific device.
List of Tables
Since a thread is also an object, each of the classes must also have another property to store a Thread object and events to send the data gathered from the device to the main application. In Figure 5-2, we can see the class interfaces for all the input classes. Let's take the Mouse class as an example to illustrate the flow of a typical program that uses DirectInput.
Figure 5-2: The input classes When the program creates a new Mouse object, the New method will get a reference to the mouse device and create a new thread that will run the DInputThread method. The reference to this thread is stored in the
InputThread variable.
.NET Game Programming with DirectX 9.0
ISBN:1590590511 TheDInputThread by Alexandre method will Santos haveLobão a never-ending and Ellen loop that keeps polling the device for data, and every Hatton time it gathers some data from the device, it'll call the GetMouseState method. This last method will then © 2003 (696 pages) analyze the data Apress gathered from the mouse and generate the proper event for the application.
The authors of this text show how easy it can be to produce
TheDispose method interesting will simply multimedia free all games usedusing resources. Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest of Microsoft's Visual Studio. This same steps version will be followed by each class that manages a device, in an analogous way. The class interfaces for the input classes are shown in the diagram in Figure 5-2. Table of Contents As you see, most of the properties and methods of the input classes are the same, regardless of the device .NET Game Programming with DirectX 9.0to InputObject and to a device, and all classes will rely on looping type. All classes will have a reference Foreword inside a thread to pool the device. Preface
Table 5-2 lists the properties and methods that are common for every input device, so if we understand how Introduction these properties andGDI+ methods work together, we'll understand all input devices. If you have any doubts about Chapter 1 - .Nettrix: and Collision Detection this topic, back and review the Intelligence mouse example earlier in this section. Chapter 2 go - .Netterpillars: Artificial and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Table 5-2:- Members of the Common Game Input Classes River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4 Chapter TYPE5
- River Pla.Net II: DirectInput and Writing Text to Screen NAME DESCRIPTION
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow InputDevice Property the input and device that API will be used to perform operations Chapter 7 - Magic KindergarteN. II:Reference Animation to Techniques Speech Chapter 8
over the device and to gather data.
- .Netterpillars II: Multiplayer Games and Directplay
Property Chapter 9 -
D-iNfEcT: Multithreading, Nonrectangular Windows, to to pool the input device. InputThread Thread object that will haveand theAccess loop used Nonmanaged Code
New .Nettrix to Pocket Method Method Bonus Chapter Porting PC that will initialize the basic objects and start the polling thread. Appendix State of PC GamingMethod with the loop for gathering data from the input device. DInputThread MethodA - The Appendix B - Motivations in Games
Dispose MethodC - How Appendix Do I Make Games?Finalizer that will destroy appropriately the objects created in the New method. Appendix D - Guidelines for Developing Successful Games Index
Each of the input device control classes will have extra members, according to the type of the device being read. For example, the Mouse class will have events to inform the application about mouse movements and List of Tables button clicks, whereas the Keyboard class will only generate events when keys are pressed. List of Figures
TheKeyboard class will have the extra elements shown in Table 5-3. Table 5-3: Members of the Keyboard Class TYPE
NAME
DESCRIPTION
Property
KeyboardState
KeyboardState structure that will be filled by calling the GetCurrentKeyboardState method of the InputDevice object
Event
Keypress
Event generated by the class to inform the game engine of the code of the keys pressed
Method
GetKeyboardState
Method that will translate the code from the KeyboardState array into values of the System.Windows.Forms.Keys enumeration and generate the Keypress event
TheMouse class will also have some extra elements, which are described in Table 5-4. Table 5-4: Members of the Mouse Class
TYPE
NAME DESCRIPTION .NET Game Programming with DirectX 9.0
Property
MouseState Hatton
Event
MouseMove
by Alexandre Santos Lobão and Ellen
ISBN:1590590511
MouseState structure that will be filled by calling the CurrentMouseState method of the InputDevice object. This Apress © 2003 (696 pages) structure holds data from three mouse buttons and a threeThe authors of this text show how easy it can be to produce coordinate system in which the 9.0 z axis interesting multimedia games using Managed DirectX andis usually associated with the programming with Visual mouse Basic wheel. .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents
Events
Event generated by the class to inform the game engine about mouse movements.
MouseDown and MouseUp
Events generated by the class to inform the game engine when a given button is pressed and when it's released.
GetMouseState
Method that will translate the code from the MouseState structure and generate the mouse events.
.NET Game Programming with DirectX 9.0 Foreword Preface Method Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter TYPE6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow NAME DESCRIPTION
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
TheJoystick class will have the extra members listed in Table 5-5. Table 5-5: Members of the Joystick Class
JoystickState JoyState structure that will be filled by calling the Property - .Netterpillars II: Multiplayer Games and Directplay CurrentJoyState method of the InputDevice D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 object. This structure holds up to 31 buttons, point-of-view Nonmanaged Code (POV) coordinates, three axes for rotation, three axes for Bonus Chapter Porting .Nettrix to Pocket PC the three-coordinate system, and two extra axes as a Appendix A - The State of PC Gaming slider object, whose semantics will depend on the input Appendix B - Motivations in Games device type. In our Joystick class, let's reduce our Appendix C - How Do I Make Games? scope to the buttons and the x and y coordinates. Chapter 8
Appendix D - Guidelines for Developing Successful Games
Event Index
JoystickMove
Event generated by the class to inform the game engine about joystick movements.
Event
JoystickButtonPressed
Events generated by the class to inform the game engine when a given button is pressed.
Method
GetJoystickState
Method that will translate the code from the JoystickState structure and generate the joystick events.
List of Figures List of Tables
Next, we'll code the input classes for each device type.
Creating the Mouse and Keyboard Initialization Code TheKeyboard class interface is shown in the next code listing; the interface for the mouse devices is very similar, with a few differences discussed later. Imports Microsoft.DirectX.DirectInput Imports Microsoft.DirectX Imports System.Threading Public Class ClsKeyboard Inherits clsGameEngine ' General use properties and enumerations Private InputDevice As Device = Nothing Private InputThread As Thread = Nothing
' Keyboard properties and events .NET Game Programming As withkeyboardState DirectX 9.0 Public Shared keyboardState ISBN:1590590511 by Alexandre Santos Lobão and Ellen Public Event Keypress(Keycode As Keys) Public Public Public Public End Class
Hatton Apress © 2003 (696 pages)
Sub New(Parent As Window.Control.Forms) The DInputThread() authors of this text show how easy it can be to produce Sub interesting multimedia games using Managed DirectX 9.0 and Sub GetKeyboardState() programming with Visual Basic .NET on Everett, the latest Sub Dispose() Implements System.IDisposable.Dispose version of Microsoft's Visual Studio.
Table of Contents
TheGame New method will follow same9.0 basic structure for every device, as shown in the next code snippet: .NET Programming withthe DirectX Foreword Preface Public Sub New(ByVal Parent As Window.Control.Forms) Introduction ' Create the device and set the data format ChapterTry 1 -'Ignore .Nettrix: GDI+ errors and Collision for now Detection Chapter 2
= NewIntelligence Device(SystemGuid.Keyboard) -InputDevice .Netterpillars: Artificial and Sprites
Chapter 3
-InputDevice.SetDataFormat(DeviceDataFormat.Keyboard) Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
SetPla.Net: the cooperative level for the device. -'River Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
-InputDevice.SetCooperativeLevel(Parent, River Pla.Net II: DirectInput and Writing Text to Screen _
Chapter 6
CooperativeLevelFlags.Exclusive _ - Magic KindergarteN.: Adventure Games, ADO.NET, andOr DirectShow
CooperativeLevelFlags.Foreground) - Magic KindergarteN. II: Animation Techniques and Speech API Catch Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Try Chapter 7
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
' Create the thread that the app will use ' to get state information from the device. Appendix A - The State of PC Gaming InputThread = New Thread(AddressOf Me.DInputThread) Appendix B - Motivations in Games ' Name it something so we can see in the output Appendix C - How Do I Make Games? ' window when it has exited. Appendix D - Guidelines for Developing Successful Games InputThread.Name = "DInputThread" Index InputThread.Start() List of Figures End Sub Bonus Chapter Porting .Nettrix to Pocket PC
List of Tables
The direct input methods used in the previous code deserve additional explanation. The first method is the DirectInput object constructor, which receives a handle from the current application instance and creates the higher level object for input handling. TheDevice'sNew method creates a new DirectInput Device object, according to the identifier received. There are two identifier constants for the keyboard (SystemGuid.Keyboard) and the mouse (SystemGuid.Mouse), which will define the device type we'll be gathering data from. For the joystick, we'll have code that is a little more complex, and it will be shown in the next section. The next method, SetDataFormat, simply informs the newly created Input-Device object what the expected data format to be read from the input device is, according to the DeviceDataFormat enumeration. The possible values are Joystick,Keyboard, and Mouse. The joystick and mouse have alternative structures with extra attributes, used if our input device has features in addition to those supported by the basic structures. For example, there are three more members with regard to the joystick data formats: Joystick2, frameJoystick, and frameJoystick2; refer to the SDK documentation to see what the provided data structure is for each member of the enumeration. The last DirectInput function seen in the New method is the SetCooperativeLevel, which determines how the instance of the device will interact with other instances created by our application and by other applications. This method receives as parameters the window handle to which the device is attached and a combination of CooperativeLevelFlags enumeration members, which can be any of the following:
.NET Programming with DirectX 9.0input device at any time, even if the application Background: OurGame application can gather data from the Santos Ellenwindow). ISBN:1590590511 window is in by theAlexandre background (it's Lobão not theand active Hatton Apress © 2003 (696 pages)
Foreground: Our application will only gather data from the input device when it's in the foreground (when The authors of this text show how easy it can be to produce it's the system active window). interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Exclusive: The application requires exclusive access to the input device; that means other applications can't require this type of access (they receive an error if they try to), but other applications can require Table of Contents use. If our application uses the exclusive mode, the menus and window buttons won't work. nonexclusive .NET Game Programming with DirectX 9.0 Foreword
NonExclusive: The application requires nonexclusive access to the input device.
Preface
Introduction
NoWinKey: ThisGDI+ disables the use of the Microsoft Windows logo key. When in exclusive mode, this key is Chapter 1 - .Nettrix: and Collision Detection disabled by default. Artificial Intelligence and Sprites Chapter 2 - .Netterpillars: Chapter 3 a- combination Managed DirectX First Steps: Direct3D and DirectX enumeration vs. GDI+ We'll use of the Foreground plusBasics the Exclusive members for all devices. This Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio works pretty well for full-screen applications, and the mouse cursor isn't shown, so we can draw our own mouse Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen pointers. Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow The last lines of the New procedure deal with the creation of the new thread (associating it with the Chapter 7 three - Magic KindergarteN. II: Animation Techniques and Speech API
DInputThread function), a name to this thread (only meaningful for debugging), and starting the new Chapter 8 - .Netterpillars II:giving Multiplayer Games and Directplay thread.
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
When we call the Start method, the function specified in the Thread constructor is called once. If we need a one-time action, like playing a sound, this is okay. But to implement polling, we'll code this function with a loop Appendix A - The State of PC Gaming that will keep the thread running until the game is over. Since our class is derived from the GameEngine class, Appendix B - Motivations in Games we can control such a loop with the shared property GameOver. The thread function is discussed in the section Appendix C - How Do I Make Games? "Polling the Devices." Bonus Chapter Porting .Nettrix to Pocket PC
Appendix D - Guidelines for Developing Successful Games Index
Creating the Joystick Initialization Code
List of Figures List of Tables
Coding for joystick devices is far more complex than for keyboards and mice, since we'll have a large variety of devices that will be handled as joysticks. A drawback to this flexibility is more complex initialization and dataprocessing routines. To initialize the joystick, we'll need to discover the specific GUID to be passed to the Device function, which will vary depending on the devices attached to the computer. To recover this GUID, we'll need to call the GetDevices method on a for-each loop, which will run once for each attached joystick device, and then get the specific GUID for the current joystick. The following code shows the New method for the Joystick class, which is analogous to the ones used for the mouse and keyboard, except for calling GetDevices and setting specific joystick properties, as discussed later. Public Sub New(ByVal Parent As Window.Control.Forms) Try 'Ignore errors for now For Each DevInstance In Manager.GetDevices(DeviceType.Joystick, _ EnumDevicesFlags.ForceFeeback Or EnumDevicesFlags.AttachedOnly) ' Simply pick the first joystick available InputDeviceInstance = DevInstance Next InputDevice = New Device(InputDeviceInstance.InstanceGuid) InputDevice.SetDataFormat(DeviceDataFormat.Joystick)
' Set the cooperative level for the device. .NET Game Programming with DirectX 9.0 InputDevice.SetCooperativeLevel(Parent,_ ISBN:1590590511 by CooperativeLevelFlags.Exclusive Alexandre Santos Lobão and Ellen Or _ Hatton CooperativeLevelFlags.Foreground) Apress © 2003 (696 pages) ' ----- Set the joystick properties of this text how easy it can be to produce ' Set The theauthors DeadZone forshow each axis interesting multimedia games using Managed DirectX 9.0 and InputDevice.Properties.SetDeadZone(ParameterHow.ByOffset, _ programming with Visual Basic .NET on Everett, the latest JoystickOffset.X, 1000) version of Microsoft's Visual Studio. InputDevice.Properties.SetDeadZone(ParameterHow.ByOffset, _ JoystickOffset.Y, 1000) Table of Contents ' Set the Joystick range .NET Game Programming with DeviceObjectInstance DirectX 9.0 Dim Axis As Foreword For Each Axis In InputDevice.Objects Preface If (Axis.ObjectId And CInt(DeviceObjectTypeFlags.Axis)) <> 0 Then Introduction ' Set the range for the axis. InputDevice.Properties.SetRange(ParameterHow.ById, _ Chapter 1 - .Nettrix: GDI+ and Collision Detection Axis.ObjectId, New InputRange(0, +10000)) Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites End DirectX If Chapter 3 - Managed First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4 -Next River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio ChapterCatch 5 - River Pla.Net II: DirectInput and Writing Text to Screen End Try Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
' Create the thread that the app will use - .Netterpillars II: Multiplayer Games and Directplay ' to get state information from the device. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterInputThread 9 = New Thread(AddressOf Me.DInputThread) Nonmanaged Code ' Name it something so we can see in the output Bonus Chapter Porting .Nettrix to Pocket PC ' window when it has exited. Appendix A - The State of PC Gaming InputThread.Name = "DInputThread" Appendix B - Motivations in Games InputThread.Start() Appendix C - How Do I Make Games? End Sub Chapter 8
Appendix D - Guidelines for Developing Successful Games Index
In the previous code listing, we are using the Properties object of the input device to set specific properties List of Figures associated List of Tables to joysticks. This object can be used to cover a wide range of properties and have many specific methods, each one corresponding to a specific joystick characteristic or property. In our sample code, we are setting two properties: one defining the range to be used by the joystick, and one defining the so-called dead zone. By setting the joystick range from 0 to 10,000, we are saying that the centered joystick will have the values (0,0) for the (x,y) coordinate pair, and when the joy-stick is totally pulled to one direction, this direction will have the value 10,000. The dead zone setting informs DirectInput about the responsiveness we want for our joystick. Setting the dead zone for 1000 in each axis, as we did in our sample, will result in our game only being informed of a joystick movement if it's 1/10 or greater than the total distance from the center to the movement limit. If we didn't set a dead zone, our game may become unplayable, since the slightest movement of the joystick would be significant in the game. In the next section we see how to code the thread function, which will be used for polling the devices.
Polling the Devices As we saw earlier in the section "Defining the Input Classes," the initialization code for each device must start a new thread, which will be responsible for gathering data from the device in a continuous loop. On the polling loop, shown later in this section, we'll go through the following steps: 1. 2.
1. Poll the device to check if we have access to it (using the Poll method of the InputDevice object). .NET Game Programming with DirectX 9.0
ISBN:1590590511 2. If we don'tby have Alexandre access,Santos try to acquire Lobão and it (using Ellen the Acquire method of the InputDevice object).
Hatton
3. If we can'tApress acquire © 2003 the device, (696 pages) we simply don't try to gather any data. This isn't necessarily an error: Since we specified we need Foreground access, if our window the active one, we won't be able to The authors of this text show how easy it can be toisn't produce interesting acquire the device. multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest versionthe of Microsoft's Studio. 4. If we do acquire device, getVisual data from the device using the Current<device>State set of methods of the InputDevice object (GetCurrentKeyboardState,CurrentMouseState, and CurrentJoyState), which returns as a parameter the data in the format specified by the Table of Contents SetDataFormat function, used in the New method. .NET Game Programming with DirectX 9.0
Foreword 5. Call the specific method for each device that will generate the events (as stated in the class diagram, Preface GetKeyboardState, GetMouseState, and GetJoystickState). Introduction
The data forGDI+ each and device type will be defined as follows: Chapter 1 formats - .Nettrix: Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites Public KeyboardState Chapter 3 Shared - ManagedKeyboardState DirectX First Steps:As Direct3D Basics and DirectX vs. GDI+
Public MouseState AsFields, MOUSESTATE Chapter 4 Shared - River Pla.Net: Tiled Game Scrolling, and DirectAudio Public JoystickState Chapter 5 Shared - River Pla.Net II: DirectInput As and JOYSTATE Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
We'll see some of the attributes of these structures in the functions that process the input device data to - .Netterpillars II: Multiplayer Games and Directplay generate the class events.
Chapter 8
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code The remainder of the code, shown here, is just thread synchronization and error trapping, to make the method Bonus Chapter Porting .Nettrix to Pocket PC shows the polling thread for the keyboard: less error prone. The following code listing Chapter 9
-
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Public Sub DInputThread()
Appendix C -CanReadDevice How Do I Make Games? Dim As Boolean = False Appendix D - Guidelines for Developing Successful Games Index ' Make sure there is a valid device. List of Figures If (Not InputDevice Is Nothing) Then List of TablesWhile (Not GameOver)
Try ' check if we can get the device state. InputDevice.Poll() Catch ex As InputException ' Check to see if either the app needs to acquire the device, or ' if the app lost the input device to another process. If TypeOf ex Is NotAcquiredException Or _ TypeOf ex Is InputLostException Then Try ' Acquire the device. InputDevice.Acquire() CanReadDevice = True Catch ex2 As InputException If TypeOf ex Is OtherApplicationHasPriorityException Then Throw New Exception("Unknown error occcurred. " & _ "This app won't be able to process device info.") End If ' Failed to aquire the device. This can happen when ' the app doesn't have focus. CanReadDevice = False End Try End If
End Try .NET Game Programming with DirectX If (CanReadDevice = True) Then9.0 by Alexandre Santos Lobão and Ellen ' Lock the class so it can't ISBN:1590590511 overwrite Hatton ' the input device State structure during a race condition. Apress © 2003 (696 pages) SyncLock (Me) The authors'ofGet this text how of easythe it candevice be to produce theshow state interesting multimedia games using Managed DirectX 9.0 and Try programming with Visual Basic .NET on Everett, the latest InputDevice.GetCurrentKeyboardState version of Microsoft's Visual Studio. ' Call the function in the other thread ' that generates keyboard events. Table of Contents Me.GetKeyboardState() .NET Game Programming with DirectX ' 9.0 Catch any exceptions. None will be handled here, Foreword ' any device re-aquisition will be handled above. Preface Catch ex As InputException Introduction End Try Endand SyncLock Chapter 1 - .Nettrix: GDI+ Collision Detection End If Artificial Intelligence and Sprites Chapter 2 - .Netterpillars: While Chapter 3 -End Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ ChapterEnd 4 -If River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio End Sub Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API The methods that will process the data acquired with Current<device>State are unique, because they will - .Netterpillars II: Multiplayer Games and Directplay be totally related to the data structures read; we'll see every method in detail in the coming sections.
Chapter 8 Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Nonmanaged The last common methodCode for our input device classes is Dispose, shown here, which will release the Bonus Chapter Porting .Nettrix Pocketcreated PC resources used and free the to objects in the class: Appendix A - The State of PC Gaming Appendix - Motivations in Games PublicB Sub Dispose() Implements System.IDisposable.Dispose Appendix C How Do I Make ' Unacquire and Games? destroy all Dinput objects. Appendix D - Guidelines for Developing Successful Games InputDevice.Unacquire() Index InputDevice.Dispose() List of Figures End Sub List of Tables
We'll see now the specific details about processing the data gathered from each input device, starting with the keyboard, in the next section.
Processing the Keyboard Input In the GetKeyBoardState method, we'll have to translate the KeyboardState byte array into keycodes from the Keys enumeration. When a key is pressed, its corresponding array element returns with the seventh bit (128, or 80 in hexadecimal notation) set; so all we have to do is to loop through all elements in the array and check the bits of each element. Since the array position has no relation at all with the ASCII values or any other character table (they just start with 1 for the Esc key, and go on sequentially left to right and then up to down), we'll have to create a Select Case command to translate it into keycodes, as shown in the subsequent code: Public Sub GetKeyboardState() Dim i As Integer = 0 Dim keyCode As System.Windows.Forms.Keys SyncLock (Me) ' Get the keys pressed from the keyboard For i = 0 To keyboardState.Length - 1 If (keyboardState(i) And &H80) <> 0 Then Select Case i
Case 208 .NET Game Programming DirectX 9.0 keyCode with = Keys.Down ISBN:1590590511 by Alexandre Santos Lobão and Ellen Case 203 Hatton keyCode = Keys.Left Apress © 2003 (696 pages)
Case 205
The authors of this text show=how easy it can be to produce keyCode Keys.Right interesting multimedia games using Managed DirectX 9.0 and Case programming with 200 Visual Basic .NET on Everett, the latest keyCode = Keys.Up version of Microsoft's Visual Studio.
Case 57 keyCode = Keys.Space Table of Contents Case 128 .NET Game Programming with DirectX 9.0 keyCode = Keys.Escape Foreword End Select Preface RaiseEvent Keypress(keyCode) Introduction End If Chapter 1 -Next .Nettrix: GDI+ and Collision Detection ChapterEnd 2 -SyncLock .Netterpillars: Artificial Intelligence and Sprites End Sub Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
To know the exact code for each key, we'll have to do some tests. For example, we can include an else clause Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow in the select case statement shown previously and include a message box that displays the value of i. Chapter 8 Of - .Netterpillars II: Multiplayer Games and Directplay Note course, we don't have to loop through the entire array if all we want to check is six keys, as shown in D-iNfEcT: the previous Multithreading, listing; we can Nonrectangular test only the Windows, elementsand we Access need, ignoring to any other keys. Chapter 9 Nonmanaged Code
Note Chapter that if wePorting are capturing thePocket keyboard, Bonus .Nettrix to PC our window won't respond to any commands, including Alt-F4 to close, soA we'd an escape sequence for users to cancel the game if they want to. Let's use the Appendix - Thebetter State include of PC Gaming letter "Q"B and inform theinuser of this exit key on the opening screen, as shown in the next code snippet and in Appendix - Motivations Games Figure 5-3. Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 5-3: The game intro screen must notify the user of the keys used in the game.
Public Sub GetKeyboardState() Dim i As Integer = 0 Dim keyCode As System.Windows.Forms.Keys SyncLock (Me) ' Get the keys pressed from the keyboard
If (KeyboardState(208) And &H80) <> 0 Then .NET keyCode Game Programming with DirectX 9.0 = Keys.Down ISBN:1590590511 by Alexandre Santos Lobão and Ellen And &H80) ElseIf (KeyboardState(203) <> 0 Then Hatton keyCode = Keys.Left Apress © 2003 (696 pages) ElseIf (KeyboardState(205) And &H80) <> 0 Then The authors of this show how easy it can be to produce keyCode = text Keys.Right interesting multimedia games using Managed DirectX 9.0 and ElseIf (KeyboardState(200) &H80) <> 0 Then programming with Visual Basic .NET onAnd Everett, the latest keyCode = Keys.Up version of Microsoft's Visual Studio. ElseIf (KeyboardState(57) And &H80) <> 0 Then keyCode = Keys.Space Table of Contents ElseIf (KeyboardState(1) And &H80) <> 0 Then .NET Game ProgrammingkeyCode with DirectX = 9.0 Keys.Escape Foreword ElseIf (KeyboardState(16) And &H80) <> 0 Then Preface keyCode = Keys.Q Introduction End If RaiseEvent Keypress(keyCode) Chapter 1 - .Nettrix: GDI+ and Collision Detection SyncLock Artificial Intelligence and Sprites Chapter 2 End - .Netterpillars: End Sub Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Next, we'll see the mouse handling routine.
Processing the Mouse input D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
TheGetMouseState method will read the MouseState structure and convert its information into workable events. This structure is very simple, with an array that returns the state of three mouse buttons, and three Appendix A - The State of PC Gaming attributes returning the coordinates of the mouse on each of the 3-D axes. Bonus Chapter Porting .Nettrix to Pocket PC Appendix B - Motivations in Games
Appendix C structure - How Do returned I Make Games? Since the just has the current information, we'll have to store the last state of each button so Appendix D - Guidelines for Developing we can instigate the MouseDown andSuccessful MouseUpGames events only once, when the button state changes. Index
As of forFigures the MouseMove event, it must be generated by every mouse movement. We need to be careful to check List if the axis attributes have real values (sometimes they can be zeroed). Since the mouse coordinates will be List of Tables
closely related to the screen resolution, we must check the GameEngine class for the screen resolution, and only generate a mouse movement event within the current resolution. We'll have to calculate the mouse position on screen based on the mouse data read from the device, as shown in the next code listing, because the device only returns the variation in each axis from the previous position, and not an absolute position. Here is the final code for this method: Public Sub GetMouseState() Dim buttons() As Byte = MouseState.GetMouseButtons() Static LastButtonState(3) As Integer ' Lock the UI class so it can't overwrite ' the MouseState structure during a race condition. SyncLock (Me) ' Update the mouse position if the mouse moved If (0 <> (MouseState.X Or MouseState.Y)) Then X += MouseState.X : Y += MouseState.Y If X < 0 Then X = 0 If Y < 0 Then Y = 0 If X > clsGameEngine.Width Then X = clsGameEngine.Width If Y > clsGameEngine.Height Then Y = clsGameEngine.Height RaiseEvent MouseMove(X, Y) End If
' Generates the events according to the button pressed Game Programming with DirectX 9.0 ' Button 0 = .NET Right button ISBN:1590590511 by Alexandre Lobão and Ellen If (Buttons(0)Santos <> LastButtonState(0)) Then Hatton If Buttons(0) <> 0 Then Apress © 2003 (696 pages) RaiseEvent MouseDown(X, Y, enButton.Right) The authors of this text show how easy it can be to produce Else interesting multimedia games using Managed DirectX 9.0 and RaiseEvent MouseUp(X, Y,Everett, enButton.Right) programming with Visual Basic .NET on the latest End Ifof Microsoft's Visual Studio. version LastButtonState(0) = Buttons(0) End If Table of Contents ' Button 1 = Left button .NET Game Programming with DirectX If (Buttons(1) <> 9.0 LastButtonState(1)) Then Foreword If Buttons(1) <> 0 Then Preface RaiseEvent MouseDown(X, Y, enButton.Left) Introduction Else RaiseEvent MouseUp(X, Y, enButton.Left) Chapter 1 - .Nettrix: GDI+ and Collision Detection End If Artificial Intelligence and Sprites Chapter 2 - .Netterpillars: LastButtonState(1) = Buttons(1) Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4 -End RiverIf Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Button middle or Chapter 5 -'River Pla.Net3II:=DirectInput and function Writing Text button to Screen If (Buttons(2) <> LastButtonState(2)) Then Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow If Buttons(2) <> 0 Then Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API RaiseEvent MouseDown(X, Y, enButton.Other) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Else D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 RaiseEvent MouseUp(X, Y, enButton.Other) Nonmanaged Code End If Bonus Chapter Porting .Nettrix to Pocket PC LastButtonState(2) = Buttons(2) Appendix A - The State of PC Gaming End If Appendix B - Motivations in Games End SyncLock Appendix C - How Do I Make Games? End Sub Appendix D - Guidelines for Developing Successful Games Index List Now of we'll Figures see details about processing the input data gathered from joystick devices. List of Tables
Processing the Joystick Input The last input device method, GetJoystickState, will deal with the JoyState structure. As mentioned before, this structure has many attributes that will be filled according to the joystick type. In order to guarantee that our class will work even with the simplest joysticktype peripheral, we'll keep it as simple as possible; but some processing will still be needed. We'll generate the JoystickPressed event according to the Buttons array, simply by passing the button index to the application; and, for the JoystickMove event, we'll pass the (x,y) coordinates and, to help the applications to create simpler code, the joystick direction, according to the enDirection enumeration defined in the GameEngine class. To calculate this direction, we have to check the X and Y joystick data members; each of these will range from 0 to 10,000, according to the values depicted in Figure 5-4.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction
Figure 5-4: The values for the X and Y joystick members for each joystick position
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites If the application requires greater precision, it canBasics use the joystick Chapter 3 - Managed DirectX First Steps: Direct3D and DirectXcoordinates vs. GDI+ directly passed as a parameter to
this event. following the full code the GetJoystickState method: Chapter 4 -The River Pla.Net: code Tiled listing Game shows Fields, Scrolling, and for DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Public GetJoystickState() Chapter 6 Sub - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Dim direction As enDirection = clsGameEngine.enDirection.None Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
' Lock the UI class so Nonrectangular it can't overwrite D-iNfEcT: Multithreading, Windows, and Access to Chapter'9 the - JoystickState structure during a race condition. Nonmanaged Code SyncLock (Me) Bonus Chapter Porting .Nettrix to Pocket PC Dim B Asof Byte, buttonNumber As Integer Appendix A - The State PC Gaming ' There's a lot Appendix B - Motivations in Games of extra information coming from the joystick devices, ' but we'll deal here only with buttons and simple 2-D movement Appendix C - How Do I Make Games? buttonNumber = 0 Appendix D - Guidelines for Developing Successful Games For Each B In JoystickState.GetButtons Index buttonNumber += 1 List of Figures If (B <> 0) Then List of Tables RaiseEvent JoystickButtonPressed(buttonNumber) End If Next ' Calculates the direction of the movement ' Center position is 5000, 5000 ' X goes from 0 to 10000, left to right ' Y goes from 0 to 10000, top to down ' We'll ignore movements < 1000 from the center Select Case JoystickState.X Case Is < 4000 ' X is to the west (left) Select Case JoystickState.Y Case Is < 4000 ' Y is to the North (top) direction = clsGameEngine.enDirection.NorthWest Case Is > 6000 ' Y is to the south (down) direction = clsGameEngine.enDirection.SouthWest Case Else ' Y is centered direction = clsGameEngine.enDirection.West End Select Case Is > 6000 ' X is to the east (right) Select Case JoystickState.Y Case Is < 4000 ' Y is to the North (top) direction = clsGameEngine.enDirection.NorthEast Case Is > 6000 ' Y is to the south (down)
direction = clsGameEngine.enDirection.SouthEast .NET GameCase Programming with 9.0 Else ' Y isDirectX centered ISBN:1590590511 by Alexandre Santos Lobão and =Ellen direction clsGameEngine.enDirection.East Hatton End Select Apress © 2003 (696 pages)
Case Else ' X is centered The authors of this textJoystickState.Y show how easy it can be to produce Select Case interesting multimedia games using Managed DirectX 9.0 and Case < Basic 4000.NET ' on Y Everett, is to the thelatest North (top) programming with Is Visual direction = clsGameEngine.enDirection.North version of Microsoft's Visual Studio. Case Is > 6000 ' Y is to the south (down) direction = clsGameEngine.enDirection.South Table of Contents Case Else ' Y is centered .NET Game Programming with DirectX 9.0 direction = clsGameEngine.enDirection.None Foreword End Select Preface End Select Introduction Chapter 1
direction clsGameEngine.enDirection.None Then -If .Nettrix: GDI+ and<> Collision Detection
Chapter 2
RaiseEvent JoystickMove(JoystickState.X, JoystickState.Y, direction) - .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
If DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ -End Managed
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
ChapterEnd 5 -SyncLock River Pla.Net II: DirectInput and Writing Text to Screen
End Sub - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 6 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 we - .Netterpillars II: Multiplayer Gameswe and Directplay Now that have all of our classes in code, can begin the new version of the River Pla.Net game, starting D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to with the9 game proposal. Chapter Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Game Proposal by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton game is to improve the sample from the previous chapter, River Pla.Net, to Our goal in this chapter's Apress © 2003such (696 pages) include some extra features, as force-feedback joystick control. The authors of this text show how easy it can be to produce
The following areinteresting the features we'll add: multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
The plane will version be controlled of Microsoft's by theVisual joystick. Studio. The ships and planes will move in order to make the game tougher and increase the need for a highTable of Contents quality game input device. .NET Game Programming with DirectX 9.0
The player's plane will shoot when the user presses the fire button of the joystick. There'll be a Foreword maximum of 16 bullets on screen, and the bullets can destroy planes, ships, and bridges. Preface Introduction
We want to give users a visual feedback about how well they are doing; so we'll include a status line
Chapter 1 the - .Nettrix: GDI+ and Collision with total points achieved (they Detection earn points for flying and destroying enemies), the amount of fuel Chapter 2 .Netterpillars: Artificial Intelligence and have Sprites in the fuel tank, and the number of lives they left. Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ As4an -extra can create newScrolling, obstaclesand in the river: steel arrows that will throw the player's Chapter Riverfeature, Pla.Net:we Tiled Game Fields, DirectAudio
plane the side theII: arrow is pointing WhenText the to plane hits such an arrow, the joystick must give Chapter 5 -toRiver Pla.Net DirectInput andto. Writing Screen force to the user, in order to provide clue thatand theDirectShow plane is being moved against his or her Chapter 6 feedback - Magic KindergarteN.: Adventure Games, a ADO.NET, will. Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
.Netterpillars II: Multiplayer Games and Directplay In the next-section we'll examine in more detail these new features before entering the code phase.
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Game Project by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Although our project goal in this chapter is simply to improve a previously created game, we can't neglect Apress © 2003 (696 pages) to create the game project. However, it'll be a little simpler. We'll basically add some properties and methods to the classes created in the last chapter, withitonly new classes: the GameFont class and The authors of this text show how easy can two be to produce interesting multimedia using Managed DirectX 9.0 and theGameInput class, described in the games previous sections. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Studio. Let's see what additional features our Visual classes must implement in order to reach each of the goals defined
in the game proposal. Table of Contents
Controlling the Plane with the Joystick
.NET Game Programming with DirectX 9.0 Foreword
TheRiverEngine class must create a Joystick object and change the control from the Keypress event of the GameWindow form to the JoystickMove event generated by this class. Since some Introduction functions will remain on the keyboard, such as the pause feature and the exit feature, we'll have to create Chapter 1 - .Nettrix: GDI+ and Collision Detection aKeyboard class as well, and include its event handler. Preface
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Including Moving Ships and Scrolling, Planesand DirectAudio - River Pla.Net: Tiled Game Fields,
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
We have already seen how to move objects independently in the last chapter: The plane moves according Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow to the arrow keys, and the game field scrolls. All we have to do is to extend this concept, moving the Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API planes and ships down (scrolling with the game field) and left to right. Reflecting on this point, it should be Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay noted that we can't move the plane and ship tiles, or we'll create holes in our game field; so we must find a D-iNfEcT: Multithreading, Windows, andofAccess different For example, weNonrectangular can create a second array active to objects that holds only the active Chapter 9 approach. Nonmanaged Code objects, and another one that holds the game field. We'll have two layers of objects, so we'll need an Bonus Chapter Porting .Nettrix to Pocket PC additional method (let's call it MoveActiveObjects) that must be called after the Scroll and Draw Appendix A - The State of PC Gaming methods so the active objects may appear over the game field. Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
Making Our Plane Shoot
Appendix D - Guidelines for Developing Successful Games Index
Following the ideas expressed previously, we'll create an extra array (with 16 elements) to hold the bullets,
List Figures andofan extra method, MoveBullets, to move the bullets. Of course, even though the TestCollision List of Tables method may continue with the same interface, the code will have to be deeply modified to consider the
collision of the plane and the bullets with the moving objects.
Adding a Status Line We can create a simple function, DrawStatus, that will present on screen the Gas and Lives properties, and a newly created Points property that may be incremented in the Scroll and the TestCollision methods from GameEngine.
Adding Support for Force-Feedback Joysticks As presented in the section "the Game Proposal," support for force-feedback joysticks in our game will be treated as an extra feature, so we'll implement it in "Adding the Final Touches" at the end of this chapter.
Defining the Class Diagram Our final class diagram will include the classes defined in the previous chapter and the methods and properties suggested previously, as shown in Figure 5-5.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index
Figure 5-5: The complete class diagram for River Pla.Net II
List of Figures List of Tables
Game Programming with DirectX 9.0 The Coding.NET Phase by Alexandre Santos Lobão and Ellen
ISBN:1590590511
As in the previousHatton chapter, let's define the steps we'll take in completing the final version: (696 pages) 1. First draft:Apress Include© 2003 DirectInput joystick and keyboard support.
The authors of this text show how easy it can be to produce interesting multimedia using Managed DirectX 9.0 and 2. Second draft: Implement movinggames enemies. programming with Visual Basic .NET on Everett, the latest ofthe Microsoft's Studio. 3. Third draft:version Include shootingVisual feature.
4. Final version: Draw the game status on screen.
Table of Contents
.NET Game Programming with DirectX 9.0
First Draft: Including DirectInput for the Joystick and Keyboard
Foreword Preface
IncludingDirectInput to add support for joysticks and keyboards is very simple: We just need to define the objects we have previously created, and code the events for them.
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter When declaring 2 - .Netterpillars: the objects Artificial private Intelligence to the RiverEngine and Sprites class, we mustn't forget to use the WithEvents Chapter keyword 3 to- allow Managed our DirectX objectsFirst to work Steps: withDirect3D events. Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
ChapterPrivate 5 - RiverShared Pla.Net II:WithEvents DirectInput and Writing Text Screen Joystick Asto ClsJoystick ChapterPrivate 6 - MagicShared KindergarteN.: AdventureKeyboard Games, ADO.NET, and DirectShow WithEvents As ClsKeyboard Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
In the initialize procedure, we'll create these objects,Windows, passing the reference as a parameter as follows: D-iNfEcT: Multithreading, Nonrectangular and window Access to
Chapter 9
-
Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC devices ' Initializes the input Appendix A Joystick - The State of = PC New Gaming ClsJoystick(Owner)
ClsKeyboard(Owner) Appendix B Keyboard - Motivations=inNew Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
And then we'll code the events. The Keypress event will be almost an exact copy of the code that was previously used in the Keypress event of the GameWindowform, including just one extra line for the Q key to List of Figures quit the game. Index
List of Tables
Private Shared Sub KeyPress(KeyCode As Keys) Handles Keyboard.Keypress Select Case KeyCode Case Keys.Right Player.SpeedX = gameSpeed Paused = False Case Keys.Left Player.SpeedX = -gameSpeed Paused = False Case Keys.Up Player.SpeedY = gameSpeed Paused = False Case Keys.Down Player.SpeedY = -gameSpeed Paused = False Case Keys.Escape 'GameOver = True Paused = Not Paused Case Keys.Q GameOver = True End Select End Sub
.NET DirectX 9.0 moving the plane in JoystickMove, and firing in As for the joystick, we'llGame have Programming to add code forwith two new events: JoystickButtonPressed by Alexandre .Santos First we'll Lobão code andonly Ellenthe former ISBN:1590590511 event; we'll include the code in the latter event Hatton when we code the shooting feature. Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce Private Shared Sub JoystickMove(x As Integer, y As Integer, _ interesting multimedia games using Managed DirectX 9.0 and As on enDirection) Handles Joystick.JoystickMove programming with direction Visual Basic .NET Everett, the latest Selectversion Caseofdirection Microsoft's Visual Studio. Case clsGameEngine.enDirection.West Player.SpeedX = gameSpeed Table of Contents Paused = False .NET Game Programming with DirectX 9.0 Case clsGameEngine.enDirection.East Foreword Player.SpeedX = -gameSpeed Preface Paused = False Introduction Case clsGameEngine.enDirection.North Chapter 1 - .Nettrix: GDI+ Player.SpeedY and Collision Detection = gameSpeed Paused = False Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Case DirectX clsGameEngine.enDirection.South Chapter 3 - Managed First Steps: Direct3D Basics and DirectX vs. GDI+ Player.SpeedY = -gameSpeed Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Paused = Falseand Writing Text to Screen Chapter 5 - River Pla.Net II: DirectInput Case clsGameEngine.enDirection.NorthWest Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Player.SpeedX = gameSpeed Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Player.SpeedY = gameSpeed Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Paused = False D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -Case clsGameEngine.enDirection.NorthEast Nonmanaged Code Player.SpeedX = -gameSpeed Bonus Chapter Porting .Nettrix to Pocket PC Player.SpeedY = gameSpeed Appendix A - The State of PC Gaming Paused = False Appendix B - Motivations in Games Case clsGameEngine.enDirection.SouthWest Appendix C - How Do I Make Games? Player.SpeedX = gameSpeed Appendix D - Guidelines for Developing Successful Games Player.SpeedY = -gameSpeed Index Paused = False List of Figures Case clsGameEngine.enDirection.SouthEast List of Tables Player.SpeedX = -gameSpeed Player.SpeedY = -gameSpeed Paused = False End Select End Sub
As we saw in the last chapter, once we have created basic classes to handle DirectX complexity, it becomes very easy for any program to use these classes. And as we create more games, we can improve our base classes to gain more control or more performance, using any new tricks we learn. Running our program now, we'll see that even with the keyboard our control over the plane is better, and we can also use any joystick device we choose to control it.
Second Draft: Implementing Moving Enemies As we said in the game project, we'll "promote" our enemies from tiles to active objects.
Loading the Active Objects After creating an array to hold these objects (identical to the tiles array), we'll need to change the LoadGameMap and LoadLine procedures to load both the Tiles array and the ActiveObjects array, as shown in the next piece of code:
Private tiles.NET As Game ClsTile(,) Programming with DirectX 9.0 Private ActiveObjects As ClsTile(,) by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Function LoadGameMap(ByVal strGameMapFileName As String) As Boolean The authors of this text show how easy it can be to produce . . . interesting multimedia games using Managed DirectX 9.0 and ReDim tiles(Width, programming with GameMapSize) Visual Basic .NET on Everett, the latest version of Microsoft's VisualGameMapSize) Studio. ReDim ActiveObjects(Width, . . . ' Load all the game map lines from the GameMap Table of Contents ' into the Tiles array and the ActiveObjects Array .NET Game Programming with DirectX 9.0 For i = 0 To GameMapSize - 1 Foreword If Not LoadLine(GameMap(i)) Then Preface LoadGameMap = False Introduction Exit Function Chapter 1 -End .Nettrix: If GDI+ and Collision Detection ChapterNext 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter . . .3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio End Function Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Function LoadLine(ByVal strLine Games, As String) Chapter 6 - Magic KindergarteN.: Adventure ADO.NET,As andBoolean DirectShow Dim x As Integer Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API AsGames String ChapterDim 8 -strSpriteFileName .Netterpillars II: Multiplayer and Directplay Dim Type As ClsTile.enType D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Static LineNumber Nonmanaged Code As Integer = 0 Bonus Chapter Porting .Nettrix to Pocket PC
LoadLine = True Appendix A - The State of PC Gaming For = 0 To in Width Appendix B -xMotivations Games- 1 strLine.Chars(x) Appendix C -Select How Do I Case Make Games? Case "1" strSpriteFileName = "borderN" Type = ClsTile.enType.Land Figures Case "2" Tables strSpriteFileName = "borderNE1" Type = ClsTile.enType.Land . (all other tiles…) Case "." ' Green background ' Do nothing strSpriteFileName = "" Type = ClsTile.enType.Background Case "_" strSpriteFileName = "water" Type = ClsTile.enType.Water Case Else ' Should never happen strSpriteFileName = "InvalidTile" Type = ClsTile.enType.Land End Select Try Select Case Type Case ClsTile.enType.Background tiles(x, LineNumber) = Nothing ActiveObjects(x, LineNumber) = Nothing Case ClsTile.enType.Water To ClsTile.enType.Land tiles(x, LineNumber) = New ClsTile(strSpriteFileName & _ ".bmp", New POINT(x, LineNumber), Type)
Appendix D - Guidelines for Developing Successful Games Index List of List of
. .
ActiveObjects(x, LineNumber) = Nothing .NET Case Game Else Programming with DirectX must 9.0 'Active objects be created over water ISBN:1590590511 by Alexandre Santos Lobão and Ellen tiles(x, LineNumber) = New ClsTile("water.bmp", _ Hatton New POINT(x, LineNumber), ClsTile.enType.Water) Apress © 2003 (696 pages)
ActiveObjects(x, LineNumber) = New ClsTile(strSpriteFileName_
The authors of this text how easy it can be to produce & show ".bmp", Color.FromARGB(255, 255, 0, 255), _ interesting multimedia games using Managed DirectX 9.0 and NewBasic POINT(x, LineNumber), programming with Visual .NET on Everett, the latest Type) ActiveObjects(x, version of Microsoft's Visual Studio. LineNumber).SpeedX = gameSpeed
End Select Catch e As Exception Table of Contents LoadLine = False .NET Game Programming with DirectX 9.0 MessageBox.Show("Unpredicted Error when loading game sprites: " & _ Foreword e.Message, "River Pla.Net", MessageBoxButtons.OK, _ Preface MessageBoxIcon.Stop) Introduction Exit Function TryGDI+ and Collision Detection Chapter 1 -End .Nettrix: ChapterNext 2 - .Netterpillars: Artificial Intelligence and Sprites the First line number counter Chapter'3 Increments - Managed DirectX Steps: Direct3D Basics and DirectX vs. GDI+ += 1Tiled Game Fields, Scrolling, and DirectAudio ChapterLineNumber 4 - River Pla.Net: End Function Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API The code just shown is exactly the same as that seen in the last chapter, with the single difference that here we
Chapter 8 an - .Netterpillars II: the Multiplayer Games Directplay included extra check on object type, at and the end of the Select Case statement: If the current tile isn't D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to background, Chapter 9 - land, or water (or, in other words, if it's a ship, a bridge, a gas barrel, or a plane), then we'll create Nonmanaged Code
a water tile in the Tiles array (active objects must always be created over water, to simplify our code) and add
Bonus Porting .Nettrix to Pocket PC a newChapter object to the ActiveObjects array. In all other cases, the ActiveObjects array will be filled with Appendix A The State of PC Gaming nulls. Appendix B - Motivations in Games
Tip This approach will Games? simplify our treatment of collisions, too. If the player collides with an active object, we Appendix C - How Do I Make can simply destroy the objectSuccessful in the array, so it won't be drawn anymore. In the previous chapter, we Appendix D - Guidelines for Developing Games needed to destroy the object and create a new water tile in the position previously occupied by the object. List of Figures Index
List of Tables
Moving the Planes and Ships on Screen If we now run our code, we'll see everything looking just like the version in the last chapter, but without the enemies, bridges, and gas barrels. Only the tiles are being drawn. We'll have to code a new method, MoveActiveObjects, that will move and draw the elements from the ActiveObjects array. This method will present no new concepts, but it will stretch your knowledge of transformation matrices. Let's look at it step by step, so that we can get the most out of the concepts being used. A quick way to start is to copy the code from the Scroll and Draw methods and adapt it to draw our active objects, scrolling with the same speed as the tiles but not yet moving. Since the scrolling has already been applied to the Transform.World matrix, we can use this by simply calling the MoveActiveObjects before theScroll and Draw procedures: Public Sub MoveActiveObjects() Dim x As Integer, y As Integer Dim LineCount As Integer = 0 ' Draw the game field y = CurrentLineNumber - 1 If y < 0 Then y = GameMapSize ' We will move the objects a line below the current line number and a line
' above the last line on screen (CurrentLineNumber + Height) Game Programming with Do While .NET LineCount < Height + 2 DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen For x = 0 To Width - 1 Hatton If Not (ActiveObjects(x, y) Is Nothing) Then Apress © 2003 (696 pages) ActiveObjects(x, y).Draw() The authors of this text show how easy it can be to produce End If interesting multimedia games using Managed DirectX 9.0 and Next programming with Visual Basic .NET on Everett, the latest LineCount +=Microsoft's 1 version of Visual Studio. y += 1 If y > GameMapSize Then y = 0 Table of Contents Loop .NET EndGame Sub Programming with DirectX 9.0 Foreword Preface Introduction
If we run game now, able toDetection see the active objects back on the screen. To make these objects Chapter 1 our - .Nettrix: GDI+we'll and be Collision (ships and move, Artificial all we have to do is and to produce Chapter 2 -planes) .Netterpillars: Intelligence Sprites a new transformation matrix, including a translation in the x axis, -toManaged the world matrix. Since every object will have to set its own world matrix with its own particular DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ transformations, we'll need to add two new Matrix variables to the procedure: one for holding the initial world Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio matrix (with the scroll information), and another to be used by the objects when applying the transformations. Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Note that to add transformations, we can simply multiply the transformation matrices, which can be done using Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow the helper function Matrix.Multiply. Chapter 3
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 code - .Netterpillars II: Multiplayer Games and Directplay The new for the procedure is as follows: D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Nonmanaged Code
Public Sub MoveActiveObjects() Dim x As Integer, y As Integer Appendix A -LineCount The State of PC Dim AsGaming Integer = 0 Appendix B Motivations in Games World Matrix (with the scrolling calculation) ' Stores the current Appendix C -WorldMatrix How Do I Make Games? Dim As Matrix = objDirect3DDevice.Transform.World Appendix D -ObjectMatrix Guidelines for Developing Successful Games Dim As Matrix Bonus Chapter Porting .Nettrix to Pocket PC
Index List of Figures ' Draw the game field
y = CurrentLineNumber - 1 List of Tables If y < 0 Then y = GameMapSize ' We will move the objects a line below the current line number and a line ' above the last line on screen (CurrentLineNumber + Height) Do While LineCount < Height + 2 For x = 0 To Width - 1 ObjectMatrix = WorldMatrix If Not (ActiveObjects(x, y) Is Nothing) Then if ActiveObjects(x, y).Type = ClsTile.enType.Plane or _ ActiveObjects(x, y).Type = ClsTile.enType.Ship then ObjectMatrix = Matrix.Multiply(ObjectMatrix, _ Matrix.Translation(_ ActiveObjects(x, y).TranslationX, 0, 0)) ' update the location - used for collision detection ActiveObjects(x, y).X += (ActiveObjects(x, y).SpeedX / 32) ' update the translation value ActiveObjects(x, y).TranslationX += _ ActiveObjects(x, y).SpeedX End if objDirect3DDevice.Transform.World = ObjectMatrix ActiveObjects(x, y).Draw() End If Next
LineCount += 1 y += .NET 1 Game Programming with DirectX 9.0 by Santos Lobão If y > Alexandre GameMapSize Then and y =Ellen 0 Loop End Sub
ISBN:1590590511
Hatton Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest If we ran our code now, we'd immediately notice two mistakes: The ships and planes are moving on screen, but version of Microsoft's Visual Studio.
they are only going from right to left, and the ships don't stop when they reach the banks. We'll have to add some code to make the planes go back (or enter again from the left side of the screen), and to make the ships Table Contents stay of over water, going back when they reach the margin. To simplify our code, let's make the enemy plane .NET enter Game again Programming from the left-hand with DirectX side of 9.0the screen, so we won't need different images for it (one for flying east, and another for flying west). Foreword Preface
Since we'll have different tests for planes and ships, we'll need to include a second if statement that will check if the plane goes beyond the screen's width and update its position to be at the beginning of the screen; and Chapter 1 - .Nettrix: GDI+ and Collision Detection check the nearby tiles (in the Tiles array) to invert the ship speed if it gets close to a margin. To see our ships Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites and planes moving on screen, just add the following code in the right place in the MoveActiveObjects Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ procedure: Introduction
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
If ActiveObjects(x, y).Type = ClsTile.enType.Plane Then Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ' Ensures that the translation will not take the enemy plane out of the screen Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API If ActiveObjects(x, y).X * 32 > (Width * 32) Then Chapter 8 -ActiveObjects(x, .Netterpillars II: Multiplayer Games and Directplay y).X -= CInt(ActiveObjects(x, y).X) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -' update the translation value Nonmanaged Code ActiveObjects(x, y).TranslationX = -(Width * clsSprite.IMAGE_SIZE - _ Bonus Chapter Porting .Nettrix to Pocket PC ActiveObjects(x, y).TranslationX) Appendix A -If The State of PC Gaming End Appendix B - Motivations in Gamesy).Type = ClsTile.enType.Ship Else 'ActiveObjects(x, Appendix - How Do that I Make the Games? ' C Ensures translation will not take the enemy ship over land Appendix - Guidelines for Developing Successful IfD tiles(ActiveObjects(x, y).X Games + 1, y).Type = ClsTile.enType.Land Then Index ActiveObjects(x, y).SpeedX = -gameSpeed List of Figures End If If tiles(ActiveObjects(x, y).X - 1, y).Type = ClsTile.enType.Land Then List of Tables ActiveObjects(x, y).SpeedX = gameSpeed End If End If
Coding the Collision Detection Everything now looks okay, but our plane still doesn't collide with the moving enemies. The code we did for the TestCollision method in the previous chapter just checks the Tiles array for any tile that isn't water, so at this stage we only collide with the margins. The new version of this function becomes more sophisticated, including three different tests: 1. Test for collision with the margins, in the Tiles array. 2. Test for collision with active nonmoving objects (bridges and gas barrels), taking the appropriated actions (fill the tank if it's a barrel, crash the plane if it's a bridge). 3. Test for collision with the active moving objects in the current line. We'll use the bounding box algorithm for testing this collision, simplified here because we only need to check the x coordinates—the y coordinates have already been checked, because we are testing the objects in the current player's line. The final code for the collision detection procedure is shown here:
Private Function TestCollision() As DirectX Boolean .NET Game Programming with 9.0 Dim x As by Integer, y As Integer Alexandre Santos Lobão and Ellen Dim i As Hatton Integer, j As Integer
ISBN:1590590511
Apress © 2003 (696 pages)
x = Player.X / 32of this text show how easy it can be to produce The authors interesting multimedia using Managed DirectX 9.0 and y = (Player.Y + 16) / 32games + CurrentLineNumber programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
' 1. Test the tiles: If we are over water, we are not colliding If Not (tiles(x, y) Is Nothing) Then If tiles(x, y).Type = ClsTile.enType.Water Then Table of Contents TestCollision = False .NET Game Programming with DirectX 9.0 Else Foreword TestCollision = True Preface End If Introduction Else Chapter 1 - .Nettrix: GDI+ and Collision Detection TestCollision = True Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites End If Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ ' 2. Test nonmoving active objects: bridges and gas barrels Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio If Not (ActiveObjects(x, y) Is Nothing) Then Chapter 5 -'River II: over DirectInput and barrel, Writing Text to Screen If Pla.Net we are a gas fill the gas tank Chapter 6 -If Magic KindergarteN.: Adventure Games,=ADO.NET, and DirectShow ActiveObjects(x, y).Type ClsTile.enType.Gas Then Chapter 7 - MagicTestCollision KindergarteN. II: Animation = FalseTechniques and Speech API Chapter 8 - .Netterpillars II: Multiplayer Games and + Directplay Player.Gas = Player.Gas 30 D-iNfEcT: Multithreading, > Nonrectangular Windows, and Access If Player.Gas 100 Then Player.Gas = 100to Chapter 9 Nonmanaged Code GasSound.Play() Bonus Chapter Porting .Nettrix to Pocket ' If we are overPCa bridge, we are colliding Appendix A -ElseIf The StateActiveObjects(x, of PC Gaming y).Type = ClsTile.enType.Bridge Then Appendix B - Motivations in Games TestCollision = True Appendix C -End How Do If I Make Games? ActiveObjects(x, y).Dispose() Appendix D - Guidelines for Developing Successful Games ActiveObjects(x, y) = Nothing Index End If List of Figures List of Tables
' 3. Test collision against moving Active objects on the current line For i = 1 To Width If Not (ActiveObjects(i, y) Is Nothing) Then If ActiveObjects(i, y).Type = ClsTile.enType.Plane Or _ ActiveObjects(i, y).Type = ClsTile.enType.Ship Then ' checks collision using the bounding box algorithm; simplified _ ' because y is already checked against the current line number If ActiveObjects(i, y).X * 32 > Player.X And _ ActiveObjects(i, y).X * 32 < Player.X + 32 Then ActiveObjects(i, y).Dispose() ActiveObjects(i, y) = Nothing TestCollision = True End If End If End If Next End Function
If you remember the bounding box algorithm, explained in Chapter 1, it'll be easier to understand the collisioncheckingif statement in the previous code. Of course, the use of approximations for the current line and each object's coordinates will lead to an inaccurate result, but we can always return at a later date and improve the code. Everything is organized so that if we want to alter this algorithm, all we'll need to change is this function.
Figure 5-6 shows.NET a screen with some movingwith planes. Notice Game Programming DirectX 9.0the plane at the far left of the screen: It's flying over land. Although every active object is being created over water, planes don't have any limitations except to ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton keep looping in the game window. Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Figure 5-6: FlyingMultithreading, enemy planesNonrectangular in our way D-iNfEcT: Windows, and Access to Chapter 9 Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
Third Draft: Including the Shooting Feature
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
To include shooting feature in a game requires a series of steps, even in a simple 2-D game like ours. We'll Appendix C - aHow Do I Make Games? have to do following: Appendix D -the Guidelines for Developing Successful Games Index1. Create some kind of structure to hold the bullets. Since we already have the Sprite class, which stores List of Figures information such as the image and the current position, we can use an array (with 16 elements, as stated
in the game proposal). List of Tables 2. Add some code to the input device handlers to inform the player that he or she must shoot. 3. Add code to the player's movement routine to handle the information gathered from the device and create the bullets. 4. Add a procedure for moving the bullets. 5. Add code to this procedure to check for collision with obstacles, which may vary from game to game. In our case, the bullet will only be destroyed when it leaves the window (at the top), or if hits a plane or a ship (river borders, for example, won't be an obstacle). We'll see details of each step in the following sections.
Creating the Bullets Array All shooting handling will be done in the RiverEngine class, so we'll have to create a private property to store the bullets. Also creating a constant, which defines the total number of bullets, will help us to easily modify this value if we want to: Private Bullets As clsSprite() Private Const TOTAL_BULLETS As Integer = 16
We'll have to define the array size in the Initialize event of the class, simply by adding the following line: .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ReDim Hatton Bullets(TOTAL_BULLETS)
ISBN:1590590511
Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce
Handling Data from the Input games Devices interesting multimedia using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
Before including any version code of for Microsoft's the event Visual handlers Studio. of the input devices, we have to have a way to tell the player he or she must shoot. For this, we can extend the enStatus enumeration of the Player class to include a "shooting" status:
Table of Contents
.NET Game Programming with DirectX 9.0
Enum enPlayerStatus Flying = 0 Preface Dying = 1 Introduction Starting = 2 Chapter 1 Shooting - .Nettrix: GDI+ = 3and Collision Detection Chapter 2 .Netterpillars: Artificial Intelligence and Sprites End Enum Foreword
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Now, all have to do is add theAdventure code in the Keypress event forDirectShow the keyboard, and create the Chapter 6 we - Magic KindergarteN.: Games, ADO.NET, and JoystickButtonPressed event. In order to test if our code is okay up to this point, we can include a Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API message box to see the result when we fire. Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Nonmanaged Private Shared SubCode KeyPress(KeyCode As Keys) Handles Keyboard.Keypress Bonus Chapter SelectPorting Case .Nettrix KeyCode to Pocket PC Keys.Right Appendix A -Case The State of PC Gaming Player.SpeedX = gameSpeed Appendix B - Motivations in Games Paused False Appendix C - How Do I Make =Games? . . . key codes) Appendix D - Guidelines for(other Developing Successful Games Case Keys.Space Index ' Just shoot if we are neither dying nor starting a new life List of Figures If Player.Status = ClsPlayer.enPlayerStatus.Flying Then List of Tables Player.Status = ClsPlayer.enPlayerStatus.Shooting MessageBox.show("BANG!") End If End Select End Sub
Private Shared Sub JoystickButtonPressed(Button As Integer) _ Handles Joystick.JoystickButtonPressed ' Shoot with any joystick button ' Just shoot if we are neither dying nor starting a new life If Player.Status = ClsPlayer.enPlayerStatus.Flying Then Player.Status = ClsPlayer.enPlayerStatus.Shooting MessageBox.show("BANG!") End If End Sub
In Figure 5-7, we see our first shot. Don't forget to remove the MessageBox lines before going on to the next step!!
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction
Figure A message box indicates the first user shot. Chapter 1 - 5-7: .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Making -the Player Shoot
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5 the - River Pla.Net II:we'll DirectInput andtoWriting Text to Screen To make player shoot, add code the MovePlayer method. This method was coded in the previous Chapter - Magic Adventure Games, ADO.NET, and DirectShow chapter6 and, until KindergarteN.: now, simply moves the player if any of the "speed" properties are nonzero. The speed Chapter 7 -are Magic II: Animation Techniques and Speech API or presses the navigation keys on the properties set,KindergarteN. as we saw before, when the player moves the joystick Chapter keyboard. 8 -The .Netterpillars movement II:code Multiplayer is presented Gamesinand theDirectplay previous chapter, so we won't revisit it here. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 the - player shoot, we'll create a new sprite with the bullet image, set its speed to some value greater To make Nonmanaged Code
than the current gameSpeed avoidPC any strange behavior), and then code the procedure that will move the Bonus Chapter Porting .Nettrix to(to Pocket bullets and for of collision. Appendix A - check The State PC Gaming Appendix B - Motivations in Games
Since we'll have a limited array of bullet objects, before creating the bullet we'll have to loop through this array and check if there are any free elements. If not, all of the array positions are set, so we'll create a new bullet Appendix D -inGuidelines forplayer's Developing Successful Games sprite just front of the plane and set its speed, as shown in the next code sample: Appendix C - How Do I Make Games? Index List of Figures
Public Sub MovePlayer() Dim i As Integer . . . ' If the player is shooting, create a bullet and reset the status to flying If Player.Status = Player.enPlayerStatus.Shooting Then Player.Status = Player.enPlayerStatus.Flying ' Look for an empty position on the bullets array i = 0 Do Until Bullets(i) Is Nothing If i = TOTAL_BULLETS - 1 Then Exit Do End If i += 1 Loop ' If not all the array positions have bullets, create a new one If Bullets(i) Is Nothing Then Bullets(i) = New clsSprite("bullet.bmp", _ Color.FromARGB(255, 255, 0, 255), _ New POINT(Player.X + clsSprite.IMAGE_SIZE / 2 - 4, _ Player.Y + clsSprite.IMAGE_SIZE - 4), _ ClsSprite.enScaleFactor.enScalePixel, 9, 9) Bullets(i).SpeedY = gameSpeed * 1.5 End If End If
List of Tables
. . . End Sub
.NET Game Programming with DirectX 9.0
ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Apress 2003 (696 In the next section, we'll ©code the pages) movement of the bullets we have just created. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and Moving the Bullets programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Once the bullets have been created, we'll have to move them to the top of the game field, using the same approach as before with transformation matrices. Table of Contents
The bullets' movements will be totally independent of the scrolling, so we'll reset the world matrix with a simple translation using the bullet speed, set in the MovePlayer method (as we saw in the previous item).
.NET Game Programming with DirectX 9.0 Foreword
Preface In the next code sample, we'll go through the following steps: Introduction
1. For each bullet in the bullets array, check if the bullet object is set.
Chapter 1
- .Nettrix: GDI+ and Collision Detection 2. If create the translation matrix, based the current TranslationY property of the bullet object. Chapter 2 so, - .Netterpillars: Artificial Intelligence andon Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
3. Increment the TranslationY property with the current bullet speed, so the bullet will go further with - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio every call of the method.
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 - Magic KindergarteN.: Adventure Games, DirectShow 4. Also increment the y position, so we'll alwaysADO.NET, have an and up-to-date x,y position of the bullet (and we'll use Chapter this 7 -later Magic Animation Techniques and Speech API toKindergarteN. calculate the II: collisions). Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
5. If theD-iNfEcT: bullet goes off the screen, destroy it (freeing the array element, Multithreading, Nonrectangular Windows, and Access to so it can be used for another shot).
Chapter 9
-
Nonmanaged Code 6. Chapter If the bullet isn't off thetoscreen, set the world matrix and draw it. Bonus Porting .Nettrix Pocket PC Appendix A - The State of PC Gaming
Private MoveBullets() Appendix B -Sub Motivations in Games Dim AsDo Integer Appendix C -iHow I Make Games? Dim As Matrix Appendix D -BulletMatrix Guidelines for Developing Successful Games Index
For i = 0 To TOTAL_BULLETS - 1 '--- 1. Move the bullets List of Tables If Not Bullets(i) Is Nothing Then ' Creates the bullet translation matrix using the position plus the ' speed of the bullet BulletMatrix = Matrix.Translation(0, _ Bullets(i).TranslationY, 0) ' Updates the bullet location (used on collision detection) Bullets(i).Y += Bullets(i).SpeedYq Bullets(i).TranslationY += Bullets(i).SpeedY ' If the bullet get out of the screen, destroy it ' the m42 element represents the translation on the Y axis If BulletMatrix.m42 > (Height - 1) * clsSprite.IMAGE_SIZE Then Bullets(i).Dispose() Bullets(i) = Nothing Else objDirect3DDevice.Transform.World = BulletMatrix Bullets(i).Draw() End If End If Next End Sub List of Figures
We'll have to set the world matrix for every bullet, because although all bullets may have the same speed, .NET Game Programming with DirectX 9.0 they'll have different translation values. by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton If we run the game now, we'd be able to see the bullets being fired from the plane to the screen top, but they Apress 2003the (696 pages) would still have no effect© on enemies because we have yet to code the collision detection algorithm. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and Implement the Bullets' Collision Detection programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Since we'll have to test the collision for each bullet, we can include the following code inside the first if statement of the MoveBullets method, inside the for statement. Table of Contents
Basically, we'll ignore the background (the Tiles array) and check for collisions with elements from the ActiveObjects array (specifically, bridges, planes, and ships, as fuel barrels won't be destroyed). And since Foreword there are two types of objects—static and moving ones—we'll have to test the current bullet position against the Preface current x,y position of the objects, and not simply against the ActiveObjects array coordinates. .NET Game Programming with DirectX 9.0
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Dim j As Integer - .Netterpillars: Artificial Intelligence and Sprites Dim y As Integer Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ '--- 2. Test the collision for the bullets with the active objects Chapter 4 Bullets(i) - River Pla.Net: Is TiledNothing Game Fields, Scrolling, and DirectAudio If Not Then Chapter 5 River Pla.Net II: DirectInput and Writing Text to Screen ' Convert the bullet position into indexes for the ActiveObjects array Chaptery6 = -(Bullets(i).Y Magic KindergarteN.: ADO.NET, and DirectShow + Adventure 5) / 32 Games, + CurrentLineNumber ChapterIf 7 y- Magic KindergarteN. II: Animation Techniques and Speech API < GameMapSize Then Chapter 8 -'.Netterpillars II: Multiplayer Games and Directplay loop through the ActiveObjects array For D-iNfEcT: j = Multithreading, 1 To Width Nonrectangular Windows, and Access to Chapter 9 Nonmanaged Code objects (planes, ships or bridges) for the current line (y) ' Test the Bonus Chapter Porting .Nettrix to Pocket PC If Not (ActiveObjects(j, y) Is Nothing) Then Appendix A - The StateIf of PC Gaming ActiveObjects(j, y).Type = ClsTile.enType.Plane Or _ Appendix B - Motivations in Games ActiveObjects(j, y).Type = ClsTile.enType.Ship Or _ y).Type = ClsTile.enType.Bridge Then Appendix C - How Do I Make ActiveObjects(j, Games? ' checks collision using the bounding box algorithm; Appendix D - Guidelines for Developing Successful Games ' simplified here because y is already checked against the Index ' current line number List of Figures If Bullets(i).X > ActiveObjects(j, y).X * IMAGE_SIZE _ List of Tables And Bullets(i).X < (ActiveObjects(j, y).X + 1) * IMAGE_SIZE_ Then 'Player gets 200 points per enemy destroyed Points += 200 ' If colliding, destroy the bullet and the active object ActiveObjects(j, y).Dispose() ActiveObjects(j, y) = Nothing Bullets(i).Dispose() Bullets(i) = Nothing ' Plays the Explosion sound effect ExplosionSound.Play() Exit For End If End If End If Next End If End If Chapter 2
As far as the game physics is concerned, we're finished. Our game can now be played, and although it won't be a huge hit in today's market, it's still very playable and fun, too. Figure 5-8 shows our new game screen.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites Figure Shooting and destroying enemiesBasics and DirectX vs. GDI+ Chapter 3 - 5-8: Managed DirectX First Steps: Direct3D Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Final6 Version: Drawing the Game Statusandon Screen Chapter - Magic KindergarteN.: Adventure Games, ADO.NET, DirectShow One last thing our game must have is a display for the player's current status. There are a lot of ways you can - .Netterpillars II: Multiplayer Games and Directplay do this, and usually the graphical ones are the best: little planes at one edge of the screen to represent the D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter number9 of-lives left, a solid bar that gets smaller the further you fly to indicate fuel consumption, and so on. For Nonmanaged Code our purposes (to test the Font class), all we need to do is to add some status text. Chapter 8
Bonus Chapter Porting .Nettrix to Pocket PC
Appendix A - Font The State of at PCfirst Gaming To use the class, we need to define the font variables and create the font objects. The variables Appendix B Motivations in Games will be defined as properties of the GameEngine class, and the Initialize method of this class is the most Appendix C - How Make out Games? appropriate placeDotoI carry the object creation, as shown in the next code sample: Appendix D - Guidelines for Developing Successful Games Index ' Status text List of Figures Private LivesText As ClsGameFont List of TablesGasText As ClsGameFont Private
Private PointsText As ClsGameFont Function Initialize(Owner As Windows.Forms.Control) As Boolean ... ' Initializes the game text fields LivesText = New ClsGameFont("Comic Sans MS", 16, "Lives: " & _ Lives.ToString, New POINT(100, 10)) GasText = New ClsGameFont("Comic Sans MS", 16, "Energy: " & _ Player.Gas.ToString, New POINT(300, 10)) PointsText = New ClsGameFont("Comic Sans MS", 16, "Points: " & _ Points.ToString, New POINT(500, 10)) ... End Function
To write the status text on the screen, we'll create a DrawStatus method, which will simply set the text color and call the Draw method to show the values of the Lives,Points, and Gas properties. In order to make the status text easier to see against any kind of background, we'll use a little trick and include a dark gray shadow with the text to make it more readable. All we need to do is to write the same text twice, moving the text a pixel to the left and down when drawing the shadow, as shown in the following code example:
Sub DrawStatus() .NET Gamegray Programming ' Draw the dark shadow with DirectX 9.0 by Alexandre Santos Lobão and Ellen LivesText.Color = Color.FromARGB(255, 50,ISBN:1590590511 50, 50) Hatton GasText.Color = Color.FromARGB(255, 50, 50, 50) Apress © 2003 (696 pages) PointsText.Color = Color.FromARGB(255, 50, 50, 50) The authors of this text how easy it can be toNew produce LivesText.Draw("Lives: " show & Lives.ToString, POINT(101, 11)) interesting multimedia games using Managed DirectX 9.0 and GasText.Draw("Energy: " & Basic Player.Gas.ToString & "%!", New POINT(301, 11)) programming with Visual .NET on Everett, the latest PointsText.Draw("Points: " &Studio. Points.ToString, New POINT(501, 11)) version of Microsoft's Visual ' Draw the yellow text Table of Contents LivesText.Color = Color.FromARGB(255, 255, 255, 0) .NET Game Programming with DirectX 9.0 GasText.Color = Color.FromARGB(255, 255, 255, 0) Foreword PointsText.Color = Color.FromARGB(255, 255, 255, 0) PrefaceLivesText.Draw("Lives: " & Lives.ToString, New POINT(100, 10)) Introduction GasText.Draw("Energy: " & Player.Gas.ToString & "%!", New POINT(300, 10))
" & Points.ToString, New POINT(500, 10)) ChapterPointsText.Draw("Points: 1 - .Nettrix: GDI+ and Collision Detection End Sub Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
If we want to include a border around all the text borders, we can use a similar trick, drawing the same text four - River Pla.Net II: DirectInput and Writing Text to Screen times: one pixel to the left, one pixel down, one pixel to the right, and a pixel up. This will create a complete Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow border. Depending on the character size, you can try moving two pixels instead of one; experiment to see which Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API result is best for each type of game. Chapter 5
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Figure 5-9 shows D-iNfEcT: the Multithreading, game screen with Nonrectangular the status text Windows, at the top. and Access to Chapter 9 Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 5-9: Score, fuel, and lives-left information, finally! Including this status text ends our coding phase. In the next section, we'll add some final details to our game that will make it even more interesting.
Game Programming with DirectX 9.0 Adding the .NET Final Touches by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hattona lot of ideas come to mind about how to make it better. As we stated before, although When coding a game, Apressto © 2003 (696 pages) it's not always possible implement all the new suggestions that arise, we must write them down for later use. Maybe a suggestion will be implemented in a how future version The authors of this text show easy it canof bethe to game, produceor even in other related games. interesting multimedia games using Managed DirectX 9.0 and withtwo Visual .NET on Everett, the latest As for our game, programming we'll implement newBasic features—a "game pause" key, and support for force-feedback version of Microsoft's Visual Studio. joysticks. In addition, you might want to consider other extra features for your version of the game, such as building a high scores table, implementing animation for when the enemy explodes, and improving the collision detection algorithm to produce more accurate results. Table of Contents .NET Game Programming with DirectX 9.0
Including a Pause Feature
Foreword Preface
We included a pause feature to our sample games in Chapters 1 and 2, but these are very simple games compared to River Pla.Net. In this game, we'll have to take into account many things, like ignoring the input Chapter 1 - .Nettrix: GDI+ and Collision Detection from DirectInput and stopping the music and the scrolling, as well as enemy and bullet movements. Introduction Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter - Managed DirectX First Steps:by Direct3D Basics DirectX vs. method, GDI+ We can3 start coding our pause feature changing the and DrawStatus in order to display a "Game Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Paused" message if the game is paused. To do this, we'll have to include the next lines in the method: Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Dim PauseText As ClsGameFont Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API PauseText = New ClsGameFont("Comic Sans MS", 20, _ Chapter 8
- .Netterpillars Multiplayer Games Directplay "Game II: Paused - Move orandShoot to Continue ", New POINT(100, 220)) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to If Paused Then Chapter 9 Nonmanaged Code= Color.FromARGB(255, 255, 255, 0) PauseText.Color Bonus Chapter Porting .Nettrix to Pocket PC PauseText.Draw() Appendix End IfA - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games?
To avoidDre-creating fontDeveloping object every time weGames are in pause mode, we can define the PauseText variable as Appendix - Guidelinesa for Successful a class property, and initialize it in the Initializemethod.
Index
List As of forFigures the music, we must know when the paused status has changed so that we call the StopPlaying and List of PlayTables methods only once. The following code lising must be included in the RiverEngine'sPlayMotifs
method: Static OldState As Boolean = Paused ' If the states changes, stop or start the background music If OldState <> Paused Then If Paused Then BackgroundMusic.StopPlaying() Else BackgroundMusic.Play() End If OldState = Paused End If
As for all the movement methods (MovePlayer,MoveBullets,MoveActiveObjects, and Scroll), we can't simply enclose all the method lines in a big if statement to avoid them from being called when the game is paused. We must apply the current transformations for the movements, but not change the translation values. For example, for the MovePlayer method, we must apply the current translation to the player plane and redraw it for every frame in the same position. In other words, all we need to do is not increment the translation
values on every call of the method.
.NET Game Programming with DirectX 9.0
ISBN:1590590511 All the movementbymethods Alexandre must Santos follow Lobão this and same Ellen rule of thumb. The next code listing shows the MovePlayer Hatton the code for the other methods is given completely on the accompanying CD-ROM. method as an example;
Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce Public Sub MovePlayer() interesting multimedia games using Managed DirectX 9.0 and Dim i As programming Integer with Visual Basic .NET on Everett, the latest ' Initializes the playerVisual position version of Microsoft's Studio. in the middle of screen (x-axis) ' and 3 tiles up (y-axis) Static PlayerMatrix As Matrix = Matrix.Translation(_ Table of Contents 10 * clsSprite.IMAGE_SIZE, 3 * clsSprite.IMAGE_SIZE, 0) .NET Game Programming with DirectX 9.0 Foreword
If Not Paused Then ' ... Player position updating code Introduction End If Chapter 1 -objDirect3DDevice.Transform.World .Nettrix: GDI+ and Collision Detection = PlayerMatrix Chapter 2 -Player.Draw() .Netterpillars: Artificial Intelligence and Sprites ChapterEnd 3 -Sub Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Preface
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
The screen showing the game pause method is given in Figure 5-10.
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 5-10: Paused game screen Next we'll learn how to add force-feedback effects when controlling our game with a joystick.
Adding Support for Force-Feedback Joysticks When dealing with joysticks, an interesting feature is to include force-feedback control in our games, so the user can enjoy a more interactive experience. When creating force effects, there are two basic approaches: loading the effects from a previously created effect file, or creating the effect from scratch for our program. The effect files are created with the Force Editor, a tool that comes with the DirectX SDK for creating and testing force-feedback files. It saves the effects into files, and we'll load them later with the CreateEffectFromFile function. This is the easier way to deal with effects, allowing us to include sophisticated force effects without a lot of programming.
We'll see here how to create a simple force effect in our program, including a new method in the Joystick Game Programming with DirectX 9.0 class to generate.NET movement in the joystick according to a direction passed as a parameter. by Alexandre Santos Lobão and Ellen
ISBN:1590590511
When creating anHatton effect, we can define the following properties: Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce
Magnitude:interesting The strength of the force to using be applied generated multimedia games Managed DirectX by 9.0the andjoystick, ranging from 0 (no force) to 10,000 (maximum programming forcewith for the Visual device), Basic .NET growing on Everett, linearly.the latest version of Microsoft's Visual Studio.
Direction: The direction from which the force comes. The default behavior is to use polar coordinates, Table of Contents where the direction is measure by hundreds of degrees from the north direction (the negative y axis); but .NET Game this can Programming be changedwith to use DirectX Cartesian 9.0 coordinates. For example, while the left direction is represented by x
= -1, y = 0 in Cartesian coordinates, it will be represented by degrees = 27,000 in polar coordinates. Foreword Preface Introduction Duration: The amount of time the effect lasts in microseconds. Chapter 1 - .Nettrix: GDI+ and Collision Detection
We can2 also specify if theArtificial effect will be a ramp force or periodic effect. A ramp force is a steady rising or Chapter - .Netterpillars: Intelligence and Sprites decreasing withDirectX a minimum and a Direct3D maximum magnitude. A periodic effect will repeat the force effect at Chapter 3 - force Managed First Steps: Basics and DirectX vs. GDI+ specific4time intervals. Chapter - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
To create a new effect in our code, we must set the parameters of an Effect data structure and call the Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow CreateEffect function. The object returned by the function will be a reference to the feedback effect and Chapter - Magicby KindergarteN. II: Animation Techniques and Speech API can be 7triggered calling the Start method. The next code listing shows a function to be included in our Joystick which will generate a simple D-iNfEcT: Multithreading, Nonrectangular Windows, and Accessclass, to Chapter 9 Nonmanaged Code effect that pulls the joystick away from the center, according to the direction specified as a parameter. Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Sub ForceEffect(ByVal Direction As enDirection) Appendix B Motivations in Games Dim -EffectData As New Effect() Appendix C -effDirection(1) How Do I Make Games? Dim As Integer Appendix D -effAxes(1) Guidelines for Developing Successful Games Dim As Integer Index List of Figures With EffectData List of Tables' We are using the default value for these members
'.StartDelay = 0 '.TriggerRepeatInterval = DI.Infinite '.UsesEnvelope = False '.SamplePeriod = 0 ' Set the effect type and flags that will control the effect .EffType = EffectType.ConstantForce .Flags = EffectFlags.Cartesian Or EffectFlags.ObjectOffsets ' Set the magnitude and the gain .Constant.Magnitude = DI.NominalMax .Gain = DI.NominalMax ' Set the duration (in microseconds). For infinite time use DI.Infinite; .Duration = 100000 ' One tenth of a second ' Set the trigger button - No trigger button .TriggerButton = Button.NoTrigger ' Set the axes we will be working on effAxes(0) = JoystickOffset.X effAxes(1) = JoystickOffset.Y .SetAxes(effAxes) ' Finally, set the direction Select Case Direction Case clsGameEngine.enDirection.South
effDirection(0) = 0 .NET effDirection(1) Game Programming = with -2DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen Case clsGameEngine.enDirection.SouthWest Hatton effDirection(0) = 1 Apress © 2003 (696 pages) effDirection(1) = -1 The authors of this text show how easy it can be to produce Case clsGameEngine.enDirection.west interesting multimedia games using Managed DirectX 9.0 and effDirection(0) = .NET 2 programming with Visual Basic on Everett, the latest effDirection(1) = 0 version of Microsoft's Visual Studio. Case clsGameEngine.enDirection.NorthWest effDirection(0) = 1 Table of Contents effDirection(1) = 1 .NET Game Programming with DirectX 9.0 Case clsGameEngine.enDirection.North Foreword effDirection(0) = 0 Preface effDirection(1) = 2 Introduction Case clsGameEngine.enDirection.NorthEast effDirection(0) = -1 Chapter 1 - .Nettrix: GDI+ and Collision Detection effDirection(1) 1 Sprites Chapter 2 - .Netterpillars: Artificial Intelligence=and Case clsGameEngine.enDirection.East Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ effDirection(0) = -2 and DirectAudio Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, effDirection(1) = 0 Text to Screen Chapter 5 - River Pla.Net II: DirectInput and Writing Case clsGameEngine.enDirection.SouthEast Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow effDirection(0) = -1 Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API effDirection(1) = -1 Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Select D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -.SetDirection (effDirection) Nonmanaged Code End With
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
If Not DIEffect Is Nothing Then Call DIEffect.Unload() Appendix C - How Do I Make Games? End If Appendix D - Guidelines for Developing Successful Games DIEffect = New EffectObject(ForceFeedbackGuid.ConstantForce, _ Index EffectData, InputDevice) List of Figures DIEffect.Start(1) Appendix B - Motivations in Games
List of Tables
End Sub
In the previous code sample, we only set the minimum number of parameters needed to create the required effect.Duration,Axis, and Constant.Magnitude are the ones used to set the basic effect characteristics discussed previously. The Gain and TriggerButton members should be set for all effects, since the default values of 0 aren't suitable. Setting Gain to 0 will scale down our force to zero, while 10,000 (the value we used) will apply no scale over the Magnitude value. TriggerButton specifies the joystick button number that will trigger the effect (useful, for example, if we want our effect to be triggered and move our joystick back every time we shoot a gun); the default value of zero will associate the effect with the first joystick button. Tip The Effect data structure has many other parameters that allow us to create very complex force effects, including members to control periodic effects, ramp forces, and constant force feedback. Refer to the SDK help files for a complete description of each of the structure's members. To make us able to test the newly created force effect feature, we must define when the effect will be fired. Since our goal here is simply to test the effects, let's create a new obstacle that will shake our plane a little and move it left or right. The new obstacles will be floating arrows over the river and are shown in Figure 5-11.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction
Figure New force-feedback Chapter 1 - 5-11: .Nettrix: GDI+ and Collision obstacles Detection appearing on screen Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 -we'll Managed Steps: Direct3D to Basics and DirectX GDI+the new type of tiles in the Tiles Of course need DirectX to makeFirst three adjustments our game code:vs. Create Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio class, include the lines to load the new tile types in the initialization of the RiverEngine class, and include Chapter 5 for - River Pla.Net the II: DirectInput Writing Text to Screen the code generating effect in theand TestCollision method of the RiverEngine class. Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
The new of the Tiles class willTechniques be as follows: Chapter 7 enumeration - Magic KindergarteN. II: Animation and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Enum D-iNfEcT: enType Multithreading, Nonrectangular Windows, and Access to Chapter 9 Nonmanaged Code Background = 0 Bonus Chapter Porting= .Nettrix to Pocket PC Water 1 Appendix A -ArrowWest The State of PC = Gaming 2 3 Appendix B -ArrowEast Motivations in=Games = I 4Make Games? Appendix C -Land How Do = 5 for Developing Successful Games Appendix D -Gas Guidelines Ship = 6 Index Plane = 7 List of Figures Bridge = 8 List of Tables End Enum
The lines to be included in the LoadGameLine function are variations of the current code, as shown in the next code listing: Case "<" strSpriteFileName = "ArrowLeft" Type = ClsTile.enType.ArrowWest Case ">" strSpriteFileName = "ArrowRight" Type = ClsTile.enType.ArrowEast
The next code listing shows the lines we must include in the TestCollisionmethod to test the collision: ' Test collision against force feedback obstacles If Not (ActiveObjects(x, y) Is Nothing) Then ' Generate force effects according to the force feedback obstacle we hit, ' moving the player to the same direction of the arrow If ActiveObjects(x, y).Type = ClsTile.enType.ArrowEast Then Joystick.ForceEffect(clsGameEngine.enDirection.East)
Player.SpeedX = clsSprite.IMAGE_SIZE .NET Game Programming with DirectX 9.0 TestCollision = False ISBN:1590590511 by Alexandre Santos Lobão and ElseIf ActiveObjects(x, y).TypeEllen = ClsTile.enType.ArrowWest Then Hatton Joystick.ForceEffect(clsGameEngine.enDirection.West) Apress © 2003 (696 pages) Player.SpeedX = -clsSprite.IMAGE_SIZE The authors of=this text show how easy it can be to produce TestCollision False interesting multimedia games using Managed DirectX 9.0 and End If programming with Visual Basic .NET on Everett, the latest End If version of Microsoft's Visual Studio. Table of Contents .NET We Game can now Programming change ourwith game DirectX map9.0 to include as many force-feedback obstacles as we want. Feel free to use
a lot of them together to see the final effect on the game's playability. Foreword Preface
Some additional improvements to our game would be including forcefeedback effects when shooting and dying, and using the newly learned text output features to create a high scores screen. We leave this for you to Chapter 1 - .Nettrix: GDI+ and Collision Detection do as an exercise on your own. Introduction Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Summary
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton In this chapter, we finished the River Pla.Net game, including extra features to support different input Apress 2003 (696 pages) devices and to add user©feedback about the game's current status on screen. The authors of this text show how easy it can be to produce
The points covered in this chapter include the using following: interesting multimedia games Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
Introduction to version DirectInput of Microsoft's and theVisual basicStudio. concepts regarding gathering input from different input devices Table of Contentstext output on the screen device, a much-needed feature to present game information to Presenting .NET Game Programming with DirectX 9.0 the player Foreword
Adding three classes to our game classes library, used to control the different input devices and send Preface feedback to the events controlled by the use of the game
Introduction
Chapter 1 - .Nettrix: GDI+ and Detection Adding one more class to Collision our game library to control the display of text on screen Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites
Adding simple force-feedback effects to our games to explore horizons in our games Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX new vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
In the next chapter, we'll introduce the DirectShow set of components, used to include streaming media - River Pla.Net II: DirectInput and Writing Text to Screen support in our games (such as playing video files or MP3 music files), while examining basic gaming Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow concepts about creating adventure games. We'll also look at how to code data access in .NET using Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API ADO.NET. Chapter 5
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Chapter .NET 6: Magic KindergarteN.:ISBN:1590590511 Adventure Games, by Alexandre Santos Lobão and Ellen Hatton ADO.NET, and DirectShow Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visualclasses Studio. created in the previous chapters, which will allow us to In this chapter we'll use some of the game
Overview
easily create a new kind of game-an adventure game-with only a few adjustments, as shown in Figure 6-1. This will also allow us to concentrate our efforts on creating new classes for this specific kind game. We'll Table of Contents create classes to manage the adventure game cursor and the player, and to load screens and objects, .NET Game Programming with DirectX 9.0 among other things. Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Figure KindergarteN., this chapter's sample game Appendix C - 6-1: How Magic Do I Make Games? Appendix D - Guidelines for Developing Successful Games
We'll also explore basic DirectShow concepts, which will allow us to play streaming media-for example, MP3 sound files or MPEG video files-as well as learn how to access data for our games using ADO.NET.
Index
List of Figures
List of Tables Before discussing any of these topics, we'll first look at the history of adventure games.
.NET Game Programming with DirectX 9.0 Adventure Games by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton We don't know for sure when the term adventure game originated, but we can assume that the first person Apress © 2003 (696 pages) to use it was a role-playing game (RPG) fan, since the RPGs first became popular in the United States almost at the same time as the first Z80 show computers hit the shelves. The authors of this text how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming Visual Basicof.NET on Everett, the latest The following sections presentwith a short history adventure games. version of Microsoft's Visual Studio.
Text-Based Adventures Table of Contents
TheGame earlierProgramming adventure games didn't have .NET with DirectX 9.0 any graphical element and were just interactive stories that you read through computer output and controlled by typing commands on a keyboard. Foreword Preface
The very first adventures ran on mainframes (some well known titles were Adventure and Star Trek) whose dumb terminals didn't have any graphical capabilities. Sometime later they appeared on the first Chapter 1 computers, - .Nettrix: GDI+ andvideo Collision Detection personal but the capabilities on these first desktops were very limited, with only block Chapter 2 .Netterpillars: Artificial Intelligence and Sprites graphics or no graphics at all. Introduction
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Even with limited graphics could find some adventure games that showed Chapter 4 -these Riverextremely Pla.Net: Tiled Game Fields, capabilities, Scrolling, andwe DirectAudio
very simple graphics, sometimes built up with characters, these graphics were used only as Chapter 5 - River Pla.Net II: DirectInput and Writing Text to but Screen illustrations like those in books. Adventure Games, ADO.NET, and DirectShow Chapter 6 - Magic KindergarteN.: Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Most of these earlier adventure games took place in castles, caves, or labyrinths, just like the first board - .Netterpillars II: Multiplayer Games and Directplay RPGs. Since then, both genres of game have evolved quite a bit, in different ways but always with many D-iNfEcT: Multithreading, Nonrectangularversions Windows, Access to board RPGs appeared, such things in Since the first computer-based of and some famous Chapter 9 common. Nonmanaged Code as Dungeon and Dragons, the border between computer RPGs and adventures has become fuzzy. Bonus Chapter Porting .Nettrix to Pocket PC Sometimes it's difficult to tell exactly the genre of some games, because adventures have also come to Appendix A - The State of PC Gaming incorporate many RPG elements through the years. Chapter 8
Appendix B - Motivations in Games
Appendix One main C -difference How Do I between Make Games? an RPG and an adventure game is the focus of the game. The main focus
of an RPG the player's character, who evolves as the player undertakes specific quests until the player Appendix D - is Guidelines for Developing Successful Games is able to achieve the final goal, which is usually saving the world from some kind of danger. In adventures, Index weofcould say that the focus is more on the puzzles and the story than on the player, because the player List Figures character doesn't evolve or earn "experience points" as he or she solves the puzzles—the player just List of Tables keeps solving the problems until the game is over. In adventures we usually see more text and more variation in the stories, and in RPGs we usually have more action than in adventures, but, as we said before, the border is sometimes fuzzy. Examples of earlier adventures are Castle Elsinore and The Phantom's Revenge, from Temple Software. In these games, the normal game flow was something like this: 1. The computer tells the user his or her current position and describes any game characters and what the player is carrying (the inventory). 2. The player types the action he or she wants the computer to do. 3. The computer parses the typed phrase and, hopefully, does something. Many times, all the player gets as a response is "I don't understand what you are saying." If you're like us, you probably still remember the first adventure game you played, and the specific scene when the computer gave such a good answer that you became an instant fan of this type of game. However, you might also have become frustrated with the lack of useful responses. The input/output of such a game is shown in the following snippet. Try to imagine it on a black monochrome screen (such as a Hercules monitor, one of the most common ones when these early text-based adventure games were being played), which only displays 80 characters across and 25 rows down, with squared, glowing green characters and a blinking cursor. The capitalized phrases are the player's. You are in a dark room.
You are carrying a glass of water. .NET Game Programming with DirectX 9.0 > TURN ON LIGHT ISBN:1590590511 Alexandre Santos Lobão and Ellen The light is by turned on. Hatton You are in a big room. There is a sword on the floor. Apress © 2003 (696 pages) There are doors to the north and the west. The authors of thisof textwater. show how easy it can be to produce You are carrying a glass interesting multimedia games using Managed DirectX 9.0 and > GET SWORD programming with Visual Basic .NET on Everett, the latest You get the sword. version of Microsoft's Visual Studio. You are in a big room. There is a sword on the floor. There are doors to the north and the west. Table Contents You ofare carrying a glass of water and a sword. .NET Game Programming with DirectX 9.0 > GO WEST Foreword You enter a small room. There is a flower here. Preface The flower is begging for water. Introduction You are carrying a glass of water and a sword. > WATER Chapter 1 -FLOWER .Nettrix: GDI+ and Collision Detection I don't "WaterIntelligence flower"and Sprites Chapter 2 -understand .Netterpillars: Artificial > GIVE TO DirectX THE FLOWER Chapter 3 WATER - Managed First Steps: Direct3D Basics and DirectX vs. GDI+ I don't "Give water the flower" Chapter 4 -understand River Pla.Net: Tiled Game Fields, to Scrolling, and DirectAudio > USE5 GLASS ON FLOWER Chapter - RiverWITH Pla.NetWATER II: DirectInput and Writing Text to Screen I don't understand "Use glass with water on flower" Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow > KILL FLOWER Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Don't be ridiculous! Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
And that's it. This sort of treatment inspired one of your authors to write his first adventure game, Deep Cave. This adventure never hit the shelves, but was a good starting point to help him understand what is Appendix - The project. State of PC Gaming behind aAgame Bonus Chapter Porting .Nettrix to Pocket PC Appendix B - Motivations in Games
The firstCgraphical game appeared shortly after that, as we'll discuss in the next section. Appendix - How Doadventure I Make Games? Appendix D - Guidelines for Developing Successful Games
Graphical Adventures
Index
List of Figures
The graphical adventure games offered little improvement over the text-based ones: They simply List of first Tables exchanged the room description with a static graphic, usually without colors. Still, these games were an important step forward because they allowed players to really see the differences from one room to another, as well as move through the game without needing to draw a map on a piece of paper to see where they were going and where they had been. There were many games with this primary interface, like The Hobbit and Inca Adventure, but just a few became widely recognized. A big improvement occurred when Sierra launched its Leisure Suit Larry in the Land of the Lounge Lizards game. This was possibly the first adventure game to become a blockbuster, and it had many sequels. "Larry," as the game was called by its fans, arrived before the mouse became widely used, so it still suffered from the interpretation problems of text-based adventure games: Sometimes the game simply didn't understand the command the user was typing. But it was packed full of humor, and the player character was finally seen on screen and actually moved and did actions as commanded. All of this was done using then cutting-edge 4-color enhanced graphics adapter (EGA) graphics. Figure 6-2 shows a screen from the first of the Leisure Suit Larry series.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Figure 6-2: Leisure Suit Larry in the Land of the Lounge Lizards Table of Contents
Although like thiswith oneDirectX usually9.0 had a help screen describing all verbs handled by the game, there .NET Game games Programming was still room for improvement. The growing use of the mouse with PCs signaled the beginning of a new Foreword adventure game generation. Preface Introduction - .Nettrix: GDI+Adventures and Collision Detection Point-and-Click
Chapter 1 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites The advent of the mouse greatly the usability of the adventures. Leisure Suit Larry had many Chapter 3 - Managed DirectX First improved Steps: Direct3D Basics and DirectX vs. GDI+
sequels, newPla.Net: series arose: King'sFields, Quest, Police Quest, Space Quest, Monkey Island, and many Chapter 4 and - River Tiled Game Scrolling, and DirectAudio others.
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter KindergarteN.: Adventure Games, ADO.NET, and DirectShow Almost6all -ofMagic the first mouse-enabled adventure games had interfaces with some common points, which Chapter 7 Magic KindergarteN. II: Animation Techniques and Speech API were improved upon in subsequent versions of each game: a main screen, a verb list, and an inventory. Chapter 8 screen - .Netterpillars Multiplayer Games andand Directplay Themain is whereII: the actions take place where the player must click objects to act upon D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to them. A9 verb Chapter - list is where the player chooses the current action by clicking a verb. An inventory is a list of Nonmanaged the objects carried by theCode player. The last important component of an adventure is the dialog between the Bonus Chapter Porting .Nettrixand to Pocket PC characters. In a mouse-enabled adventure game, the dialog player-controlled character the game Appendix A The State of PC Gaming choices usually pops up somewhere on screen to allow the player to choose the phrases when talking to Appendix B - Motivations in Games the nonplayer characters. Appendix C - How Do I Make Games?
A good example of thisfor kind of adventure is LucasArts Appendix D - Guidelines Developing Successful Games Entertainment's The Secret of Monkey Island, which attracted a legion of new fans to this game genre. A screen shot of this game is shown in Figure 6-3. Index List of Figures List of Tables
Figure 6-3: The Secret of Monkey Island As we can see in Figure 6-3, the inventory is just a list of names of objects (on the bottom-right side), and 12 different verbs (Open, Close, Push, Pull, Use, Walk to, etc.) from which to choose on the bottom-left side. With each new version, the adventures gained simpler interfaces: fewer verbs, more tips on which objects can be used in the game (the active objects), improved gameplay and graphics. The genre then received a new description: point-and-click adventure games. Eventually, the verbs were replaced by different mouse pointers, with each pointer representing one type of action, of which there were usually no more than five—for example, an eye icon for examining items, a hand for getting objects, a wrench for using objects, a pair of legs for walking, and a mouth for eating and talking.
LucasArts' Sam and Max Hit the Road reached even higher levels of abstraction, where even phrases in a .NET Game Programming with DirectX 9.0 dialog were not presented to the player to choose from. Only graphical tips for the phrases appeared on ISBN:1590590511 by would Alexandre Santos Lobão and Ellen screen: The player select a question mark to ask a question, an exclamation mark to explain Hatton something, a duck to chat, and sometimes a face to talk about a specific game character and an object Apress © 2003 (696 pages) icon when the player needs to talk about such an object in the game. Adventure game fans didn't like this The authors of this text show how easy it can be to produce kind of totally wordless interface, and later games returned to the previous formula. Figure 6-4 presents a interesting multimedia games using Managed DirectX 9.0 and typical Sam and Max Hit the Road programming with screen. Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter Figure 2 - 6-4: .Netterpillars: Sam andArtificial Max HitIntelligence the Road and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ As we can from this figure, the user interface hasand been reduced to a single box in the bottom-right Chapter 4 -see River Pla.Net: Tiled Game Fields, Scrolling, DirectAudio
corner of the screen for accessing the inventory. The mouse cursor changes to represent the verbs and - River Pla.Net II: DirectInput and Writing Text to Screen icons to control the dialog, which appears only when the player starts a conversation. A typical example of Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow icon dialogs is shown in Figure 6-5. Chapter 5 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
6-5: Sam.Nettrix and Max the PC Road dialog icons BonusFigure Chapter Porting to Hit Pocket Appendix A - The State of PC Gaming
In the next section, we'll summarize the most important points to keep in mind when coding an adventure game.
Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX Games 9.0 Technical Tips for Coding Adventure by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton As we've discussed previously, before writing the first line of code in any game, it's very important to Apress © 2003 pages) the game goals, details about the gameplay, design, etc. But generate a project in which we(696 describe when coding an adventure game, kind of work is even more important. The authors of thisthis text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and withmust Visual Basic on Everett, latest an adventure is the story. Of Possibly the mostprogramming critical item we take into.NET account when the planning version of Microsoft's Visual Studio. course the interface must be user friendly, or users may abandon the game before they've had enough time to understand the story, but the story is what will keep the user playing until the end of the game and produce enough interest to justify sequel games. Table of Contents .NET Game Programming DirectX 9.0 story: the story flow, a good ending, deep characters with strong Many factors contribute with to create a good Foreword personality, well-thought-through and logical puzzles (neither too easy, nor too hard), and good dialogs. Preface Making a good adventure game is a challenge that can be compared to making a good movie. Introduction
Here's 1a summary the ten necessary to creating an adventure game. Of course this is not an Chapter - .Nettrix:ofGDI+ andsteps Collision Detection exhaustive but it'll helpArtificial you when creatingand yourSprites first adventure. After that, you'll be able to incorporate Chapter 2 - list, .Netterpillars: Intelligence the extra you think are First necessary, according to your experience. Chapter 3 steps - Managed DirectX Steps: Direct3D Basics andown DirectX vs. GDI+ 1. Define the Pla.Net: main focus your Fields, story: comedy, terror, or what? Chapter 4 - River TiledofGame Scrolling, drama, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
2. Define the game's goal: Will the player save the world? Will he or she defeat an enemy? Will the Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow player find a treasure? Chapter 8 - .Netterpillars Games and Directplay 3. Choose the genreII: of Multiplayer graphics you'll use: Will they be realistic, cartoonish, or surreal? Defining the D-iNfEcT: Multithreading, Nonrectangular and thinking Access toabout different possibilities when genre early on will help your artistic Windows, team to start Chapter graphics 9 Nonmanaged Code the next steps are discussed. Bonus Chapter Porting .Nettrix to Pocket PC
4. Write theState gameofflow: How will the story go from beginning to end? Appendix A - The PC Gaming Appendix B - Motivations in Games
5. Describe game characters: Which characters will be presented? Which ones will be there to give playing tips? Which ones will only add color to the surroundings? Which will be friendly and which Appendix D - Guidelines for Developing Successful Games will be hostile? For each important character, you must define the character's background: What is Index his or her main motivation? What are his or her most important characteristics? Appendix C - How Do I Make Games?
List of Figures
List of 6.Tables Specify the screens or rooms: What will be the game locations that the player will move across?
Basically, we must read the game story and create "shots," breaking it into discrete pieces, one for each location. 7. Create the puzzles and objects: These objects are usually very closely related. Logical puzzles are the key to a good adventure. You know that a specific adventure fails when you see the user is stuck, trying each object in the inventory with all objects on screen to find a solution. This is very common, and the game developer must create a balance between logical puzzles and easy ones to make the game more appealing. 8. Write the game dialogs: It's in these dialogs that the player will discover the background of each of the characters. In some games a player might run into a muscly, angry-faced character and, upon talking to him, discover that in fact he is a friendly guy. This kind of surprise makes the game more interesting. Good dialog requires the development team to write different dialog paths in order to give the player a flexible approach when talking to the characters. Also, in some games the dialogs are part of the puzzles: You can solve a puzzle only by choosing the right words when speaking. 9. Define a table describing the result for each action over each active object and character, and a table describing which objects will act with others: It's important not only to define the actions that will help with the game solution, but also extra actions that will add fun to the game's story. 10. Add the final touches: Think about cut-scenes (short movies used on introduction and between different game phases) that go deeper into the characters' backgrounds and the story flow. Create extra puzzles and characters. Define some easter eggs (hidden actions or screens that will only
10.
appear when the player does some specific action). Decide whether the game will have cheats or .NET Game Programming with DirectX 9.0 not, like secret codes to give extra power to the player character, or specific keyboard sequences Lobão that allow by theAlexandre player to Santos go to the nextand theEllen game level. ISBN:1590590511
Hatton Apress ©thing 2003 (696 pages) Note One important to remember when writing your games is that it's almost impossible to The authors of this details text show howplanning easy it can be to produce define ALL of your game at the stage. When coding, new ideas will arise about multimedia gamesorusing DirectX 9.0features and how to interesting increase character appeal, newManaged puzzles and extra to be created; so it's up to programming with Visual Basic .NET on Everett, the latest you to create the perfect balance between planning too much and planning too little. An extreme version of Microsoft's Visual Studio.
in either category will usually lead to disaster.
Another important point to stress is that the planning documents (scripts, storyboards, technical projects, Table of Contents spreadsheets, etc.) are with not static, but living, and they get updated with more details and corrections as the .NET Game Programming DirectX 9.0 project evolves. Foreword Preface
On the technical side, you must think about the game interface: Will your game follow some interface
Introduction pattern common to other games, or will you create something totally new? Where on screen will dialogs Chapter 1 -(below .Nettrix: Collision Detection take place orGDI+ aboveand characters' heads, within balloons, etc.)? How can the user distinguish Chapter 2 background - .Netterpillars: Artificial and Sprites between objects and Intelligence active objects—with status text tips, highlights, or mouse pointer Chapter 3 -Which Managed DirectX Steps:deal Direct3D andmouse DirectXpointer vs. GDI+ changes? actions willFirst the game with?Basics Will the change to reflect different action Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, andcarried DirectAudio verbs chosen by the player? How many objects can be by the player? How will the player access Chapter these objects—through 5 - River Pla.Net aII: game DirectInput inventory? and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Data Game Programming DirectX 9.0 ADO.NET and Access inwith Games by Alexandre Santos Lobão and Ellen
ISBN:1590590511
It's not our goal inHatton this section to discuss everything about data access or about ADO.NET; we'll only see Apress 2003 (696 pages) a simple program that reads data from a given data source, and the basic information we©need to create then use these concepts later in the chapter. any details about how to update data or The authors of this text show We howalso easywon't it cansee be to produce multimedia games using Managed DirectX 9.0 and making searchesinteresting on a database. programming with Visual Basic .NET on Everett, the latest version of Microsoft's VisualtoStudio. Game development teams usually choose create their own data structures, not only for in-memory
handling but also to store information on disk using their homemade data access routines. This approach is especially valuable when coding games of high graphical intensity, when you need to achieve the best Table of Contents performance results possible in every aspect of the game. But in other games (like most adventures), we .NET Game Programming with DirectX 9.0 don't think this is imperative, because extra time is spent writing data access routines instead of improving Foreword other aspects of the game. Preface
Introduction Tip Using simple data access methods-such as reading text files or using premade data access Chapter 1routines, - .Nettrix: and Collision Detection likeGDI+ ADO.NET-will also give your game extra appeal to international audiences: The Chapter 2easier - .Netterpillars: the game isArtificial to translate Intelligence (we are and notSprites talking about real localization, just translation), the Chapter 3better. - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
A good example of this is the first game of Sid Meyer's Civilization series: Much of the game's text - River Pla.Net II: DirectInput and Writing Text to Screen was in text files and you could find, some time after the game was released, translated files Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow (French, Portuguese, etc.) for this game on fan sites throughout the Internet. Chapter 5 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 - .Netterpillars II: Multiplayer Directplay In the gaming world, ADO.NET can be Games used toand read configuration files written with XML, read game data, D-iNfEcT: Multithreading, Nonrectangular Windows, Access to will always provide faster and even save game files. Although writing your own read andand save routines Chapter 9 Nonmanaged Code speed with the effort it takes to write your customized routines for each type code, it is important to balance Bonus Chapter Porting .Nettrix Pocket PC of data access used in each to new game. Appendix A - The State of PC Gaming
ADO.NET better XML integration (it can read and write XML files easily), better support to work with Appendix B -has Motivations in Games disconnected data forGames? accessing remote data), better performance, and good integration with the Appendix C - How Do(ideal I Make .NET Framework, allowing you to navigate and Games retrieve data using arrays and collections, for example, Appendix D - Guidelines for Developing Successful thereby making the programs easier to write and maintain.
Index
List ofNote Figures If you don't understand or don't care about XML and disconnected data, all you need to know is List of Tables that ADO.NET is an evolution of the previous ADO library, and that it's faster and easier to use.
ADO.NET offers two basic ways to manipulate data from a data source: using a DataSet, which allows us to read, navigate, and update data in the database, or reading the data directly from the database using aDataReader. Choosing the object to access data is a matter of balancing flexibility against speed: DataSets are inmemory database representations that maintain synchronization with the database through a DataAdapter object and allow the program to update and navigate freely through the data read. With theDataReader object, the program can only read the data in a sequential way, but it is a lot faster. On any of these approaches, our program must use a Connection object to make a link with the database, and a Command object to perform a data-retrieving operation. Usually the operations of opening a connection and executing a command consume a lot of time, so we must plan carefully how many times we'll open the connection and issue new commands. Here is an explanation of the main ADO.NET objects: TheConnection object handles the connection to the data source and controls the database transactions. TheCommand object represents a command to be executed upon a data source and includes explicit functionality such as the ExecuteNonQuery method for commands that do not return arguments, and the ExecuteScalar method for queries that return a single value rather than an argument set.
TheDataSet and DataReader objects are in-memory representations of a data source. The former .NET Game Programming with DirectX 9.0 provides a dynamic connection to the database, helping you update the data as necessary, and also by methods Alexandreto Santos Lobão anddata Ellenas an XMLISBN:1590590511 provides some read relational hierarchy and transform it using XSL and Hatton XPath. The latter of these provides less functionality and fast read-only serial access to data, in a Apress © 2003 (696 pages) disconnected manner. The authors of this text show how easy it can be to produce
interesting multimedia games using Managed DirectX 9.0 and and the data source, hiding The last object, DataAdapter, provides a bridge between the DataSet programming with Visual Basic .NET on Everett, the latest any specific details about the source from the DataSet and handling updates on the data sent back version of Microsoft's Visual Studio. to the data source.
Visual help is filled with explanations and simple examples, so we won't include additional details Table of Studio Contents about ADO.NET; but wewith will DirectX instead9.0 provide the basic information to help us understand the data access .NET Game Programming code used in this chapter's sample game, Magic KindergarteN. Foreword Preface
Tip If you want to learn more about .Net, refer to William R.Vaughn's book, ADO.NET and ADO
Introduction Examples and Best Practices for Visual Basic Programmers , which is one of the best sources on Chapter 1the - .Nettrix: subject. GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites Since we need toDirectX read data ourBasics program follow Chapter 3 only - Managed First sequentially, Steps: Direct3D and will DirectX vs.three GDI+steps: Chapter 4 - River Pla.Net: Tiled Game Scrolling, DirectAudio 1. Create a Connection objectFields, and connect to and the data source. Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen
2. Create a Command objectAdventure to executeGames, a command-such asDirectShow Select * from ActiveObjects, or, Chapter 6 - Magic KindergarteN.: ADO.NET, and language, "read all information in the and Active Objects Chapter in 7 common - Magic KindergarteN. II: Animation Techniques Speech API table." Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay 3. Create a DataReader to retrieve the result of the command and write the data into our game D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to structures. Chapter internal 9 Nonmanaged Code Bonus Chapter Porting .Nettrixato Pocket PC The following listing shows complete sample of code for retrieving data from the Northwind.mdb Appendix A -the Thesample State ofdatabase PC Gaming database, that comes with Microsoft Access and Visual Studio, including the error Appendix - Motivations in Games trappingBcode: Appendix C - How Do I Make Games? Appendix D - Guidelines for as Developing Games Dim StrCategories stringSuccessful = "Categories: " Index Dim Conn As OleDbConnection List of Figures Dim Cmd As OleDbCommand List Dim of Tables DataReader As OleDbDataReader
Try ' Open the connection with the database ' (it must be in the application directory) Conn = New OleDbConnection(_ "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & _ Application.StartupPath & "\NorthWind.mdb") Conn.Open() ' Create and execute the command that will retrieve the data Cmd = Conn.CreateCommand() Cmd.CommandText = "SELECT CategoryName from Categories" ' Fill the DataReader with the command data DataReader = Cmd.ExecuteReader() ' Display all category names in a message box Do While DataReader.Read() If (DataReader.IsDBNull(0)) Then StrCategories = StrCategories & _ "-" & DataReader.GetString(0) End If Loop MessageBox.Show(strCategories, "NorthWind Categories") Catch e As Exception
MessageBox.Show("Unpredicted error when loading data: " & e.Message, _ Game Programming with DirectX 9.0 "Error",.NET MessageBoxButtons.OK, MessageBoxIcon.Error) ISBN:1590590511 by Alexandre Santos Lobão and Ellen Finally Hatton ' Close the DataReader and free the command Apress © 2003 (696 pages) DataReader.Close() The authors of this text show how easy it can be to produce Cmd.Dispose() interesting multimedia games using Managed DirectX 9.0 and Conn.Close() programming with Visual Basic .NET on Everett, the latest End Try version of Microsoft's Visual Studio. Table ofnext Contents In the section we'll explore DirectShow, the object library that provides access to streaming media. .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Introducing.NET DirectShow by Alexandre Santos Lobão and Ellen
ISBN:1590590511
DirectShow is theHatton set of components within the DirectX architecture that enables capture, editing, and playback Apress © 2003 (696 pages) of multimedia streams. The authors of this text show how easy it can be to produce
The full set of features of DirectShow very wide, in the first version of managed DirectShow—for use interesting multimediaisgames usingbut Managed DirectX 9.0 and programming with Visual Basic .NETto onbasic Everett, the latest inside the .NET Framework—we only have access playback capabilities for streaming media, which Microsoft's Visual Studio. can help us a lot version if all weofneed is to play sound files like MP3 and WAV and video files such as MPEG, ASF, and AVI. As with all other DirectX components, DirectShow will take advantage of any video or audio acceleration hardware to improve its performance. Table of Contents .NET Game Programming with DirectX Since we don't have access to many9.0 features of DirectShow with this first managed version, it'll suffice for us to Foreword have a simple class, with a New method, where we'll perform the initialization, a Play method to start playing Preface the streaming media, and a StopVideo method to stop playing any streaming media. Introduction
Note can't name method "Stop" because this is a reserved word for Visual Basic. Chapter 1 We - .Nettrix: GDI+ the andstop Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
To implement these basic methods we'll add a reference to the AudioVideo-Playback interface of DirectX. - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ This interface has only two objects, Video and Audio, which will enable the program to play a video or an Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio audio file. These objects are very simple, with a basic set of methods and properties that help the program to Chapter - River Pla.Net DirectInput and Writing Text to Screen perform5 streaming mediaII:playing operations and check state data. These objects don't support any events, Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and which would be useful to inform the application about the state ofDirectShow any playing operation. Chapter 3
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API In our constructor (the New weGames must receive the control used as a video window, according to the Chapter 8 - .Netterpillars II: method) Multiplayer and Directplay
parameters D-iNfEcT: expected Multithreading, by the Video object constructor. The Play method Nonrectangular Windows, and Access to must receive the name of the file to play; all other Nonmanaged methods will Code not require any parameters.
Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC
OurVideo class interface is described in the following piece of code:
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Imports Appendix C -Microsoft.DirectX.AudioVideoPlayback How Do I Make Games? PublicD Class clsVideo Appendix - Guidelines for Developing Successful Games Public VideoSize As Size Private VideoWindow As Windows.Forms.Control List of Figures Public IsPlaying as boolean Index
List of Tables
' The class methods Public Sub New(ByVal WndVideo as Windows.Forms.Control) Public Sub Play(ByVal strFileName As String) Public Sub StopVideo() Public Sub PauseVideo() End Class
After we implement this class, all we need to do to play a video is to create an object of this class, passing a reference to a window or form control, and then call the Play method for each file we wish to play. Let's now look at and comment on the code for each method, to uncover some details about the DirectShow AudioVideoPlayback library. The following code sample shows the constructor of our class: Public Sub New(ByVal WndVideo As Windows.Forms.Control) ' Stores the video window control and size for later use VideoWindow = WndVideo VideoSize = VideoWindow.Size End Sub
As we can see, all we do in this first method is store the parameters in class properties. All the playing file work
is done in the Play method, as we show in the subsequent code sample: .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Public Sub Play(ByVal strFileName As String) Hatton ' Store the path to Apress © 2003 (696the pages)file. strFileName = Application.StartupPath & "\" & VIDEOS_PATH & "\" & strFileName The authors of this text show how easy it can be to produce DxVideo =interesting Nothing multimedia games using Managed DirectX 9.0 and ' Set theprogramming control used with Visual as Basic a owner .NET on toEverett, play the thelatest videos Microsoft's Visual Studio. DxVideo =version New of Video(strFileName) DxVideo.Owner = VideoWindow Table of Contents
' Start playing DxVideo.Play()
.NET Game Programming with DirectX 9.0 Foreword Preface
' We must set the video window size again, because
Introduction ' playing a video resizes the windows to the video's Chapter'1 default - .Nettrix: GDI+ sizeand Collision Detection ChapterVideoWindow.Size 2 - .Netterpillars: Artificial Intelligence and Sprites = VideoSize Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ End Sub Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
TheStopVideo is also very simple; all weADO.NET, need to do is DirectShow call the Stop method of the Video object, as Chapter 6 - Magicmethod KindergarteN.: Adventure Games, and presented in the following code sample: Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Public Sub StopVideo() D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 ' If there's Nonmanaged noCode media running, there might be errors. -> We'll Bonus'Chapter Porting just .Nettrixignore to Pocketthem PC TryA - The State of PC Gaming Appendix Appendix B DxVideo.Stop() - Motivations in Games Catch Appendix C - How Do I Make Games? EndD Try Appendix - Guidelines for Developing Successful Games End Sub Index List of Figures List ofPauseVideo Tables The method follows the same structure as the previous code sample, using the Pause method
of the Video object. The last element of our class is the IsPlaying property. We can calculate it comparing the video's current position with its duration, as we do in the next code example: If they are equal, it means that the video is over. Public ReadOnly Property IsPlaying() As Boolean Get Try If DxVideo.CurrentPosition = DxVideo.Duration Then IsPlaying = False Else IsPlaying = True End If Catch ' Ignore error if DxVideo is not initialized End Try End Get End Property
Once this class is finished, we can play a video with three lines of code, as shown in the following code:
Public Video As clsVideo .NET Game Programming with DirectX 9.0 Video = New clsVideo(picVideo) by Alexandre Santos Lobão and Ellen Video.Play("MySampleVideo.AVI")
ISBN:1590590511
Hatton Apress © 2003 (696 pages)
The authors of this show how easy it can game be to produce In the next section, we'll discuss thetext proposal for the sample of this chapter and the next, including the interesting multimedia games using Managed DirectX 9.0 and concepts discussed in the previous sections. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Game Proposal by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton In this chapter, we'll create a very simple adventure game named Magic Kinder-garteN. Apress © 2003 (696 pages)
While our adventure simple, must still address some of the common problems encountered The is authors of itthis text show how easy it can be most to produce when coding a complex adventure: interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
Choosing verbs, version or actions, of Microsoft's with the Visual mouse Studio. pointer (right button changes the mouse pointer icon). We'll use the verbs Walk to, Use, Talk, Take, and Examine. Table of Contentsan inventory to show the objects carried by the player. Controlling .NET Game Programming with DirectX 9.0
Using objects from the inventory with other objects on screen. Foreword Preface
Controlling the dialog between the player's character and nonplayer characters.
Introduction
Chapter 1 - .Nettrix: GDI+ and within Collision Controlling the navigation theDetection game (walking from one screen to another). Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites
Initially,3our- Managed adventureDirectX will beFirst much like aDirect3D book, because we'll use only static images as we build the game Chapter Steps: Basics and DirectX vs. GDI+ in this chapter. In the next chapter, we'll discuss basic animation and incorporate simple animation into our - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio game.
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 -dialogs, Magic KindergarteN.: Adventure Games, and DirectShow As for the we'll implement them only in theADO.NET, next chapter, when presenting the basics about the Chapter - Magic KindergarteN. II: Animation Techniques and Speech API Speech7 API. Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
The game storyline our game willNonrectangular be as follows: Windows, and Access to D-iNfEcT:for Multithreading, Chapter 9 Nonmanaged Code The main character in our game will be a little boy, a magician's son, who is studying basic tricks in a Bonusmagic Chapter Porting .Nettrix to Pocket PC his name) arrives one day at school and finds no one there, just kindergarten. Natanael (that's Appendix A The State of PC Gaming a big television that can play some movies and a magic book. Looking around, he finds a mud Appendix B - Motivations Games monster. It turns outinto be Natanael's teacher, Fiona. Fiona was trying some metamorphosis tricks Appendix C How Do I Make Games? when she lost her magic wand. She asks Natanael to find it for her. Appendix D - Guidelines for Developing Successful Games Index Natanael looks around and can't find the wand, but he does find a magic mushroom, which is able to
make him small.When he turns small, he manages to enter a mouse hole inside the school, where he can find the wand, and then help his teacher to get back to her normal form.
List of Figures List of Tables
Based on this storyline, we'll now create the screens, dialogs, active objects, and tables that describe the results of each action over each object.
.NET Game Programming with DirectX 9.0 The Game Project by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Our project will be divided into three main sections: defining the game screens and the flow between these © 2003 (696 pages) screens; definingApress what characters will be present, and what will be the result of each action on each character; and defining the results these actions on all other objects in our game. Besides these The authors of thisof text show how easy it can beactive to produce interesting multimedia games Managed 9.0described and sections, which will help us to define how we'llusing implement theDirectX storyline in the game proposal, programming with Visual Basic .NETto ondefine Everett, latest we'll include in our project some technical sections thethe game interface elements, the class version of Microsoft's Visual Studio. diagram, and the database that will store the game data.
After we write all the sections in the game project, we'll have enough detail to start coding our game. Since it's very important that the whole team shares the same vision of what the game will be, it's good practice .NET Game Programming with DirectX 9.0 to include as many visual feedback elements in the project phase as possible. This is usually done by Foreword including early drafts of screens, characters, and objects, but in our case we'll show the final drawings, Preface since they've already been done. All the drawings for this game (except for the table and the TV used to Introduction test DirectShow) were made by Waldivar Cesar (http://wace.cosmo.com.br), a Brazilian graphical Chapter artist. 1 - .Nettrix: GDI+ and Collision Detection
Table of Contents
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites As for the we'll create a class diagram depicting the vs. classes Chapter 3 -technical Managedside, DirectX First Steps: Direct3D Basics and DirectX GDI+we'll use in the coding phase,
including classes we created in the previous chapters, and highlighting the new classes to be created. Chapter 4 the - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Creating Game Screens
Chapter 6 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API We'll use storyline described in the Games sectionand "The Game Proposal" to determine the screens needed for Chapter 8 the - .Netterpillars II: Multiplayer Directplay
our game. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to -
Chapter 9
Nonmanaged Code We must imagine the.Nettrix story as comicPC book, with as few scenes as possible, to define our screens. This Bonus Chapter Porting toaPocket
technique is also used when defining the cut-scenes in many games, and is usually called storyboarding.
Appendix A - The State of PC Gaming
Appendix B -our Motivations Games Let's read little storyinagain and start creating the game screens and composing the presentation text Appendix C How Do I Make used in each screen, whichGames? will be displayed every time the player enters each screen. Appendix D - Guidelines for Developing Successful Games
The main character in our game will be a little boy, a magician's son, who is studying basic tricks in a magic kindergarten. Natanael (that's his name) arrives one day at school and finds no one there, just List of Figures a big television that can play some movies and a magic book. Index
List of Tables
The first sentence describes the player's character, while the second one describes the first location: a school.Figure 6-6 shows the first game screen.
Figure 6-6: The magic kindergarten school To adapt the story to presentation text, we must use shorter sentences, since the player will be reading them on screen. And since we won't implement dialogs with the game characters in this first version, we'll substitute the dialog with fixed sentences on each screen. One possible approach to the text of this screen is as follows: Natanael arrives on his first day at magic kindergarten, but he doesn't find anyone waiting for him
there.
.NET Game Programming with DirectX 9.0
Alexandre "Where's myby teacher?" heSantos thinks.Lobão and Ellen
ISBN:1590590511
Hatton Looking back at the Apress first©sentence, 2003 (696 pages) we can see that, in fact, it describes two locations: one depicting an
outside view of the school (heofarrives ...),show and how another the inside of it (... there).Figure 6-7 The authors this text easyrepresenting it can be to produce shows the inside interesting view of themultimedia school. games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5 - 6-7: RiverThe Pla.Net II: DirectInput and Writing Text to Screen Figure magic kindergarten schoolroom Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
We include a table inside the school because we need to use DirectShow somewhere in this game, so - .Netterpillars II: Multiplayer Games and Directplay we'll create a TV on the table that can play some movies for us. There must be a mouse hole somewhere, D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter too (an9active object, to be added later), as we read in the story. The presentation text will be as follows: Nonmanaged Code Chapter 8
thePorting kindergarten there's BonusInside Chapter .Nettrixschool, to Pocket PC a huge table with a TV on it. There's a mouse hole in the wall. Appendix A - The State of PC Gaming
Of course, the player will have already seen the TV and the mouse hole on screen, but including these items in the text will give hints to the player about which visual cues are the important objects on screen.
Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Games Getting back to our story, let's see theSuccessful next sentences: Index
Looking around, he finds a mud monster. It turns out to be Natanael's teacher, Fiona. Fiona was trying some metamorphosis tricks when she lost her magic rod. She asks Natanael to find it for her.
List of Figures List of Tables
In the previous text, we can see a description of a second game character, a nonplayer character called Fiona. Write this down on a piece of paper; we'll be detailing the game characters in the next section. Following the idea of thinking about the story as a comic book, we see that we can't place the Fiona character in any of the first screens designed for the game, because the first part of the story states that the player didn't find anyone at the school (outside and inside). We'll need a third screen, some location in which to put our nonplayer character. This can be a forest clearing near the school, as shown in Figure 68.
Figure 6-8: A clearing in the forest
The presentation text for this screen will be as follows:
.NET Game Programming with DirectX 9.0
Entering the by forest, Natanael meets a mud monster. Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Natanael, please help me! Says the monster. Apress © 2003 (696 pages) Theteacher! authors Iof thispracticing text show my how easy it can be to produce I'm Fiona, your was mutation magic when I lost my magic wand. Can you find it for me? interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Continuing with our story, we have this text:
Natanael looks around and can't find the wand, but he does find a magic mushroom that is able to Table of Contents make him small. .NET Game Programming with DirectX 9.0
We could simply include a mushroom (it will be one of the game's active objects) on the same screen as Foreword Fiona's character, but that would be too easy. It's not our goal here to create a great adventure, with many Preface clever puzzles, but let's at least add an extra screen so the player will need to do some more walking Introduction
before finding the mushroom. The next screen, illustrating another part of the forest, is depicted in Figure - .Nettrix: GDI+ and Collision Detection 6-9.
Chapter 1 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Figure Another the forest—the mushroom Appendix D - 6-9: Guidelines for part Developing Successful Games clearing Index
This screen will have the following presentation text:
List of Figures
Natanael finds another clearing in the forest, with an old tree and an owl. In the middle of the clearing, there's a strange mushroom.
List of Tables
The last sentence of our story suggests still another screen, as we can see in the following text: When he gets small, he manages to enter a mouse hole inside the school, where he can find the wand, and then help his teacher to get back to her normal form. The wand is found inside the mouse hole, so we'll need an inside view of the mouse hole. We must remember later to include an active object representing the mouse hole inside the school. Figure 6-10 shows the last of our game screens.
Figure 6-10: Inside the mouse hole
.NET Game Programming with DirectX 9.0
We can describe this screen as follows:
by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Natanael finds the magic wand. It's inside the mouse hole. Hopefully, there are no mice here right Hatton now, so all he needs© 2003 to do(696 is take Apress pages)the wand and give it to Fiona. The authors of this text show how easy it can be to produce
In Figure 6-11 weinteresting show the flow between the screens, and give a number to each one to help us identify multimedia games using Managed DirectX 9.0 and them later on in the project. with Visual Basic .NET on Everett, the latest programming version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
BonusFigure Chapter Porting Pocket PC screens 6-11: The.Nettrix game to flow between Appendix A - The State of PC Gaming Appendix B - Motivations in Games
In the diagram Figure 6-11, we can see the screens ordered as the game flows; for example, Appendix C - Howpresented Do I MakeinGames? when the player walks to the right from Screen2, he or she will go to Screen3. The story begins when Natanael arrives at the school, so our game will begin on Screen2. From this screen, this character can Index walk into the school (Screen1) or away to the forest (Screen3). Appendix D - Guidelines for Developing Successful Games List of Figures
List of Tables In the next section we'll see the details of the game characters.
Drawing Game Characters As we saw in the previous sections, our game will consist of two main characters: the player, Natanael, and his teacher, Fiona. Before drawing anything, we must create a profile for each character so our team of artists can understand exactly what we want. So let's look at a short briefing of each character and then see the artistic result: Natanael: He's a young boy, about five years old. Although his parents are magicians, he is a regular boy, and dresses like one. (No hats here!) He lives in a house near school, in a forest, and walks to kindergarten everyday, where he is learning the first magical tricks a magician must learn. Figure 6-12 shows the graphical artist's view of our character.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX Figure 6-12: Natanael, the 9.0 player's character Foreword Preface
Fiona: Fiona is Natanael's teacher at the magic kindergarten. She is an old woman, and dresses like a fairy, but for most of our game flow she is a monster composed only of mud (no clothes). She is a Chapter 1 - .Nettrix: GDI+ and Collision Detection very kind person, and this must be clear from looking at her, and she also gets a little confused from Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites time to time (as we can guess based on her losing her magic wand). Figure 6-13 shows Fiona's Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ character as a mud monster, and Figure 6-14 shows her in her human form. Introduction
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 6-13: Fiona, the player's teacher, as a mud monster
Figure 6-14: Fiona back to human form
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton A question that arises for many developers when starting to code games is, Why must we describe Apress © 2003 pages) character profiles? What's the(696 point, after all, in saying that a character is a "very kind person," or that he "gets a little confused"? The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming Visual on Everett, thethe latest Although such profiles may notwith appear toBasic have .NET a direct impact on game, they are very important, even version of Microsoft's Visual Studio. for fast-paced action games, because they allow the team to understand the images we are trying to put across to the player. These profiles help the artist to understand what we want, and create more realistic or more cartoonlike characters; and they also help the coders to think about new jokes, puzzles, or action Table of Contents sequences that fit the character's personality. .NET Game Programming with DirectX 9.0
Foreword In a real game, at this point the team must start thinking about extra characters that will add some color to Preface the scenery, making the game more interesting. Since our objective is to keep the game very simple, we Introduction won't add other characters, but we'll suggest some in the "Adding the Final Touches" section, so you can Chapter 1 - new .Nettrix: GDI+ and Collision Detection think about game sequences. Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites To finish characters' descriptions, weDirect3D must define result of each action over each of the Chapter 3 our - Managed DirectX First Steps: Basicsthe and DirectX vs. GDI+
characters. Regarding the player's character, Natanael, in our game, he will not be an active object. This - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio means that we can't try to take him, or examine him, or execute any other action on him. As for Fiona, the Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen following tables present the result of each verb the player issues over her, starting with Fiona as a Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow monster, presented in Table 6-1. Chapter 4
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Table 6-1: Result of Each Action on Fiona as Mud Monster
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
ACTION Nonmanaged EXECUTE?CodeDISPLAY TEXT
Bonus Chapter Porting .Nettrix to Pocket PC
Examine Yes Ech! It's a mud monster! Appendix A - The State of PC Gaming Appendix in Games Take B - Motivations No I don't want to put my hands on this dirty thing! Appendix C - How Do I Make Games?
Walk to
No
I'd rather not. I would get stuck in the mud.
No
I can't use a monster!
Appendix D - Guidelines for Developing Successful Games Index Use List of Figures
List of Tables Table 6-2 shows the results of the same actions when performed over Fiona's character when
transformed back to human. Table 6-2: Result of Each Action on Fiona in Human Form ACTION
EXECUTE?
DISPLAY TEXT
Examine
Yes
My teacher is cured!
Take
No
I can't take her.
Walk to
No
I can't walk to her. I'm already here.
Use
No
I can't use my teacher.
In the next section, we'll discuss these same actions for each of the active objects in the game.
Active Objects Anactive object is any element on screen that the player can act upon—for example, the television in the kindergarten and the magic mushroom. In this class we'll have some extra elements: invisible objects that will mark the transition from one screen to another, so the player can "walk" to the next screen. Reading the storyline for our game again and looking at the screen definitions, we can create a list of the basic active objects, including the screen transitions (see Table 6-3). In a real adventure, such a list can
take dozens of pages, and gets updated as the game project evolves and new ideas arise. .NET Game Programming with DirectX 9.0
by Alexandre Santos Lobão and Ellen Table 6-3: The Active Objects List, with Verbs Results Hatton Apress © 2003 (696 ACTION pages) OBJECT
SCREEN
ISBN:1590590511
EXECUTE?
DISPLAY TEXT
The authors of this text show how easy it can be to produce Magic book multimedia Examine It's9.0 myand teacher's magic book. interesting games usingYes Managed DirectX programming with Visual Basic .NET on Everett, the latest TakeVisual Studio.No I'd rather not. I don't want to be version of Microsoft's
1
transformed into a frog. Table of Contents
Walk to
No
Walk into a book? I'm still in the kindergarten!
Use
No
No, thanks. I could mess things up.
Examine
Yes
Wow, it's a huge TV! How can I turn it on?
.NET Game Programming with DirectX 9.0 Foreword Preface Introduction
Television
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Take Steps: Direct3D Basics No and DirectXThe vs. TV GDI+ is too heavy to carry.
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
Yes and Speech What - Magic KindergarteN. II:Use Animation Techniques API happens if I press these
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Walk to
No
I still haven't learned the magic for walking into a TV, yet. buttons?
D-iNfEcT: NonrectangularYes Windows, and Access to leads to outside the Door Multithreading, Examine This door Nonmanaged Code
school.
Bonus Chapter Porting .Nettrix to Pocket PC
Take Appendix A - The State of PC Gaming
No
I can't take it. It's bolted to the wall.
Walk to
Yes
OK, I'll go outside.
Index
Use
No
It's already unlocked.
List of Figures Mouse hole List of Tables
Examine
Yes
I can see the magic wand in there, but I can't take it!
Take
No
I can't take a hole!
Walk to (when big)
No
I'm too big to fit in there!
Walk to (when small)
Yes
Now I can go in there!
Use
No
I can't use a hole!
Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games
2
Door Examine with DirectX Yes .NET Game Programming 9.0 by Alexandre Santos Lobão and Ellen Take No Hatton Apress © 2003 (696Walk pages) to Yes
It's my school's entrance door. ISBN:1590590511
Are you kidding? Take a door? OK, let's go in!
The authors of this text show how easy it can be to produce Use games usingNo There's nothing to do here. It's interesting multimedia Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, theunlocked. latest version of Microsoft's Visual Studio.
Path to forest Table of Contents
Éxamine
Yes
If I walk this way, I'll reach the forest.
Take
No
I can't take a path!
Walk to
Yes
Let's go to the forest!
Use
No
I can't use a path!
Yes
If I walk this way, I'll go back to my school.
.NET Game Programming with DirectX 9.0 Foreword Preface Introduction
3 Chapter 1
Exit to school Examine - .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio it!
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
Walk to Games, Yes It's time to get back to school. - Magic KindergarteN.: Adventure ADO.NET, and DirectShow
Chapter 7 Chapter 8
- Magic KindergarteN. II:Use Animation Techniques API use a path, I must walk on No and Speech I can't - .Netterpillars II: Multiplayer Games and Directplay it!
Chapter 9
-
Take
No
I can't take a path, I must walk on
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Exit to forest Examine Yes That's the path to the deep Nonmanaged Code
forest.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Take
No
I can't take this.
Yes
Appendix D - Guidelines for Developing Successful Games
OK, it's far from school, but I'll go there!
Index
Appendix B - Motivations in Games
Walk to Appendix C - How Do I Make Games?
List of Figures
4
List of Tables
Exit to monster clearing
Mushroom
Use
No
I can't use this.
Examine
Yes
I must walk this way to get back to the forest.
Take
No
I can't take a path!
Walk to
Yes
Let's get back to the forest!
Use
No
I can't use a path!
Examine
Yes
It's a big and weird mushroom.
Take
No
It's stuck to the forest ground.
Walk to
No
I can't walk to it
Use
Yes
I ate a piece of it ... Oh, my, I feel SO strange ...
5
Magic wand Examine with DirectX Yes .NET Game Programming 9.0 by Alexandre Santos Lobão and Ellen Take Yes Hatton Apress © 2003 (696 pages)
It's my teacher's magic wand! ISBN:1590590511
I'll take it and give it to my teacher!
Walk No it can be toI produce can't walk over a magic wand! The authors of this texttoshow how easy interesting multimedia games using Managed DirectX 9.0 and Use must use it ON something. programming with Visual Basic .NETNo on Everett, theI latest version of Microsoft's Visual Studio. Table of Contents
Use (with teacher)
Yes
Wow! I managed to transform the monster back to my teacher!
Use (with any other)
No
I can't use the magic wand on THIS!
Examine
Yes
I must walk this way to get out of here.
No
I can't take a hole!
.NET Game Programming with DirectX 9.0 Foreword
Mouse hole
Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
Yes and DirectXOK, time to get out of here. - Managed DirectX First Walk Steps:toDirect3D Basics vs. it's GDI+
Chapter 4
- River Pla.Net: Tiled Game UseFields, Scrolling, Noand DirectAudio I can't use a hole! - River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 5
Take
Chapter 6 -summarizes Magic KindergarteN.: Adventure DirectShow Table 6-3 everything we need Games, to knowADO.NET, about theand game active objects, and with it we have Chapter - Magic information KindergarteN. Animation Techniques and Speech API enough7 planning to II: start our game. But on the technical side, before coding we'd better define Chapter - .Netterpillars II: Multiplayer Gamesare andthe Directplay a draft 8of the user interface elements. These game classes, including some previously created D-iNfEcT: Multithreading, Nonrectangular Windows, and details, Access to classes we'll use and new ones we must create, as well as other like defining the entityChapter 9 Code relationship Nonmanaged data model for our project so we can have better control over the development phase. Bonus Chapter Porting .Nettrix to Pocket PC
The userA interface elements are described in the next section. Appendix - The State of PC Gaming Appendix B - Motivations in Games
User Interface Elements Draft
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games
Before writing the game classes, it's always good practice to draw some sketches of the user interface Index elements. This usually serves as a guide to the game classes' creation. List of Figures List of Tables
Figure 6-15 shows a first draft of the game user interface elements.
Figure 6-15: Game user interface elements, first draft As shown in Figure 6-15, our user interface will be very simple: Almost all of the screen will show the current screen image. We'll have a status text line and an area reserved for displaying the current screen text (sufficient to display 4 lines of about 60 characters each). A character's head will represent the current
character in a dialog (used only in the next version of the game, in the next chapter), and our inventory is .NET Game Programming with DirectX 9.0 represented by the image of two hands, upon which the objects currently carried will be shown. by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Another interfaceHatton element, not expressed in Figure 6-15, is the mouse pointer. In our game, we'll have four Apress 2003 (696 pages) action verbs (walk, take,©examine, and use), which will be active according to the current mouse pointer. The pointers, authors ofincluding this text one showextra how pointer easy it can to produce The possible mouse for abe"wait" state, are displayed in Figure 6-16. interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0
Figure 6-16: Mouse pointer icons for each action Foreword Preface
The mouse pointers must cycle when the user presses the right button on the mouse.
Introduction
Chapter 1 -section .Nettrix:we GDI+ and the Collision Detection In the next discuss suggested class diagram for our game. Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Creating the Class Diagram - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4
Chapter 5 - River II:base DirectInput Textengine, to Screen In our project we'llPla.Net use the classesand forWriting the game sprite, and mouse control, and then create Chapter - Magic KindergarteN.: Games,needs. ADO.NET, DirectShow derived6classes according to ourAdventure game's specific We'lland also create a new class to control Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API DirectShow streaming media playing features. Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Using the experience we gained in the last chapter, Windows, we can devise three new D-iNfEcT: Multithreading, Nonrectangular and Access to classes: a game control Chapter 9 class, derived from clsGameEngine, that will be called clsKinderEngine; an active objects control Nonmanaged Code class,Chapter derivedPorting from clsSprite, named Bonus .Nettrix to Pocket PC clsActiveObject; and a player character control class, derived from clsSprite too, named clsAdvPlayer. Analogous classes exist in our River Pla.Net Appendix A - The State of PC Gaming sample,Bso- we just transpose the idea to our current game. Appendix Motivations in Games Appendix C - How Do I Make Games?
Two other classes will be specific to the current game. Since we'll have a non-continuous game field, we'd better create a class to implement any details at screen level (clsScreen); and, as discussed before, we Index want the game's mouse pointer to have custom images that can be replaced according to the action to be List of FiguresSo we'll create a class named clsAdvPointer to handle this. performed. Appendix D - Guidelines for Developing Successful Games
List of Tables
The next sections describe the main properties and methods for each of the game classes, starting with the game engine class. In real game projects, these first drafts of the properties and methods are the result of a brainstorming session between the game team members, and other interface elements may be included in the classes as the project evolves; but here we will just present the results of such efforts.
The Game Engine Class The game engine class (clsKinderEngine) interface is presented in Table 6-4. We present here a brief explanation of the class members; we'll look at them in more detail in the section "The Coding Phase." Table 6-4: The Game Engine Class
TYPE
NAME DESCRIPTION .NET Game Programming with DirectX 9.0
Property
TalkingHead Hatton
Property
Apress © 2003 (696 pages)Represents the left hand (first inventory slot) LeftHand
Property
LeftHandObject object DirectX carried by interesting multimediaRepresents games usingthe Managed 9.0the andleft hand
Property
RightHand Represents version of Microsoft's Visual Studio.the right hand (second inventory slot)
Property
RightHandObject
by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Indictates the current character head, to be shown on screen
The authors of this text show how easy it can be to produce programming with Visual Basic .NET on Everett, the latest
Table of Contents TextBackground
Property
Represents the object carried by the right hand Specifies the text background to be displayed on screen
.NET Game Programming with DirectX 9.0
Property Foreword
Text
Indicates the current screen text (array with four elements)
Preface Property
StatusText
Indicates the status text
Introduction
CurrentScreen Property Chapter 1 - .Nettrix: GDI+ and CollisionSpecifies Detectionthe current screen object Chapter 2 - .Netterpillars: and Pointer Artificial Intelligence Property Indicates theSprites mouse pointer Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Player Property Represents theand player's character Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, DirectAudio Chapter 5 - River Pla.Net II: DirectInputRepresents and Writingthe Text to Screen Video Video class object to play videos on the TV Property Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Mouse Property - Magic Indicates the DirectInput class that controls the mouse KindergarteN. II: Animation Techniques and Speech API Chapter 8 - .Netterpillars II: MultiplayerInitializes Games and Initialize Method allDirectplay objects and properties Chapter 7
Chapter 9 Method
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to TestCollision Checks for collision to update the status text Nonmanaged Code
Bonus Chapter Porting PC Render.Nettrix to Pocket Draws Method the screen Appendix A - The State of PC Gaming
MouseDown MethodB - Motivations Appendix in Games Appendix C - How Do I Make Games?
Changes the mouse pointer, executes the action (Do ...) methods
Appendix for Developing Successful MouseMove Moves theGames mouse pointer and calls the TestCollision MethodD - Guidelines Index method List of Figures
Method
DoExamine
Executes the Examine action on an object
Method
DoTake
Executes the Take action on an object
Method
DoWalk
Executes the Walk to action on an object
Method
DoUseAlone
Executes the Use action on an object
Method
DoUseWith
Uses one object in the inventory with another object on screen
Method
PlayTVChannel
Calls DirectShow playing features
List of Tables
Although we are usually tempted to not include much detail in our project, the game engine class includes a lot of properties and methods. By spending some extra time thinking about which details we'll need in our code to implement all features planned, we'll save ourselves a lot of effort later, and ultimately we'll have a better game made in less time. Take a little time to carefully read each of the properties and methods in the preceding table, in order to guarantee that you understand what we'll do in our sample.
The Active Object Class Table 6-5 shows the description of the methods and properties for the active object (clsActiveObject) class, which is more straightforward than the clsKinderEngine class. It includes only the properties directly associated with the actions that can be executed over the object.
Table 6-5: The Active Object Class
.NET Game Programming with DirectX 9.0
TYPE
NAME DESCRIPTION by Alexandre Santos Lobão and Ellen
Property
Hatton Name Apress © 2003 (696 pages) Represents the name of the active object
Property
The authors of this textSpecifies show howifeasy it can be produce CanTake the player cantotake the object
Property
programming with Visual Basic .NET on player Everett, thewalk latest CanWalk Specifies if the can to the object
Property
CanUseWithOther
ISBN:1590590511
interesting multimedia games using Managed DirectX 9.0 and version of Microsoft's Visual Studio.
CanUseAlone Property Table of Contents
Specifies if the player can use the object with another object Specifies if the player can use the object (alone)
.NET Game Programming with DirectX 9.0 Indicates the text to be displayed when executing the ExamineText Property Foreword Examine action Preface
Property Introduction
Indicates the text to be displayed when executing the Take action Chapter 1 - .Nettrix: GDI+ and Collision Detection Chapter 2 - .Netterpillars: andthe Sprites WalkText Artificial Intelligence Property Indicates text to be displayed when executing the Walk Chapter 3 - Managed DirectX First Steps:to Direct3D action Basics and DirectX vs. GDI+ TakeText
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Property
UseWithOtherText
Chapter 6
Indicates the text to be displayed when using the object with another object
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow UseAloneText Property Indicates the text and to be displayed Chapter 7 - Magic KindergarteN. II: Animation Techniques Speech API when executing the Use Chapter 8
action and Directplay - .Netterpillars II: Multiplayer Games
Chapter Method 9 -
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to New Does the class initialization, loading the object data from a Nonmanaged Code
database
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Appendix B game's - Motivations Games are derived from our basic Sprite class, defined in Chapter 4, all the Since the activeinobjects Appendix C How Do I Make properties and methods of Games? the base class will be present, too: Width,Height,Draw, etc. Appendix D - Guidelines for Developing Successful Games
The Index
AdvPlayer Class
List of Figures
The next class to be described is the class that will control the adventure player, clsAdvPlayer. This class will be very simple. Besides the elements of the base class, we'll only need an extra property to determine if the player is in a normal state or reduced, and a new Draw method that will draw the player accordingly.
List of Tables
The screen control class will also be very simple, and it'll be named clsScreen. Since it will be derived from the clsSprite class, all we need to do is to create an array to hold all the screen's active objects, and specific New and Draw methods that will load the active objects when the screen is created and draw the active objects on the screen. The last of our game classes, as mention before, will be the game pointer class, clsAdvPointer, which will store each of the possible action icons and the associated text for the verbs. Table 6-6 shows the first draft for the properties and methods of this class. Table 6-6: The Adventure Pointer Class
TYPE
NAME DESCRIPTION .NET Game Programming with DirectX 9.0
Property
Status Hatton
Property
Apress © 2003 (696Specifies pages) WalkIcon the image to draw for the Walk to action
Property
ExamineIcon Specifies the using imageManaged to draw DirectX for the Examine interesting multimedia games 9.0 and action
Property
TakeIcon Specifies theStudio. image to draw for the Take action version of Microsoft's Visual
Property
UseIcon
by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Indicates the current action verb/pointer status
The authors of this text show how easy it can be to produce programming with Visual Basic .NET on Everett, the latest
Table of Contents WaitIcon
Property
Specifies the image to draw for the Use action Specifies the image to draw when in wait state
.NET Game Programming with DirectX 9.0
Property Foreword
Object1Icon
Specifies the image to draw when carrying one object in the left hand
Object2Icon
Specifies the image to draw when carrying one object in the right
Preface Introduction Property Chapter 1
- .Nettrix: GDI+ and Collision hand Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
WalkText Property - Managed Indicates the Walk to action text DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4 - River Pla.Net: Tiled Game Fields,the Scrolling, and DirectAudio ExamineText Property Indicates Examine action text Chapter 3 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Property
TakeText
Indicates the Take action text
Chapter 7 - Magic UseText KindergarteN. II: Animation Property Indicates theTechniques Use actionand textSpeech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Method Method
Draw
Draws the pointer according to the current status
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code Cycles the pointer status NextStatus
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
We suggested the creation of properties to hold the action text to make a possible translation easier: All Appendix B - Motivations in Games user interface strings will beGames? located in tables in a Microsoft Access database that will be read when Appendix C - How Do I Make loading each object. for Developing Successful Games Appendix D - Guidelines Index
Figure 6-17 shows the final class diagrams, depicting the classes described in this section plus the base classes we'll use.
List of Figures List of Tables
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Figure 6-17: Nonmanaged Magic KindergarteN. Code class diagram
Bonus Chapter Porting .Nettrix to Pocket PC
In the next we'll the data model for our game, according to the properties of the game Appendix A -section The State of define PC Gaming classes.
Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Creating the Game's Data Model
Appendix D - Guidelines for Developing Successful Games Index
We'll create a simple Microsoft Access database to store all the game data. Microsoft Access has the advantage of being very easy to use and also being portable—you can simply copy the .mdb file from one List of Tables place to another to move your data. List of Figures
Since we are planning to put all the game strings in this data file, we must create a new table to hold the game pointer verbs (with just one record with the verbs used for the current language), and tables for screen text, screen number, and active objects data. The Screen table is the one that glues everything together, as we can see from Figure 6-18.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Figure KindergarteN. dataGames, model ADO.NET, and DirectShow Chapter 6 - 6-18: Magic Magic KindergarteN.: Adventure Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
.Netterpillars II: Multiplayer Games and Directplay The Active- Object table in Figure 6-18 holds all the class properties, as described in the previous section, D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to plus some Chapter 9 -extra information we'll explain in the next sections. For example, we create some extra Nonmanaged Code properties to control the use of one object with another, and create pairs of texts for each verb: the text to Bonus Chapter Porting .Nettrix to Pocket PC display when you can't execute the verb, and the text to display when you can. Appendix A - The State of PC Gaming
Appendix B -section Motivations Gamesthe game's main program flow, finalizing the game project phase. In the next we'llindiscuss Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
Planning the Main Program Flow
Index
List of main Figures The program for our game will be analogous to the main program we saw in the previous chapter, List although of Tables the games are completely different. The pseudocode for it will be very simple, as shown in the
following sample: Create a window to be the game screen Create an object from KinderEngine class Create the splash screen Show the splash screen Initialize KinderEngine object Show the game window Close the splash screen Run the game (execute method RUN from KinderEngine object) ' The Run is a syncronous method, it will return when the game ends Destroy the KinderEngine object Dispose the game window
Comparing this sample code with the sample code from Chapter 4, you'll notice that there are very few differences between them; in fact, we can say that almost all games will follow this basic structure. In the next section we'll show the main parts of our adventure game.
Game Programming with DirectX 9.0 The Coding.NET Phase by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton like this involves hundreds of lines of code, and we can get lost in the tiny details if we Even a simple adventure 2003 (696 pages)we'll take a look at the game's main routines, to understand what is being try to look at all ofApress them ©here. Instead, done, and we'll leave some details To see complete code, refer to the accompanying CDThe authors of this aside. text show howthe easy it can besample to produce interesting multimedia games using Managed DirectX 9.0 and ROM.
programming with Visual Basic .NET on Everett, the latest versionphase of Microsoft's Visualsteps, Studio. We'll divide our coding into discrete so we can focus on specific features to understand every main
aspect of the game, and easily reuse the techniques shown in other games: draft: Code the screen and active objects data loading. Table1.of First Contents .NET Game Programming with DirectX 9.0
2. Second draft: Code the mouse pointer cycling (action verbs) and status text updating.
Foreword
Preface 3. Third draft: Code the mouse pointer actions. Introduction
4. Final version:GDI+ Codeand the Collision player and the inventory. Chapter 1 - .Nettrix: Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Our main purpose in dividing the program into well-controlled steps is to establish milestones, where we can - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ check the game coding process and the overall code quality. This is a very common approach, and this quality Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio practice can be reinforced by creating day builds of the program and following the paradigm, "You must always Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen have an executable version." Chapter 3
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter In the next 7 -section Magic KindergarteN. we'll use ADO.NET II: Animation to loadTechniques data for the and screens Speechand API objects. Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Windows, and Access to First Draft: Loading the Nonrectangular Game Data Nonmanaged Code
Chapter 9
Bonus Chapter Portingin.Nettrix Pocket Our main objective this firsttostep is toPCload information from the game database and transform it into the game Appendix A The State of PC Gaming objects—screens and active objects. After loading the data, we'll code the basic game routines to display the Appendix B -screen. Motivations in Games objects on Appendix C - How Do I Make Games?
Let's start the Initialize of the KinderEngine class, so we'll have a better idea about how Appendix D -coding Guidelines for Developingmethod Successful Games theNew method of the Screen class must work to get things running.
Index
List of Figures Since we want to load all the data for the screens at startup, a possible pseudo-code for the Initialize List of Tables method is shown in the next listing:
From Screen1 to Screen5 Create the screen object Load the screen data Load the Active Objects for the screen Create the font objects that will display the screen text for the current screen Set the current screen to Screen2 ' as planned in the game flow diagram
The font objects mentioned in the previous code listing are the same objects we created in the preceding chapter to display text on screen. The next listing shows the code for the Initialize method of the KinderEngine class. One important point to remember is that this class is derived from clsGameEngine, the generic game engine class created earlier in this book. We'll need to call the base class Initialize method in order to properly initialize the Direct3D components. Two other important functions we must code are the Render method, which will actually put the drawings of our game on screen and is called by the loop inside the Run method of clsGameEngine class, and theFinalize method, if we want to add any specific finalization code. Public Shared Text() As ClsGameFont Private Shared Screen() As ClsScreen Private Shared CurrentScreen As ClsScreen
... .NET Game Programming with DirectXAs 9.0Windows.Forms.Control) As Boolean Public Shadows Function Initialize(owner ISBN:1590590511 by Alexandre Santos Lobão and Ellen Dim WinHandle As IntPtr = owner.Handle Hatton Dim i As Integer Apress © 2003 (696 pages) ReDim Text(3) The authors of this text show how easy it can be to produce ReDim Screen(5) interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Initialize = True version of Microsoft's Visual Studio.
' Start Direct3D, with a full screen 800x600 resolution If Not MyBase.Initialize(WinHandle, True, 800, 600) Then Table of Contents Initialize = False .NET Game Programming with DirectX 9.0 Exit Function Foreword End If Preface Introduction ' Load the screens
= 0 To 4 and Collision Detection ChapterFor 1 -i.Nettrix: GDI+ Chapter 2
New ClsScreen() -Screen(i) .Netterpillars: =Artificial Intelligence and Sprites
Chapter 3
Not Screen(i).LoadData(i + 1,and 0)DirectX Then vs. GDI+ -If Managed DirectX First Steps: Direct3D Basics
Chapter 4
= False - RiverInitialize Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- RiverExit Pla.NetFunction II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
End If
Next
' Initialize the game text fields D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterFor 9 -i = 0 To 3 Nonmanaged Code Text(i) = New ClsGameFont("Microsoft Sans Serif", 14, Space(120), _ Bonus Chapter Porting .Nettrix to Pocket PC New POINT(236, 525 + i * 18)) Appendix A - The State of PC Gaming Next Appendix B - Motivations in Games ' Set the startup screen Appendix C - How Do I Make Games? CurrentScreen = Screen(1) Appendix - Guidelines Developing Successful ' D Update thefor text strings with Games the current screen text Index UpdateScreenText() List of Figures End Function List of Tables
Shared Sub UpdateScreenText() Dim i As Integer For i = 0 To 3 Text(i).Text = CurrentScreen.Text(i) Next End Sub
As we can see in this code listing, it would appear to be better to create a separate method, LoadData, to load each screen data (based on the screen number), so we can retrieve easily any error and abort the program. Another point that deserves a special mention is the creation of the Font objects: the position of the text on screen, given by the Point parameter, was calculated via a trial-and-error algorithm; we simply keep changing these numbers until we have positioned the text as we wish to. If we create the clsScreen class now with empty methods, we can already run our code and test it. Besides the New and Draw methods, mentioned in the class diagram, we must define the LoadData method, which will load the screen data based on the screen number and three extra properties: the Text string array, which will hold the screen text; the ScreenNumber, which will store the screen identification number; and the ActiveObjectsNumber, which will express the quantity of active objects on the current screen.
.NETwhy Game Programming DirectX 9.0 Tip Once again, did some methods with and properties not appear in the class diagram? As we have said in ISBN:1590590511 Alexandre Lobãogame and Ellen previous by chapters, in aSantos real-world project we must try to create the best project possible, with Hatton that will guarantee quality code; but we must take care to maintain a proper balance and enough details Apress © 2003 (696 pages) not get into an "analysis-paralysis" hole, and never finish the project. So we are using the same paradigm authors of this show howclass easy it can be toonly produce here, at aThe simpler level: Wetext define in our diagrams the obvious properties and methods, and multimedia games usingwe Managed DirectX and project, new details that were not discover interesting new ones when coding, because then see, as in9.0 a real programming with Visual Basic .NET on Everett, the latest clear when planning. version of Microsoft's Visual Studio.
The next code listing shows the Screen class interface: Table of Contents .NET Imports Game Programming Microsoft.DirectX.Direct3D with DirectX 9.0
Imports Microsoft.DirectX Foreword Preface
Public Class ClsScreen Introduction clsSprite ChapterInherits 1 - .Nettrix: GDI+ and Collision Detection ActiveObjectsNumber Asand Integer ChapterPublic 2 - .Netterpillars: Artificial Intelligence Sprites = 0 Public ActiveObjects() As clsActiveObject - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Public ScreenNumber As Integer
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
' The four text lines for the current screen. Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ' Each line can have up to 60 chars Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Public Text() As String D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterSub 9 -New() Nonmanaged Code
Shadows Sub Draw() Function LoadData(ByVal intScreenNumber As Integer, ByVal screenStatus As Appendix A - The State of PC Gaming End Class Bonus Chapter Porting .Nettrix to Pocket PC Appendix B - Motivations in Games Appendix C - How Do I Make Games?
We are able to run ourfor program now,Successful and see the splash screen as shown in Figure 6-19. Appendix D - Guidelines Developing Games Index List of Figures List of Tables
Figure 6-19: The game splash screen After the screen is loaded, the video goes blank, because we haven't included any code in the Render method to draw anything yet. And of course, there's nothing to be shown until we code the screen class. The most important method in the screen class is LoadData, which will open the database and load the screen data (in our case, only the screen text) and then load all active objects for the current screen. We can do this last step by calling a LoadData method on the ActiveObject class, passing the appropriate parameters. For example, we can pass the screen number and the object number; or we can open the database and access the
Active Objects table in the screen LoadData method, and then pass the record to the ActiveObject class to .NET Game Programming with DirectX 9.0 read the object data. This last approach is better, since we can reuse the opened connection to the database and ISBN:1590590511 by Alexandre Santos Lobão and Ellen generate faster code. Hatton Apressthe © 2003 (696 pages)code. Some lines have been suppressed for clarity—such as the error The next listing shows LoadData thisthe text show how easy be similar to produce handling routines.The Asauthors we can of see, data access codeit iscan very to the one we saw when presenting multimedia games using Managed DirectX 9.0 and ADO.NET, whichinteresting can be divided into these three steps: programming with Visual Basic .NET on Everett, the latest 1. Open the connection. version of Microsoft's Visual Studio.
2. Create a command and read the screen text (from the ScreenText table). Table of Contents
Create a command read9.0 the ActiveObjects data (from the Active Objects table). .NET3. Game Programming withand DirectX Foreword
After this last step, we create the active objects, passing the DataReader object as a parameter to the New method. We'll code the ActiveObject class using this sequence. Refer to the code comments to find out the Introduction purpose of each code line. Preface
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Function LoadData(intScreenNumber As Integer, screenStatus As Integer) As Boolean - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Dim i As Integer Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio LoadData = True ChapterScreenNumber 5 - River Pla.Net=II:intScreenNumber DirectInput and Writing Text to Screen ChapterReDim 6 - Magic KindergarteN.: Adventure Games,erases ADO.NET,any and DirectShow Text(3) ' Redim the array previous contents Chapter 3
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter'8 Load - .Netterpillars II: for Multiplayer Games and screen Directplayfrom the database the data the current D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Dim StrConnection as string = _ Chapter 9 Nonmanaged Code "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" _ Bonus Chapter Porting .Nettrix to Pocket PC & Application.StartupPath & "\Data\KinderData.mdb" Appendix A -Conn The State PC Gaming Dim As of OleDbConnection Appendix B -Cmd Motivations in Games Dim As OleDbCommand Appendix Dim C -DataReader How Do I Make As Games? OleDbDataReader
' D Load the current screen image, using the Load method of the base class Appendix - Guidelines for Developing Successful Games Index If Not Load("screen" & screenNumber & ".bmp") Then
MessageBox.Show("Error loading the screen image", _ List of Figures "KindergarteN. Error", MessageBoxButtons.OK, MessageBoxIcon.Error) LoadData = False End If
List of Tables
' Open the connection with the database Conn = New OleDbConnection(StrConnection) Conn.Open() ' Create and execute the command which will retrieve the screen text Cmd = Conn.CreateCommand() Cmd.CommandText = "SELECT text from ScreenText where ScreenNumber = " & _ ScreenNumber & " order by TextNumber" DataReader = Cmd.ExecuteReader() ' Load the screen text from the database i = 0 Do While DataReader.Read() If (DataReader.IsDBNull(0)) Then Text(i) = " " Else Text(i) = DataReader.GetString(0) End If i += 1 Loop ' Close the DataReader and free the command
DataReader.Close() .NET Game Programming with DirectX 9.0 Cmd.Dispose() ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton ' We'll have 5 objects at maximum on each screen Apress © 2003 (696 pages)
ReDim ActiveObjects(5) of thisthe text show how easy can be to produce ' Create The andauthors execute command to itretrieve the active objects data interesting multimedia games using Managed DirectX 9.0 and Cmd = Conn.CreateCommand() programming with Visual Basic .NET on Everett, the latest Cmd.CommandText = _ version of Microsoft's Visual Studio. "SELECT * from ActiveObject where ScreenNumber = " & ScreenNumber DataReader = Cmd.ExecuteReader() Table of ' Contents Load each of the objects .NET Game Programming with DirectX 9.0 Do While DataReader.Read() Foreword ActiveObjects(ActiveObjectsNumber) = New clsActiveObject(DataReader) Preface ActiveObjectsNumber += 1 Introduction Loop theGDI+ DataReader free the command Chapter'1 Close - .Nettrix: and Collisionand Detection ChapterDataReader.Close() 2 - .Netterpillars: Artificial Intelligence and Sprites ChapterCmd.Dispose() 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ connection with Scrolling, the database Chapter'4 Close - Riverthe Pla.Net: Tiled Game Fields, and DirectAudio ChapterConn.Close() 5 - River Pla.Net II: DirectInput and Writing Text to Screen End Function Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 - .Netterpillars Multiplayer and Directplay If we comment the activeII: object lines inGames the previous procedure and run our program, all we'll see is the current D-iNfEcT: Multithreading, Nonrectangular Windows, Access screen,9without objects or any interface elements. So, before and running ourtoprogram, we'll code the active object Chapter Nonmanaged Code
class. The class interface, shown in the next code listing, is a direct representation of the class diagram and the data model of our project, although some extra properties will be included when we code the inventory handling.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Public Class clsActiveObject Inherits clsSprite
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index Public Name As String List of Figures Public CanTake As Boolean List of Tables Public CanWalk As Boolean
Public CanUseWithOther As Boolean Public CanUseAlone As Boolean Public CanTalk As Boolean ' Text Public Public Public Public Public
to show when doing each action ExamineText As String TakeText As String WalkText As String UseWithOtherText As String UseAloneText As String
' Text Public Public Public Public
to show when each action can't be done CantTakeText As String CantWalkText As String CantUseAloneText As String CantUseWithOtherText As String
' Is the object visible? Public Visible As Boolean = True ' Icon to be shown in the inventory, if the object is taken Public Icon As clsActiveObject = Nothing
Public Sub New(ByVal DataReader As OleDbDataReader) .NET Game Programming with DirectX 9.0 Public Sub LoadData(ByVal DataReader As OleDbDataReader) ISBN:1590590511 by Alexandre Santos Lobão and Ellen End Class
Hatton Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio. We create a LoadData method in order to give our code a little more flexibility. With this approach we can, for
example, create an overloaded New method that would receive the object number or name, open the connection to the database, and call the LoadData method, passing the appropriated DataReader, and thus being able to Table of Contents create objects not tied to a specific screen. .NET Game Programming with DirectX 9.0
Foreword In our New method we'll simply call the base class New method, which will effectively create the sprite to be Preface drawn, and then call our LoadData method. Introduction
The parameters expected by the base class (clsSprite) include the image name, the transparent color, the x Chapter 1 - .Nettrix: GDI+ and Collision Detection and y starting position for Artificial the sprite, the width and andSprites height of the sprite, and the scale factor to be applied when Chapter 2 - .Netterpillars: Intelligence
doing matrix transformations on it. The code to call this method using the values from the DataReader received - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ as a parameter is shown in the following code lines:
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
MyBase.New(DataReader.GetString(2), Chapter 6 - Magic KindergarteN.: Adventure Games,Color.FromArgb(255, ADO.NET, and DirectShow 255, 0, 255), _ New POINT(DataReader.GetInt32(3), DataReader.GetInt32(4)), _ Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API clsSprite.enScaleFactor.enScalePixel, _ Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay DataReader.GetInt32(5), DataReader.GetInt32(6)) Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
As we can see, it's pretty difficult to read this code, since the data is accessed from the DataReader according to the absolute position of the field within the record. That's the fastest way to access data, but the code becomes Appendix B - Motivations in this Games unreadable. To minimize problem and improve the readability of our code, we'll create an enumeration that Appendix C How Do I Make Games? will list the DataReader fields, as shown in the next listing: Appendix A - The State of PC Gaming
Appendix D - Guidelines for Developing Successful Games Index
' This enum is just to make the data reading code clearer
List of Figures Private Enum Fields List of Tables Name = 2
X = 3 Y = 4 Width = 5 Height = 6 CanTake = 7 CanWalk = 8 CanTalk = 9 CanUseWithOther = 10 CanUseAlone = 11 ExamineText = 12 TakeText = 13 WalkText = 14 UseAloneText = 15 UseWithOtherText = 16 NoTakeText = 17 NoWalkText = 18 NoUseAloneText = 19 NoUseWithOtherText = 20 Visible = 21 ImageName = 22 End Enum
Using the enumeration we have just created, the new version of the constructor for the ActiveObject class is .NET Game Programming with DirectX 9.0 shown in the nextby listing: ISBN:1590590511 Alexandre Santos Lobão and Ellen Hatton Apress © 2003DataReader (696 pages) Public Sub New(ByVal As OleDbDataReader) ' Create The theauthors image, calling of this text showthe how base easy it class can be toconstructor produce interesting multimedia games using Managed DirectX 9.0 and _ MyBase.New(DataReader.GetString(Fields.ImageName), programming with Visual Basic0, .NET on Everett, the latest Color.FromArgb(255, 255, 255), _ version of Microsoft's Visual Studio. New POINT(DataReader.GetInt32(Fields.X), _ DataReader.GetInt32(Fields.Y)), clsSprite.enScaleFactor.enScalePixel, _ DataReader.GetInt32(Fields.Width), DataReader.GetInt32(Fields.Height)) Table of Contents LoadData(DataReader) .NET Game Programming with DirectX 9.0 End Sub Foreword Preface Introduction
TheLoadData method will simply fill the object properties using the data read from the record received as a .Nettrix: GDI+ and Collision Detection parameter,- as shown in the next code listing:
Chapter 1 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Public Sub LoadData(ByVal DataReader As OleDbDataReader) - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Icon = New clsActiveObject(DataReader.GetString(Fields.ImageName), _ Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Color.FromArgb(255, 255, 0, 255), _ Chapter 6 -New MagicPOINT(8, KindergarteN.: Games, ADO.NET, and DirectShow 8),Adventure clsSprite.enScaleFactor.enScalePixel, 64, 64) Chapter 4
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
ChapterName 8 - .Netterpillars II: Multiplayer Games and Directplay = DataReader.GetString(Fields.Name) D-iNfEcT: Nonrectangular Windows, and Access to = Multithreading, Name ChapterIcon.Name 9 Nonmanaged Code Visible = DataReader.GetBoolean(Fields.Visible) Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming CanTake = DataReader.GetBoolean(Fields.CanTake) Appendix B - Motivations in Games CanWalk = DataReader.GetBoolean(Fields.CanWalk) Appendix C - How Do I Make Games? CanUseAlone = DataReader.GetBoolean(Fields.CanUseAlone) Appendix CanUseWithOther D - Guidelines for Developing = DataReader.GetBoolean(Fields.CanUseWithOther) Successful Games Index CanTalk = DataReader.GetBoolean(Fields.CanTalk) List of Figures
' Text to show when doing each action List of Tables ExamineText = DataReader.GetString(Fields.ExamineText) TakeText = DataReader.GetString(Fields.TakeText) WalkText = DataReader.GetString(Fields.WalkText) UseAloneText = DataReader.GetString(Fields.UseAloneText) UseWithOtherText = DataReader.GetString(Fields.UseWithOtherText) ' Text to show when each action can't be done CantTakeText = DataReader.GetString(Fields.NoTakeText) CantWalkText = DataReader.GetString(Fields.NoWalkText) CantUseAloneText = DataReader.GetString(Fields.NoUseAloneText) CantUseWithOtherText = DataReader.GetString(Fields.NoUseWithOtherText) End Sub
In the previous code listing, notice the parameters of the object icon creation: The object icon is a new active object, with the same image as the current object, but with the dimensions 64×64 pixels. The initial position of this icon is (8,8) on screen, which is in the bottom left of the screen. This initial position will allow us to draw the icon directly over the right side of the inventory, and with a little translation on the x axis, draw it over the left side of the inventory. We'll see more details on this when talking about inventory control later in the chapter. We do not need to code a Draw method for the ActiveObject class, since the base class one will suffice. Before we can finally see the results of our code on screen, we have to code the Draw method of the screen class (which will draw the screen and call the Draw method of each of the screen active objects) and the
Render method of the KinderEngine class (which will simply call the screen Draw method). The following .NET Game Programming with DirectX 9.0 code listing shows these two methods: by Alexandre Santos Lobão and Ellen Hatton Shadows Sub Draw() Apress © 2003 (696 pages)
ISBN:1590590511
Dim i As The Integer authors of this text show how easy it can be to produce ' Draw the screen background interesting multimedia games using Managed DirectX 9.0 and MyBase.Draw() programming with Visual Basic .NET on Everett, the latest version Microsoft's Visual Studio. ' Draw all theofactive objects For i = 0 To ActiveObjectsNumber-1 If Not ActiveObjects(i) Is Nothing Then Table of Contents If ActiveObjects(i).Visible Then .NET Game Programming with DirectX 9.0 ActiveObjects(i).Draw() Foreword End If Preface End If Introduction Next Chapter 1 - .Nettrix: GDI+ and Collision Detection End Sub Chapter . . .2 - .Netterpillars: Artificial Intelligence and Sprites ChapterPublic 3 - Managed DirectX First Direct3D Basics and DirectX vs. GDI+ Overrides SubSteps: Render() Chapter 4 -CurrentScreen.Draw() River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio ChapterEnd 5 -Sub River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Running our sample now, we can see the current screen and any active objects it has. In order to see a screen D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - active objects (the invisible objects, like the exits on each screen, are not shown, as indicated in the with visible Nonmanaged Code previous code sample), we'll change the Initialize method of the KinderEngine class, just for the Bonus Chapter Porting .Nettrix to Pocket PC moment, to set the current screen to Screen1, replacing the CurrentScreen = Screen(1) command with Appendix A - The State of PC Gaming CurrentScreen = Screen(0). The result is shown in Figure 6-20, where we can see the screen and three Appendix B - Motivations in Games active objects: the television and the magic book on the table, plus the mouse hole behind the table. Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 6-20: The kindergarten indoors, including active objects The other screen elements, as depicted in earlier in Figure 6-15, are just sprites that can be created by including the following lines in the Initialize method: ' Load the screen elements (hands, head and text background) RightHand = New clsSprite("RightHand.Bmp", New POINT(4, 4), _ clsSprite.enScaleFactor.enScalePixel, 72, 72) LeftHand = New clsSprite("LeftHand.Bmp", New POINT(80, 4), _ clsSprite.enScaleFactor.enScalePixel, 72, 72) TalkingHead = New clsSprite("NatanaelFace.Bmp", New POINT(156, 4), _ clsSprite.enScaleFactor.enScalePixel, 72, 72) TextBackground = New clsSprite("TextBackground.Bmp", New POINT(232, 4), _ clsSprite.enScaleFactor.enScalePixel, 564, 72)
After including the code for drawing these sprites our Render method, we'll be able to see all interface .NET Game Programming with in DirectX 9.0 elements on screen. The final touch is to create a procedure to display the screen text in the Text() font array ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton we created earlier, as shown in the next listing: Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce Sub DrawText() Dim i As interesting Integermultimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest For i = 0version To 3of Microsoft's Visual Studio. Text(i).Draw() Next Table Contents End ofSub .NET Game Programming with DirectX 9.0 Foreword
Figure 6-21 shows the final interface for the Magic KindergarteN. adventure. Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix Figure C - 6-21: How Do The I Make Magic Games? KindergarteN. interface elements in place Appendix D - Guidelines for Developing Successful Games
In the next section we'll create the last interface element for our game, the mouse pointer. Index List of Figures
Second Draft: Coding the Mouse Pointer
List of Tables
The last user interface element is the mouse pointer, which will represent a specific action verb to be applied to an active object when clicking. Although simple, the coding for the mouse pointer must take into account the following requirements: One object must display different images according to the current status, so the basic Sprite methods will not suffice. The pointer must move according to the mouse movement, so we'll need to code the mouseMove event of theclsMouse class (created in the previous chapter) to update the object's position on screen. Every time the pointer passes over an active object, we'll need to update the status text on screen; so we'll need to code a collision detection algorithm in the game engine class. When the user clicks an active object, we'll need to handle this event, checking the current mouse status and running the appropriate action. Since we are including all game strings in the database, to make the translation easier, we'll need to read the verbs from the database, too, and include some private properties to store the verbs to be used in the game, plus one extra property to store the "with" word, employed to compose the status text on screen when the player is using an object in the inventory with another on the current screen. To allow the game engine to easily retrieve the verb for the current pointer, we'll need an extra property, PointerText, that must be updated every time the current status changes.
The next code listing interface for with the adventure pointer class: .NETshows Gamethe Programming DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Public Class Hatton clsAdvPointer © 2003 (696 pages) Inherits Apress clsSprite The authors of this text show how easy it can be to produce interesting multimedia games = using Managed DirectX 9.0 and Public PointerText As String "Examine " programming Visual Basic on Everett, the latest Private pStatus Aswith enStatus = .NET enStatus.Examine version of Microsoft's Visual Studio.
' These properties will hold each of the pointer icons Table ofPrivate Contents WalkIcon As Direct3DTexture8 Private ExamineIcon As9.0 Direct3DTexture8 .NET Game Programming with DirectX Private TakeIcon As Direct3DTexture8 Foreword PrefacePrivate UseIcon As Direct3DTexture8 Private WaitIcon As Direct3DTexture8 Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
' Set default values for english verbs - .Netterpillars: Artificial Intelligence and Sprites Private WalkText As String = "Walk to " Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Private ExamineText As String = "Examine " Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Private TakeText As String = "Take " ChapterPrivate 5 - RiverTalkText Pla.Net II: DirectInput and = Writing Text" to Screen As String "Talk ChapterPrivate 6 - MagicUseText KindergarteN.: Adventure=Games, and DirectShow As String "Use ADO.NET, " ChapterPrivate 7 - MagicWithText KindergarteN. Animation AsII:String = Techniques " With "and Speech API ChapterEnum 8 - .Netterpillars enStatus II: Multiplayer Games and Directplay D-iNfEcT: Walk = 0Multithreading, Nonrectangular Windows, and Access to Chapter 9 Nonmanaged Code Examine = 1 Bonus Chapter Porting .Nettrix to Pocket PC Take = 2 Appendix A -Use The State = 3 of PC Gaming Appendix B -Wait Motivations = 4 in Games Appendix End C -Enum How Do I Make Games? Chapter 2
Appendix D - Guidelines for Developing Successful Games Index Public Sub New()
Shadows Function Load(strImageName, colorKey) As Direct3DTexture8 List of Figures Function CreateVertexBuffer() As Boolean List of Tables Sub ReadVerbs() Sub NextStatus() Shadows Sub Draw() End Class
TheSprite New method creates a single vertex buffer for a single image. Since we'll use a single buffer with many images, we'll have to create new methods for the whole texture creation process. We can copy the methods from the Sprite class and adapt them to create a Load method that does not create a vertex buffer, so we can load many different textures onto the verb icon and include a separate method to create a solo vertex buffer. The code for the New,Load, and CreateVertexBuffer methods is shown in the following listing: Public Sub New() IsTransparent = True X = 0 Y = 0 Width = 32 Height = 64 ScaleFactor = clsSprite.enScaleFactor.enScalePixel ExamineIcon = Load("IconExamine.Bmp", _
Color.FromArgb(255, 255, 0, 255).ToArgb) Game Programming with DirectX 9.0 TakeIcon .NET = Load("IconTake.Bmp", Color.FromArgb(255, 255, 0, 255).ToArgb) ISBN:1590590511 255, 0, 255).ToArgb) by Alexandre Santos Lobão and Ellen WalkIcon = Load("IconWalk.Bmp", Color.FromArgb(255, Hatton UseIcon = Load("IconUse.Bmp", Color.FromArgb(255, 255, 0, 255).ToArgb) Apress © 2003 (696 pages) WaitIcon = Load("IconWait.Bmp", Color.FromArgb(255, 255, 0, 255).ToArgb) The authors of this text show how easy it can be to produce CreateVertexBuffer() interesting multimedia games using Managed DirectX 9.0 and End Sub programming with Visual Basic .NET on Everett, the latest Shadows Function As String, _ versionLoad(strImageName of Microsoft's Visual Studio. Optional colorKey As Integer = &HFFFF00FF) As Texture Try Table of Contents Load = TextureLoader.FromFile(objDirect3DDevice, _ .NET Game Programming with DirectX 9.0 Application.StartupPath & "\" & IMAGE_PATH & "\" & strImageName) Foreword Catch de As DirectXException Preface MessageBox.Show("Could not load image file " & strImageName & ". _ Introduction Error: " & de.ErrorString, "3D Initialization - AdvPointer.", _ MessageBoxButtons.OK, Chapter 1 - .Nettrix: GDI+ and Collision DetectionMessageBoxIcon.Error) Nothing Chapter 2 -Return .Netterpillars: Artificial Intelligence and Sprites ChapterEnd 3 -Try Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ End Function Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Function CreateVertexBuffer() As Boolean Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Dim vertices As CustomVertex() Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Dim VertexType As CustomVertex Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
ChapterTry 9 -
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
VertBuffer = New VertexBuffer(VertexType.GetType, 4, objDirect3DDevice, _ Usage.WriteOnly, FVF_CUSTOMVERTEX, Pool.Default) Appendix A - The State of PC Gaming vertices = VertBuffer.Lock(0, 0) Appendix B - Motivations in Games ' Create a square, composed of 2 triangles in a triangle strip Appendix C - How Do I Make Games? vertices(0) = CreateFlexVertex(X * ScaleFactor, _ Appendix D - Guidelines for Developing Successful Games Y * ScaleFactor, 1, 0, 1) Index vertices(1) = CreateFlexVertex(X * ScaleFactor + Width, _ List of Figures Y * ScaleFactor, 1, 1, 1) List of Tablesvertices(2) = CreateFlexVertex(X * ScaleFactor, _ Y * ScaleFactor + Height, 1, 0, 0) vertices(3) = CreateFlexVertex(X * ScaleFactor + Width, _ Y * ScaleFactor + Height, 1, 1, 0) ' Release the vertex buffer and commit our vertex data VertBuffer.Unlock() Bonus Chapter Porting .Nettrix to Pocket PC
Return True Catch de As DirectXException MessageBox.Show("Could not create vertex buffer for AdvPointer. Error: " _ & de.ErrorString, "3D Initialization.", MessageBoxButtons.OK, MessageBoxIcon.Error) Return False End Try End Function
The functions used to load the texture and to create the vertex buffer, and further explanations on how to use them, are presented in Chapter 3. Once the textures for the pointer are loaded, we need to code the Draw procedure, the NextStatus procedure (to cycle between the possible statuses), and the ReadVerbs procedure. This will set the text values for each
verb so we can see the results on screen.
.NET Game Programming with DirectX 9.0
ISBN:1590590511 In the Draw method, by Alexandre shown inSantos the next Lobão listing, andwe Ellen apply the current translation information to the world matrix, Hatton choose the texture to be used, and draw our vertex buffer, resetting the world matrix after that. (If we don't do this Apress © 2003 (696 last step, everything on screen willpages) move with the mouse pointer! ) Refer to Chapter 3 if you're still unclear about The authors of this textthem. show how easy it can be to produce matrix transformations and how to use
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Shadows Sub Draw() version of Microsoft's Visual Studio.
' If the sprite has a speed, increment the translation If (SpeedX + SpeedY) > 0 Then Table of Contents TranslationX += SpeedX .NET Game Programming with DirectX 9.0 TranslationY += SpeedY Foreword End If Preface Introduction ' If there's a scale to be applied, apply it... ChapterIf 1 (ScaleX - .Nettrix: GDI+ + ScaleY) and Collision > 0 Detection Then Chapter 2
-objDirect3DDevice.Transform.World .Netterpillars: Artificial Intelligence and Sprites = _
Chapter 3
Matrix.Multiply(objDirect3DDevice.Transform.World, _ - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
Matrix.Scaling(ScaleX, ScaleY, 0)) - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
ChapterEnd 5 -If River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
' If- Magic there's a translation to be applied, apply it... KindergarteN. II: Animation Techniques and Speech API If (pTranslationX + pTranslationY) > 0 Then Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay objDirect3DDevice.Transform.World = _ D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Matrix.Multiply(objDirect3DDevice.Transform.World, _ Nonmanaged Code Matrix.Translation(pTranslationX, pTranslationY, 0)) Bonus Chapter Porting .Nettrix to Pocket PC End If Chapter 7
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
' If there's a rotation to be applied, apply it... If (RotationX + RotationY) > 0 Then Appendix D - Guidelines for Developing Successful Games objDirect3DDevice.Transform.World = _ Index Matrix.Multiply(objDirect3DDevice.Transform.World, _ List of Figures Matrix.Scaling(RotationX, RotationY, 0)) List of Tables End If ' Turn on alpha blending, since sprite has transparent colors objDirect3DDevice.RenderState.AlphaBlendEnable = True Select Case pStatus Case enStatus.Examine objDirect3DDevice.SetTexture(0, ExamineIcon) Case enStatus.Take objDirect3DDevice.SetTexture(0, TakeIcon) Case enStatus.Use objDirect3DDevice.SetTexture(0, UseIcon) Case enStatus.Walk objDirect3DDevice.SetTexture(0, WalkIcon) Case enStatus.Wait objDirect3DDevice.SetTexture(0, WaitIcon) End Select objDirect3DDevice.SetStreamSource(0, VertBuffer) objDirect3DDevice.DrawPrimitives(PrimitiveType.TriangleStrip, 0, 2) ' Turn off alpha blending objDirect3DDevice.RenderState.AlphaBlendEnable = False ' Reset the world matrix objDirect3DDevice.Transform.World = Matrix.Identity End Sub Appendix C - How Do I Make Games?
The mouse cycling method will just increment the current status property, resetting the status counter to the first .NET Game Programming with DirectX 9.0 status after the last one, as shown in the next listing: ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Sub NextStatus() Apress © 2003 (696 pages)
Status +=The 1 authors of this text show how easy it can be to produce multimedia gamesmouse using Managed DirectX 9.0 and ' we can interesting go through all the states, except wait with Visual Basic If Statusprogramming = enStatus.Wait Then.NET on Everett, the latest version of Microsoft's Visual Studio. Status = 0 ' restart End If End Sub Table of Contents .NET Game Programming with DirectX 9.0 Foreword
To ensure that every time we change the Status property the PointerText property will remain synchronized, even if the game engine changes it without using the NextStatus method, we must define Status as a Introduction property procedure, and code the Set procedure to update the PointerText procedure according to the Chapter - .Nettrix: GDI+ current1Status being set. and The Collision code forDetection the property procedure is shown in the following listing: Preface
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
' This property is defined as a property procedure, and - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio ' it uses the enumeration above as property types Chapter 5 Pla.Net II: Property- River Status() AsDirectInput enStatusand Writing Text to Screen ChapterGet 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7 -Status Magic KindergarteN. II: Animation Techniques and Speech API = pStatus ChapterEnd 8 -Get .Netterpillars II: Multiplayer Games and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Value As enStatus) ChapterSet(ByVal 9 Nonmanaged Code pStatus = Value Bonus Chapter .Nettrix to Pocket ' Porting We could have donePCthis with an array, but this way the code is clearer Appendix A -Select The StateCase of PC Gaming pStatus Appendix B - Motivations Games Case in enStatus.Examine Appendix C - How Do I Make PointerText Games? = ExamineText Case enStatus.Take Appendix D - Guidelines for Developing Successful Games PointerText = TakeText Index Case enStatus.Use List of Figures PointerText = UseText List of Tables Case enStatus.Walk PointerText = WalkText End Select End Set End Property Chapter 4
The last method of this class, ReadVerbs, will only load the verbs from the database, using the same ADO.NET objects and methods we have already seen. If the database contains English verbs, the values will be the same as the default values, but you can translate them in the database if you want to play the games in other languages. The code for the method is on the sample CD-ROM that accompanies this book, with the full code for the game inside the Chapter 6 directory. We need to include a call for the drawing method of the Render procedure of the game engine class—Pointer.Draw() will suffice for displaying the game pointer on screen. If we run our game now, we'll be able to see the mouse pointer in the bottom left of the screen, but it isn't working yet, since we haven't written the code for moving and cycling it. Creating one object of the clsMouse class (which wraps DirectInput, as shown in the previous chapter), we can make our pointer move and act as expected, just by coding the mouse events in the KinderEngine class. We can now see how easy coding games becomes when using our base classes. In this example, we'll initialize DirectInput with just one line—when creating the mouse object in the Initialize method of the game engine
class.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
Mouse = New ClsMouse(Owner) Hatton
ISBN:1590590511
Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and We can control the movementwith of our pointer by.NET simply adding two programming Visual Basic on Everett, the lines latestto the MouseMove event of the Mouse object, and do theversion actionofverb cycling Visual by adding one line to the MouseUp event, as shown in the next listing: Microsoft's Studio.
Sub Mouse_MouseMove(X As Integer, Y As Integer) Handles Mouse.MouseMove Pointer.TranslationX = X .NET Game Programming with DirectX 9.0 Pointer.TranslationY = clsGameEngine.Height - Y Foreword End Sub Preface Sub Mouse_MouseUp(X As Integer, Y As Integer, _ Introduction Button As KindergarteN.ClsMouse.enButton) Handles Mouse.MouseUp Chapter 1 If- .Nettrix: and Collision Detection ButtonGDI+ = ClsMouse.enButton.Left Then Pointer.NextStatus() Chapter 2 .Netterpillars: Artificial Intelligence and Sprites End Sub
Table of Contents
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Since the axis value is counted from the astoexplained Chapter 5 y- River Pla.Net II: DirectInput andbottom Writingup, Text Screen in Chapter 3, we must subtract it from the
height of screen to calculate Adventure the properGames, translation value and for this axis. Chapter 6 the - Magic KindergarteN.: ADO.NET, DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
We can now run our program and move our pointer on the screen, and cycle the actions by clicking the left - .Netterpillars II: Multiplayer Games and Directplay mouse button. Figure 6-22 shows the screen with the mouse moving over it.
Chapter 8 Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 6-22: Moving the pointer with the Examine verb In the next section we'll add the code to the KinderEngine class to update the status line when moving over an active object, as well as the code to effectively execute the actions when clicking them, including playing the video using DirectShow.
Third Draft: Coding the Mouse Pointer Actions There are two main points we must take into account when coding the mouse pointer actions: First, we must update the status text every time the mouse passes over an active object, regardless of its visibility; and second, we must code the click event to trigger the appropriate action, according to the current pointer status and the clicked object. For these two actions we'll have a collision testing procedure that must check the current pointer against all active objects on screen. Returning the active object will allow the calling procedure to take the appropriate action in each case. The next code listing shows the TestCollision procedure, which uses the bounding box algorithm (discussed earlier in this book) to calculate the collision and return, if any, the colliding object:
' Test for collision the pointer, update .NET Game with Programming with DirectX 9.0 the status line ' and returnby the colliding object ISBN:1590590511 Alexandre Santos Lobão and Ellen Private Sub TestCollision(ByRef ClickedObject As clsActiveObject) Hatton Dim i As Apress Integer © 2003 (696 pages) ClickedObject = Nothing The authors of this text show how easy it can be to produce For i = 0interesting To CurrentScreen.ActiveObjectsNumber 1 multimedia games using Managed DirectX 9.0-and programming with Visual Basic .NET on Everett, the If Not CurrentScreen.ActiveObjects(i) Is latest Nothing Then version of Microsoft's Visual>Studio. If Pointer.CenterX CurrentScreen.ActiveObjects(i).X And _ Pointer.CenterX < CurrentScreen.ActiveObjects(i).X + _ CurrentScreen.ActiveObjects(i).Width Then Table of Contents If Pointer.CenterY > CurrentScreen.ActiveObjects(i).Y And _ .NET Game Programming with DirectX 9.0 Pointer.CenterY < CurrentScreen.ActiveObjects(i).Y + _ Foreword CurrentScreen.ActiveObjects(i).Height Then Preface ClickedObject = CurrentScreen.ActiveObjects(i) Introduction End If Chapter 1 - .Nettrix: GDI+ and Collision Detection End If Chapter 2 -End .Netterpillars: Artificial Intelligence and Sprites If ChapterNext 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio End Sub Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow We'll use procedure in the Render method to checkand for Speech collisionAPI every time the screen is being drawn, and Chapter 7 this - Magic KindergarteN. II: Animation Techniques
use the8resulting information to update Games the status which can be created by including the following code line Chapter - .Netterpillars II: Multiplayer andtext, Directplay in the Initialize method of the KinderEngine class: D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to -
Chapter 9
Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC StatusText = New ClsGameFont("Microsoft Sans Serif", 14, _ Appendix A - The State Space(135), of PC Gaming New POINT(4, 508)) Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
In the Render method, we should retrieve the current game pointer action verb—the PointerText property—and concatenate the object name to it, when there's an object under the mouse pointer. Thus, when List of Figures we move the mouse pointer in Examine status over an object, let's say a magic book, the status line will display List of Tables "Examine magic book". This will give the player the clue he or she needs to figure out which objects on screen are active ones. Index
' The TestCollision procedure returns the object that ' is colliding with the mouse - if there's any TestCollision(ClickedObject) ' Updates the status line text StatusText.Text = "" StatusText.Text = StatusText.Text & Pointer.PointerText If Not ClickedObject Is Nothing Then StatusText.Text = StatusText.Text & ClickedObject.Name End If ' Centers the status text on screen (a line can show 135 characters) StatusText.Text = Space((135 - Len(StatusText.Text)) / 2) & StatusText.Text StatusText.Draw()
If we run our program now, we can move the pointer over the first screen and check the two active objects—the entrance to the school and the exit to the forest. To code the actions, we must update the MouseUp event, now including code for pressing the right mouse button. The code, shown in the next listing, will call the TestCollision procedure and, if there is any active
object under the game pointer when the button is pressed, call the appropriate procedure to process the action: .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Sub Mouse_MouseUp(X As Integer, Y As Integer, _ Hatton Button As KindergarteN.ClsMouse.enButton) Handles Mouse.MouseUp Apress © 2003 (696 pages) Dim clickedObject As clsActiveObject The authors of this text show how easy it can be to produce If Buttoninteresting = ClsMouse.enButton.Left Then DirectX 9.0 and multimedia games using Managed Pointer.NextStatus() programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio. Else TestCollision(clickedObject) If Not clickedObject Is Nothing Then Table of Contents Select Case Pointer.Status .NET Game Programming with DirectX 9.0 Case clsAdvPointer.enStatus.Examine Foreword DoExamine(clickedObject) Preface Case clsAdvPointer.enStatus.Take Introduction DoTake(clickedObject) Chapter 1 - .Nettrix: GDI+ andclsAdvPointer.enStatus.Use Collision Detection Case Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites DoUseAlone(clickedObject) Chapter 3 - Managed DirectX Steps: Direct3D Basics and DirectX vs. GDI+ Case First clsAdvPointer.enStatus.Walk Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio DoWalk(clickedObject) Chapter 5 - RiverEnd Pla.Net Select II: DirectInput and Writing Text to Screen Chapter 6 -End MagicIf KindergarteN.: Adventure Games, ADO.NET, and DirectShow End If Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API End Sub Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Each of the preceding procedures is unique: The DoWalk procedure, in our game, will not make the player really walk, but will change the current screen; the DoUseAlone procedure will process special actions associated with Appendix A - The State of PC Gaming the Use verb—for example, turning on a television; the DoExamine will show the description of each object Appendix B - Motivations in Games (stored in the ActiveObject class); and the DoTake procedure will store objects in the inventory, if they can be Appendix C - How Do I Make Games? carried. Bonus Chapter Porting .Nettrix to Pocket PC
Appendix D - Guidelines for Developing Successful Games
Index Every time the player executes an action upon an object, text is displayed in the text box on the List of Figures screen—reinforcing the reaction of the player when executing the action, or giving the proper excuses for not executing it. We'll create a helper function, Say, to display text in this box. The DoExamine method will simply List of Tables
call this procedure, as shown in the next code listing, but the other methods will do a lot more. Sub Say(strText1 Optional Text(0).Text Text(1).Text Text(2).Text Text(3).Text End Sub
As String, Optional strText2 As String = "", _ strText3 As String = "", Optional strText4 As String = "") = strText1 = strText2 = strText3 = strText4
Sub DoExamine(ByVal clickedObject As clsActiveObject) Say(clickedObject.ExamineText) End Sub
TheDoWalk method will be responsible for the navigation between screens. To implement this, we must know exactly which object was clicked, and then execute four steps: 1. Check the CanWalk flag on the clicked object. If the player can't walk to the object, simply display the CantWalkText property on screen, using the Say method. If the player can walk to the object, check the object name (according to the name stored in the database) and execute the next steps. 2. Update the CurrentScreen variable, so the next execution of the Render method will draw the new
3.
2. screen.
.NET Game Programming with DirectX 9.0
Alexandretext Santos Lobão and screen. Ellen 3. Update thebydisplayed on the current
ISBN:1590590511
Hatton 4. Update theApress player© position, 2003 (696 pages) if the player must appear in a different screen position. We'll talk more about
the player The in the next section of this chapter. authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
At this point, we must programming refer to our withstoryline Visual Basic and .NET classon diagram Everett,and the check latest if there are any special conditions when of another. Microsoft's Studio. walking from oneversion place to In Visual our game, such special conditions will occur only when walking to the mouse hole: The player can indeed walk to the mouse hole, but only if he or she has become small, as a result of eating the magic mushroom. So we must check the player status property (refer to the class diagram and to Table of Contents thenext section), and, if the player is small, grant access to the hole; if not, just display the CantWalkText .NET Game Programming with DirectX 9.0 property (in this case, "I'm too big to fit in there! "). Foreword
Preface Note One extra point that we can't forget is to restore the "Big" status of the player when entering the hole, Introductionsince the player must appear big when inside the hole, and restore the "Small" status when walking Chapter 1 outside - .Nettrix: theGDI+ hole and again. Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
The next code sample shows part of the DoWalk method:
Sub DoWalk(ByVal clsActiveObject) Chapter 5 - River Pla.NetclickedObject II: DirectInput and As Writing Text to Screen Then ChapterIf 6 clickedObject.CanWalk - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Say(clickedObject.WalkText) ' If we can walk, load the next screen Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay ' (show the wait Pointer icon) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -Pointer.Status = clsAdvPointer.enStatus.Wait Nonmanaged Code Select Case clickedObject.Name Bonus Chapter Porting .Nettrix to Pocket PC Case "kindergarten door" Appendix A - The State of PC Gaming CurrentScreen = Screen(0) Appendix B - Motivations in Games UpdateScreenText() Appendix C - How Do I Make Games? ' Set the player position on the new screen Appendix D - Guidelines for Developing Successful Games Player.X = 525 Index Player.Y = 0 List of Figures Case "door" List of Tables CurrentScreen = Screen(1) UpdateScreenText() ' Set the player position on the new screen Player.X = 300 Player.Y = 0 . . . Case "mouse hole" If Player.status = clsAdvPlayer.enStatus.Small Then CurrentScreen = Screen(4) Player.status = clsAdvPlayer.enStatus.Big UpdateScreenText() ' Set the player position on the new screen Player.X = 325 Player.Y = 0 Else Say(clickedObject.CantWalkText) End If Case "exit" ' Going out the mouse hole CurrentScreen = Screen(1) UpdateScreenText() Player.status = clsAdvPlayer.enStatus.Small ' Set the player position on the new screen Player.X = 50 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Player.Y = 0 .NET Game Programming with DirectX 9.0 End Select by Alexandre Lobão mouse and Ellenpointer ISBN:1590590511 ' Restore the Santos previous Hatton Pointer.Status = clsAdvPointer.enStatus.Walk Else
Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce Say(clickedObject.CantWalkText) interesting multimedia games using Managed DirectX 9.0 and End If programming with Visual Basic .NET on Everett, the latest End Sub version of Microsoft's Visual Studio.
Table The of next Contents method to explore, DoUseAlone, will have a structure similar to the one in the previous listing: It must .NET check Game if the Programming object can be with used, DirectX and9.0 if so use it accordingly. But the actions to be executed will be unique,
depending on each object clicked in a game: You can unlock a door, eat a meal, or turn on a sound system. In Foreword our game, we'll have only two objects that can be used with the mouse pointer: the TV, which will play video files, Preface and the magic mushroom, which will make the player shrink and grow. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
The next code sample presents the code for doing these actions:
Sub DoUseAlone(ByVal clickedObject As clsActiveObject) - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio If clickedObject.CanUseAlone Then Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Say(clickedObject.UseAloneText) Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Select Case clickedObject.Name Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Case "television" Chapter 8 - .Netterpillars Multiplayer Games and Directplay IfII:Not Video.IsPlaying Then D-iNfEcT: Multithreading, Nonrectangular ' Turn on the TV Windows, and Access to Chapter 9 Nonmanaged Code PlayTVChannel() Bonus Chapter Porting .Nettrix to Pocket PC End If Appendix A - The State PC Gaming Caseof "mushroom" Appendix B - Motivations'inUsing Games the magic mushroom changes the player size Appendix C - How Do I Make Games? If Player.status = clsAdvPlayer.enStatus.Small Then Appendix D - Guidelines for Developing Successful = Games Player.status clsAdvPlayer.enStatus.Big Index Else List of Figures Player.status = clsAdvPlayer.enStatus.Small End If List of Tables End Select Else Say(clickedObject.CantUseAloneText) End If End Sub Chapter 4
ThePlayTVChannel procedure, called when using the television, will employ DirectShow to play four different videos on the TV, cycling each time the TV is clicked. Since video play is asynchronously controlled by DirectShow, we must stop drawing the screen in order to display video without flickering. To do this, we'll check the IsPlaying property and stop everything else when a video is playing, by including proper code in the game to prevent the Render procedure from being called, the pointer from processing the mouse events, and a new video from playing—as we can already see in the previous code listing. The complete code is on the CD-ROM for this book. In order to use DirectShow, we must create the Video object in the Initialize method of the KinderEngine class before calling the Play method, as shown in the next piece of code. PicVideo is a pictureBox control that will be used to play the video inside the television image on screen, and that will be passed as a new parameter to the Initialize method. Public Video As clsVideo
Shadows Function Initialize(ByVal owner As Windows.Forms.Control, _ .NET Game with DirectX 9.0 As Boolean WndVideo as Programming Windows.Forms.Control) ISBN:1590590511 by Alexandre Santos Lobão and Ellen . . . Hatton ' Create the Video Object Apress © 2003 (696 pages) ' The Video Position must be over the TV bitmap The clsVideo(VideoWindow) authors of this text show how easy it can be to produce Video = New interesting multimedia games using Managed DirectX 9.0 and . . . programming with Visual Basic .NET on Everett, the latest End Sub version of Microsoft's Visual Studio. Sub PlayTVChannel() Table ofStatic Contents Channel As Integer = 1 .NET Game Programming Channel += 1 with DirectX 9.0 Foreword If Channel > 4 Then Channel = 1 Preface Introduction Select Case Channel Chapter 1
1 GDI+ and Collision Detection -Case .Nettrix:
Chapter 2
Video.Play("SlapMont.AVI") - .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
2 DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ -Case Managed
Chapter 4
- River Video.Play("VideoFX.AVI") Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
3 -Case River Pla.Net II: DirectInput and Writing Text to Screen
Video.Play("Pyramids.Avi") Case 4 Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Video.Play("skiing.Avi") Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Select D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 End Sub Nonmanaged Code Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State the of PC Gaming Figure 6-23 presents use of DirectShow in our game, while testing the Use verb on the kindergarten Appendix B Motivations in Games television. Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 6-23: The mouse pointer triggers an action—turn on the TV. All the videos we use in this program were created by Jasmine Multimedia, and are royalty free. The television cycles through the videos shown in the following list: Skiing: This video clip is from the SPORTS IN MOTION CD-ROM. Video Effects: This is a sample of the video clips available on Video Special Effects—Volumes I & II CDROMs.
.NET Game Programming withfrom DirectX 9.0 Egyptian Pyramids: This video clip comes the Famous Places CD-ROM. ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Slapstick Montage: This (696 video clip is from Amazing Movies CD-ROM. Apress © 2003 pages)
The authors of this text show how easy it can be to produce
In the next sectioninteresting we'll discuss the DoTake which will add objects multimedia gamesmethod, using Managed DirectX 9.0 and to the inventory, and one extra method we'll need to create, DoUseWith, which willon beEverett, called when using two objects together (one from the programming with Visual Basic .NET the latest of Microsoft's Visual Studio. inventory, anotherversion from the current screen).
Final Version: Coding the Player and the Inventory
Table of Contents
.NET Game Programming with DirectX 9.0
In this section we'll finalize our game, including the code for drawing the player and all operations related to inventory handling, such as taking the objects, drawing the objects in our inventory, and using them with other Preface objects on screen. Foreword
Introduction
Chapter 1 player - .Nettrix: GDI+ and Collision Detection Since our character for this game will be very simple (only a fixed sprite on screen), all we have to do is to Chapter .Netterpillars: Artificial Intelligence and its Sprites include2the- action for scaling the character when status is "Small", creating a new Draw procedure. The next Chapter code listing 3 - Managed displays the DirectX mostFirst important Steps: Direct3D lines of the Basics clsAdvPlayer and DirectX vs.class: GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Enum enStatus Chapter Big 6 - Magic = 0 KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter Small 7 - Magic II: Animation Techniques and Speech API = KindergarteN. 1 Chapter End Enum 8 - .Netterpillars II: Multiplayer Games and Directplay
Public status AsMultithreading, enStatus =Nonrectangular enStatus.Big D-iNfEcT: Windows, and Access to -
Chapter 9
Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Shadows Sub Draw() Appendix IfA status - The State = of enStatus.Small PC Gaming Then
= in 0.2 Appendix B -ScaleX Motivations Games 0.2Games? Appendix C -ScaleY How Do I =Make When we theSuccessful image, Games the axis is scaled too, so we must: Appendix D -'Guidelines forscale Developing ' 1) move the object to (0,0), scale it and move it back ' - OR List of Figures ' 2) apply a new translation to balance the scaling List of Tables ' We use 2) here, because we don't need a generic routine TranslationX = X + 75 TranslationY = Y + 75 Else ScaleX = 1 ScaleY = 1 TranslationX = X TranslationY = Y End If MyBase.Draw() End Sub Index
To draw the player on screen, all we need to do is to add the following line to the Render procedure: Player.Draw()
Figure 6-24 shows a screen with the player character.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1 - 6-24: .Nettrix: GDI+ andisCollision Detection Figure The player finally shown on screen—in this case, inside the mouse hole. Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
As for the inventory control, since we have only two slots to carry objects (the right hand and the left hand), we - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio can choose a simpler way to control it: Instead of creating functions to pick an object from the inventory and then Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen using this object on other objects, we'll simply add new actions to our mouse pointer, showing icons of the Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow inventory objects. Once we have added a new action to the game pointer, we can use a procedure similar to the Chapter - Magic Animation and Speech API one we7saw in theKindergarteN. last section toII:execute the Techniques other actions. Chapter 4
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
To implement this solution, first we'llNonrectangular need to adjust Windows, our clsAdvPointer D-iNfEcT: Multithreading, and Access toclass to use two more statuses, which Chapter 9 Code carried, if any. The code for creating the new statuses and the updated cyclical will present Nonmanaged the objects being Bonus Chapter Porting in .Nettrix to Pocket routine is presented the next listing: PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Enum enStatus Appendix C - How Walk = 0Do I Make Games? Appendix D - Guidelines Examine = 1 for Developing Successful Games Index Take = 2
Use = 3 List of Figures Object1 = 4 List of Tables Object2 = 5 Wait = 6 End Enum Public Object1 As clsActiveObject = Nothing Public Object2 As clsActiveObject = Nothing Sub NextStatus() Status += 1 ' Only stay on status Object1 and Object2 if we are carrying objects If Status = enStatus.Object1 And Object1 Is Nothing Then Status += 1 End If If Status = enStatus.Object2 And Object2 Is Nothing Then Status += 1 End If ' We can go through all the mouse states, except wait If Status = enStatus.Wait Then Status = 0 ' restart End If End Sub
We'll need to update the status property procedure to update the PointerText property accordingly, and also
add new lines to the Draw method to draw the icon of the object in the inventory, as displayed in the next piece of .NET Game Programming with DirectX 9.0 code: by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Sub Draw() ... The authors of this text show how easy it can be to produce Case enStatus.Object1 interesting multimedia games using Managed DirectX 9.0 and objDirect3DDevice.SetTexture(0, programming with Visual Basic .NET on Everett, Object1.Icon.SpriteImage) the latest version of Microsoft's Visual Studio. Case enStatus.Object2 objDirect3DDevice.SetTexture(0, Object2.Icon.SpriteImage) ... Table of Contents End sub .NET Game Programming with DirectX 9.0 Foreword Preface In order to display our objects in the inventory, we'll need to create two extra active objects—RightHandObject Introduction andLeftHandObject—that will store the images to be displayed in the inventory. The real object of the Chapter 1 will - .Nettrix: GDI+ andmouse Collision Detection inventory be stored in the pointer, so we can access it easily when needed. Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites
When the executes the Take action on an Basics objectand thatDirectX can bevs. picked Chapter 3 -player Managed DirectX First Steps: Direct3D GDI+up, we must update the mouse
pointer class and that of the object. We'll always try to carry the object in the right hand. If it is occupied, we'll use - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio the left hand. If the left hand is also occupied, then we'll display the CantTakeText property. The full code for Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen theDoTake method is presented in the next code listing. It is executed when the player clicks an active object Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow with the Take mouse pointer. Chapter 4
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Sub DoTake(ByVal clickedObject As clsActiveObject) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterIf 9 clickedObject.CanTake Then Nonmanaged Code ' If the right hand is Bonus Chapter Porting .Nettrix to Pocket PC empty, store the object in it If RightHandObject Is Nothing Then Appendix A - The State of PC Gaming ' Set the right hand object to the icon of the object we took Appendix B - Motivations in Games ' All object icons are created by default over the right hand, Appendix C - How Do I Make Games? ' so the Render procedure will draw the object icon over this hand Appendix D - Guidelines for Developing Successful Games RightHandObject = clickedObject.Icon Index ' Set the pointer of the mouse to the object we took List of Figures Pointer.Object1 = clickedObject List of Tables ' The object will be invisible, since we take it clickedObject.Visible = False clickedObject.IsOnInventory = True ' If the left hand is empty, store the object in it ElseIf LeftHandObject Is Nothing Then ' Set the left hand object to the icon of the object we took ' so the Render procedure will draw the object over the hand LeftHandObject = clickedObject.Icon ' All object icons are created by default over the right hand, ' so we must translate the icon to make it appear over the left hand clickedObject.Icon.TranslationX = 84 ' Set the pointer of the mouse to the object we took Pointer.Object2 = clickedObject ' The object will be invisible, since we take it clickedObject.Visible = False clickedObject.IsOnInventory = True Else Say(clickedObject.CantTakeText) End If Say(clickedObject.TakeText) Else Say(clickedObject.CantTakeText) End If
End Sub .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
As we can see inHatton the previous listing, in the RightHandObject and LeftHandObject active objects we store Apress © 2003 (696 pages) only the icon of the object we are taking, so it can be drawn in the inventory. Referring to the previous sections, The authors of this text show how easy it can be the to produce remember that the icon for every object is already created with appropriated size and in the correct position to interesting multimedia games using 9.0toand be displayed in the right hand. To display it in the leftManaged hand allDirectX we have do is perform a simple translation on programming with Visual Basic .NET on Everett, the latest the x axis (that's why we set clickedObject.Icon.TranslationX to 84). version of Microsoft's Visual Studio. The full object is stored in the game pointer class for later use, and we set two flags with the object on screen. The of first one is to make the object invisible, and the second one is to inform the player that the object is in the Table Contents inventory. This last flag with will be used 9.0 repeatedly in the program. For example, in the collision detection routine, it is .NET Game Programming DirectX used to inform a procedure that this object should be ignored. Foreword Preface
The comments in the previous code listing should make it clear what each line is supposed to do.
Introduction
Chapter To draw 1 the - .Nettrix: objects GDI+ in the and inventory Collision (over Detection the corresponding hand), we must include some extra lines in the
Render as displayed the next listing: Chapter 2 procedure, - .Netterpillars: Artificial in Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 -are Rivercarrying Pla.Net: Tiledany Game Fields, Scrolling, DirectAudio ' If we objects, draw and them in the inventory Chapter If Not 5 RightHandObject - River Pla.Net II: DirectInput Is Nothing and Writing Then Text to Screen ChapterRightHandObject.Draw() 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
End If Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API If Not Is Nothing Chapter 8 LeftHandObject - .Netterpillars II: Multiplayer Games Then and Directplay
LeftHandObject.Draw() D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to End If - Nonmanaged Code
Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
The last part of our inventory handling routine is the creation of a special procedure—DoUseWith—to be called every time the user clicks an object icon over another object.
Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
Appendix - Guidelines for Developing Successful Games AlthoughD we could create specific code for every object action in this procedure, our experience tells us that most Index occurrences of using one object upon another can be reduced to a few simple questions: List of Figures
Object 1 (the carried object) be destroyed after using it with Object 2? List ofWill Tables Will Object 2 be destroyed after the action? Will a new object be created? These questions will allow us to address situations like the following: Using a glass with water and a flower: Destroy the glass with water, don't destroy the flower, and create a new object—a glass without water (so it will look like we have watered the flower). Using paper on a waste basket: Destroy the paper, don't destroy the basket, and don't create any objects. Using a magic wand on a mud monster: Don't destroy the wand, destroy the mud monster, and create a new object—a teacher. With a little imagination, we can use this approach to generically address many diverse situations. In our game, we created new properties in the clsActiveObject class and in the database, so we can handle these situations, as shown in the next code listing. The DoUseWith function, as with the analogous procedures show earlier in this chapter, must be called from the MouseUp event handling procedure, and will pass as parameters the clicked object, the mouse pointer object, and a Boolean value informing the procedure whether the object on the mouse pointer was in the right hand or the left, in the inventory.
Sub DoUseWith(Object1 As clsActiveObject, _ .NET Game Programming with DirectX 9.0 clickedObject As clsActiveObject, RightHand As Boolean) ISBN:1590590511 by Alexandre Santos Lobão and Ellen Dim i As Integer Hatton Apress © 2003 (696 pages)
' Checks if the clicked object is the one object1 can be used with The authors of this text show how easy it can be to produce Then If Object1.UsesWith.ObjectName = clickedObject.Name interesting multimedia games using Managed DirectX 9.0 and Say(Object1.UseWithOtherText) programming with Visual Basic .NET on Everett, the latest ' If we areofexpected to create version Microsoft's Visual Studio. a new object, then create it If Object1.UsesWith.CreateObjectAfterUse <> "" Then ' Create the new object on the screen Table of Contents CurrentScreen.ActiveObjects(CurrentScreen.ActiveObjectsNumber) = New _ .NET Game ProgrammingclsActiveObject(Object1.UsesWith.CreateObjectAfterUse) with DirectX 9.0 Foreword CurrentScreen.ActiveObjectsNumber += 1 Preface End If Introduction' If we must destroy the other object after using it, destroy it Object1.UsesWith.DestroyOtherAfterUse Then Chapter 1 -If .Nettrix: GDI+ and Collision Detection For i =Artificial 0 To Intelligence CurrentScreen.ActiveObjectsNumber - 1 Chapter 2 - .Netterpillars: and Sprites If Not Is Nothing Then Chapter 3 - Managed DirectX FirstCurrentScreen.ActiveObjects(i) Steps: Direct3D Basics and DirectX vs. GDI+ If Game CurrentScreen.ActiveObjects(i).Name = _ Chapter 4 - River Pla.Net: Tiled Fields, Scrolling, and DirectAudio clickedObject.Name Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Then CurrentScreen.ActiveObjects(i) = Nothing Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow clickedObject = Nothing Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Exit For Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End If D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 End If Nonmanaged Code Next Bonus Chapter Porting .Nettrix to Pocket PC End If Appendix A - The State of PC Gaming ' If we are expected to be destroyed after used, Appendix B - Motivations in Games ' then destroy the object from the inventory Appendix C - How Do I Make Games? If Object1.UsesWith.DestroyMeAfterUse Then Appendix D - Guidelines for Developing Successful Games Pointer.NextStatus() Index ' Destroy the object on the mouse pointer List of Figures Object1 = Nothing List of Tables ' Reset the object drawing on the inventory If RightHand Then RightHandObject = Nothing Else LeftHandObject = Nothing End If End If Else Say(Object1.CantUseWithOtherText) End If End Sub
In Figure 6-25 we can see the player getting the magic wand: It disappears from the screen and is displayed over the right hand, in the inventory section of the screen.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface
Figure 6-25: The player gets the wand, which is then stored in the inventory (right hand).
Introduction
Chapter 1 game - .Nettrix: GDI+ and Collision Detection Now our is complete. If we take the magic wand, a new icon will appear as our mouse pointer (a magic Chapter .Netterpillars: Intelligence Spritesthe character's teacher back to her normal self. Figure 6wand), 2and- we can use it Artificial on the mud monsterand to return Chapter 3 -the Managed DirectX Firstgame, Steps:when Direct3D Basics and DirectX vs. GDI+ 26 shows last screen of the the mission is completed. Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List ofFigure Tables 6-26: The game ending— Fiona is a nice witch again!
That's all for this chapter's sample game. We just finished our first adventure game, while creating a library of classes that can be used to build other analogous games as well.
Game Programming with DirectX 9.0 Adding the .NET Final Touches by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton In the next chapter we'll add some extra features to our game, such as including a dialog control to make Apress © 2003 (696 pages) the player character able to communicate with other characters in the game, and introduce Speech API and animation concepts so we can make our character his lips moving! The authors of this text show how easy ittalk—and can be to see produce interesting multimedia games using Managed DirectX 9.0 and programming withaVisual Basic .NET on Everett, the latest storyline using more complex As for this chapter's final touches, simple suggestion is a more complex version of Microsoft's Visual Studio. puzzles, with more situations, and more characters to improve the game.
Based on the same basic principles, here's a possible extended story, along with some new images drawn by Waldivar Cesar:
Table of Contents
.NET Game Programming with DirectX 9.0
The main character in our game will be a little boy, a magician's son, who is studying basic tricks in a magic kindergarten.
Foreword Preface
Introduction Natanael (that's his name) arrives one day at school and finds his pal, Michael, outside the school Chapter 1 Figure - .Nettrix: GDI+ and Collision (see 6-27). Michael tells himDetection that there's no one at school, and his father told him to stay here Chapter 2 wait - .Netterpillars: Artificial Intelligence and Sprites and for Fiona, their teacher. Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 6-27: Michael, a supporting character and Natanael's friend Natanael enters the school and finds no one there, just a big television that can play some movies, a magic book, and a box on the table. There is also a bucket on the floor (see Figure 6-28). He examines the magic book, and a page of the book falls on the floor. Natanael picks up the page. He looks at the page and sees that it's a magic potion for shrinking people, using a mushroom and water from a waterfall.
Figure 6-28: New objects— a box and a bucket Exiting from the school, Natanael decides to go into the forest to see if he finds anyone. He finds a mud monster near a tree that has a big hole in it. The monster tells him that, in fact, it is Natanael's
teacher, Fiona. Fiona was trying some metamorphosis tricks when she lost her magic wand, and she .NET Game Programming with DirectX 9.0 asks Natanael to find it for her. by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Natanael goes back to school and sees the magic wand inside a mouse hole, but he can't get it. He Apress 2003 (696 pages) then remembers the©shrinking potion. The authors of this text show how easy it can be to produce interesting multimedia games using Managed 9.0 and Going deeper into the forest, Natanael finds a place withDirectX many mushrooms. When he tries to get a with Visual on Everett, the latest unless he brings something in mushroom, aprogramming dwarf appears and saysBasic that .NET he can't get a mushroom version of Microsoft's Visual Studio. exchange (see Figure 6-29). The dwarf tells him that he wants a feather from an owl so that he can do some magic. Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 Figure - Magic KindergarteN. II:king Animation Techniques and Speech API 6-29: The dwarf, of the mushrooms Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -back to where the mud monster is, Natanael examines the hole in the tree, and finds an owl. Going Nonmanaged Code
hePorting tries to.Nettrix take thetoowl, all he BonusWhen Chapter Pocket PC gets is a feather, which he gives to the dwarf. He receives a mushroom exchange. Walking away from the forest, he finds a waterfall, but he has nothing to put Appendix A - The in State of PC Gaming the water in (see Figure 6-30).
Appendix B - Motivations in Games
Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 6-30: A waterfall in the forest Natanael goes to school and puts the mushroom in the bucket. He takes the bucket and goes back to the waterfall. Using the bucket at the waterfall, Natanael fills the bucket, which contains the mushroom, with water from the waterfall, making it a shrinking potion. He throws away (automatically) the magic page, since he doesn't need it anymore. Natanael drinks the potion and becomes small. He goes to school, and, when entering the mouse hole, he finds a mouse that doesn't let him take the wand (see Figure 6-31).
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
6-31:DirectX An armed Chapter 3 Figure - Managed Firstmouse Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5 - River Pla.Net DirectInput and Writing Text Screenagain, and grows. Looking at the box on Natanael comes out II: of the mouse hole and uses thetopotion Chapter - Magic KindergarteN.: Adventure Games, He ADO.NET, and DirectShow the6table, he opens it and finds some cheese. uses the potion once again, and enters the mouse Chapter hole 7 with - Magic the cheese. KindergarteN. WhenII: heAnimation gives theTechniques cheese to the and mouse, Speech it API becomes occupied with eating the
cheese, allowing Natanael to escape withand the Directplay wand. Chapter 8 - .Netterpillars II: Multiplayer Games D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Natanael uses the wand Nonmanaged Codeon the mud monster, and helps his teacher to get back to her normal form. Bonus Chapter Porting .Nettrix to Pocket PC
The images presented in this section are on the accompanying CD-ROM, so you can play with them and extend the game, creating your storyline and puzzles as needed. We'll use some elements of this new Appendix B - Motivations in Games storyline in the next chapter. Appendix A - The State of PC Gaming
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Summary
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
In this chapter, we Hatton reused our basic game classes, clsGameEngine and clsSprite, created in Chapter Apressof ©a 2003 (696 pages) 4, to construct a game totally different genre—an adventure game. Although very simple, this chapter sample helps youThe to understand the points you must take intobe account when creating adventures. We also authors of this text show how easy it can to produce interesting multimedia games using Managed DirectX 9.0 and discussed the following: programming with Visual Basic .NET on Everett, the latest of adventure Microsoft's games, Visual Studio. Some of the version history of including concepts associated with the creation of games of
this genre Table of Contents
The managed DirectShow component library, and the basic concepts of streaming media
.NET Game Programming with DirectX 9.0 reproduction Foreword
The creation of a new game class that handles the playing of streaming media Preface Introduction
Introduction of data access concepts in Visual Basic .NET, with the use of ADO.NET objects
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 -chapter, .Netterpillars: Artificial Sprites In the next we'll create a Intelligence new versionand of our game, including dialog handling—an essential part of Chapter 3 Managed DirectX First Steps: Direct3D Basics and the DirectX vs. GDI+ any adventure game. We'll also be exploring notions about animation of characters and looking at the Chapter - River Pla.Net: Tiled Game Fields,toScrolling, and DirectAudio Speech4 API, which will enable our games talk to us—and, eventually, to make them understand what Chapter 5 River Pla.Net II: DirectInput and Writing Text to Screen we are saying to them. Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Chapter .NET 7: Magic KindergarteN.ISBN:1590590511 II: Animation by Alexandre Santos Lobão and Ellen Hatton Techniques and Speech API Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio. In this chapter, we'll extend the adventure game created in the previous chapter to add dialog between the
Overview
player's character and game characters (see Figure 7-1). With these dialogs, we can extend the game puzzles and add one extra level of interaction to our game. Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - 7-1: Magic KindergarteN. II, this chapter's sample game Figure Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
We'll use this feature to introduce two new concepts: animation in games and the use of Speech API, which performs text-to-speech conversion and voice recognition. As usual, we'll create a new game class Appendix B - Motivations in Games to allow us to easily control the speech generation. Also as usual, we won't get too deep into these Appendix C -only Howgoing Do I Make Games? concepts, through enough information to enable us to create the sample game and do initial Appendix - Guidelines for Developing Successful Games steps in D speech generation and use of animation in games. Appendix A - The State of PC Gaming
Index
We'll begin with a look at some animation concepts that any game programmer must keep in mind when List of Figures designing a game. All of the drawings in this section are by the Slovenian game developer, cartoonist, and List of Tables graphical artist Igor Sinkovec, unless otherwise stated.
.NET Game Programming with DirectX 9.0 Character Animation in Games by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton"Well, I'm a programmer, I don't need to worry about character animations. That's You might be thinking, Apress artist, © 2003 right?" (696 pages) the job of the graphical Wrong! The authors of this text show how easy it can be to produce
Even if you were interesting born with no drawing skills all, and even ifDirectX you aren't planning to draw anything in your multimedia gamesatusing Managed 9.0 and with Visual Basic .NET Everett, latestunderstand your team of artists games, knowing programming some basic animation concepts willon help you tothe better of Microsoft's and improve yourversion communication withVisual theseStudio. team members. On the other hand, if you are a lone programmer, and you'll need to create your own art, these little tips may help you to create simple graphics with a professional touch.
Table of Contents
.NET Game Programming with DirectX 9.0
Foreword We don't include a full drawing course nor an advanced animation course. Many excellent books on these
topics are available to anyone who wants to master them; our goal here is just to introduce some concepts Preface that any serious gamer must know in order to create better game animations. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
In the following sections we present some character animation tips, exemplifying four of the most - .Netterpillars: Artificial Intelligence and Sprites important animation concepts: cycling, squashing and stretching, anticipation, and posture.
Chapter 2 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Animating Movements - River Cycling Pla.Net II: DirectInput and Writing Text to Screen
Chapter 5 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
One cannot talk about animation in games without mentioning cycling. First, this is because many of the - Magic KindergarteN. II: Animation Techniques and Speech API animations will be cycles executed in response to a player action, and second, we cannot create a game Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay like we would a TV cartoon—there are limits we must respect about the size and quantity of the D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to animations. Chapter 9 - The most obvious example of a cycling movement is a walking character: Every time the Nonmanaged Code player moves the input device in a different direction, the player character is shown to be walking by Bonus Chapter Porting .Nettrix to Pocket PC cycling through the animation (usually, a single step) many times. Chapter 7
Appendix A - The State of PC Gaming
Appendix B characteristic - Motivations inofGames The main an animation cycle is that the last position in the cycle is the same as the first Appendix one. A typical C - How game Do Ihas Make many Games? cycling animations: a jump (which starts and ends with the player character
standing), shooting sequence, and Successful so on. Because Appendix D -aGuidelines for Developing Gameseach game character must usually return to its initial position after an animation—in order to repeat or start a different animation—we can see that most, if not Index all,ofofFigures the animations used in games are cycles. List List of Tables
Each image that composes an animation is called a frame, and the most important ones are usually called key frames . A simple walking animation in a TV cartoon takes 12 frames on average, but in a game we can work with less ambitious numbers, depending mainly on the size of the character on screen and the level of detail required. Figure 7-2 presents an animated walking cycle with 10 frames.
Figure 7-2: A simple walking cycle, with 10 frames In games with small characters, we can usually cope with fewer frames. A cycle with 6 frames is okay if we don't need a realistic look and feel, and even cycles with 4 frames can work, if they're done particularly well. Earlier games had walking cycles with 3 or even 2 frames, but we would only recommend this be used today for games that are aiming for a "retro" look and feel. Figure 7-3 shows the same walking animation cycle presented earlier, but this time with only 4 frames.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Figure 7-3: A simple walking cycle, with 4 frames The authors of this text show how easy it can be to produce interesting multimedia Managed DirectX 9.0best and advice, if you're not an artist, is Now, how can a programmer apply thisgames idea inusing his or her games? The programming with Visual Basic .NET on Everett, the latest to find an artist toversion join your team. You can always do some rough sketches, however, to at least have an of Microsoft's Visual Studio. approximation of how your animation would work when testing your game before applying the final artwork. Because we can barely draw two parallel lines, we always have a sample at hand when Table beginning of Contents to draw, and we suggest you do the same. If you collect enough samples, you'll be able to create your own characters simply .NET Game Programming with by DirectX 9.0adapting the ideas from those samples. Foreword
In Figure 7-4, we show one of author's own sketches, based on Igor's sample walking man. It's no Renoir, but it sufficed for the first animation tests on a game we were working on, some years ago.
Preface
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 - 7-4: MagicAKindergarteN. II: Animation Techniques Figure 5-frames zombie boy animation cycle and Speech API Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Keep Note in mind the cycling concept, because we'll be using it throughout the next section, which Nonmanaged Code
will explain other animation concepts, starting with the idea of squashing and stretching characters when animating.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Animating Squashing and Stretching Motions
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games
Althoughsquash and stretch sounds like the name of a second-rate cartoon, it's actually a very important concept—one that will give your game a much more professional look.
Index
List of Figures
List of idea Tables The behind squashing and stretching characters is that game characters represent (somewhat) real
things, and as such, they are smooth and flexible. Usually a character squashes when it is pressed by gravity, when it finishes a jump, or when an anvil drops on it. A character stretches when something pulls it, such as gravity, if it starts falling, or if a rope is tied around its neck. Forgetting to incorporate these concepts in your animations will make your characters look like hard metal balls when they bounce against any obstacles. Compare the images in Figures 7-5 and 7-6 to see an example of this.
Figure 7-5: A squashing and stretching bouncing ball
Figure 7-6: The same bouncing movement, without squash and stretch We must use this same idea when animating characters, especially in jumping sequences and when
hitting (or being hit by) an obstacle. Figure 7-7 shows the same concept used for a jumping rabbit .NET Game Programming with DirectX 9.0 character. by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and with Visual Basic .NET on Everett, the latest Figure 7-7: Aprogramming squashing and stretching jumping rabbit version of Microsoft's Visual Studio.
Although we can create a jump by just moving a character up and down, including squashing and stretching will make that character much more lifelike. Looking at Figure 7-7, we can see that it's hard to Table of Contents imagine creating a jumping .NET Game Programming with character DirectX 9.0without using these concepts. Nevertheless, forgetting them is more common than you would think. For example, Mario and Luigi in the first Mario Brothers games jumped like Foreword bricks. Preface
Introduction Tip Including flexible parts with or on our characters—such as a tail, a feather on a hat, or the ears of Chapter 1our - .Nettrix: GDI+ and rabbit—that can beCollision moved Detection to emphasize the effects of momentum and gravity on the Chapter 2drawings - .Netterpillars: Artificial the Intelligence and Sprites can strengthen illusion of movement. Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Looking4 again at Pla.Net: Figure 7-7, we can see that the last and position is almost the same as the sixth one, except Chapter - River Tiled Game Fields, Scrolling, DirectAudio
for some weDirectInput simply copy the first five positions, in reverse order, after the current last one, Chapter 5 minor - Riverdetails. Pla.NetIfII: and Writing Text to Screen we'll have -aMagic complete jumping cycle that can be used along with any other animation. KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 6
Chapter 7 7-8 - Magic KindergarteN. II: Animation Techniques andIgor's Speech API In Figure we have tried to create a jumping rabbit using drawings, but without squashing and Chapter 8 .Netterpillars II: Multiplayer Games and Directplay stretching. The result is not very realistic, as you can see. Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games IndexFigure 7-8: Without squashing and stretching, the jumping rabbit looks like a statue. List of Figures
In the next section we discuss anticipation, an animation concept that works closely with squashing and List of Tables stretching to help us improve the movement of our game characters.
Animating Anticipation Anticipation is an animation concept based on observation of real movements. Although it sounds like an obvious concept, even today we see many commercial games that fail to include anticipation in their characters' animation. The basic idea is simple: Before starting any movement, a character will always do a "preparation" movement, usually in the opposite direction. For example, if the character is sitting down, before it stands up it will lower its head and shoulders a little, just like we would. If the character is going to run to the left, it will first gain momentum by moving a foot to the right. The most common example of anticipation is crouching before and after jumping, as we have already seen with the jumping rabbit in Figure 7-7. If we don't use anticipation when creating a jump, the result will be as unrealistic as the jumping rabbit in Figure 7-8. Any doubts? Just take a look at Figure 7-9, where we see the jumping rabbit without the anticipation frames.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce
Figure 7-9: Ainteresting jumping rabbit without anticipation multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Next we'll discuss another very important and widely overlooked animation concept: the use of correct character posture. Table of Contents .NET Game Programming with DirectX 9.0
Animating Posture to Reveal Emotions
Foreword
Preface The use of posture in our characters is directly associated with the characters' emotions. Basically, posture Introduction constitutes the "corporal language" used to express an emotion. Body language is universal—we needn't
explain1anything elseGDI+ in a game if we use this animation trick. Chapter - .Nettrix: and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Although using different character postures is not necessary in every game (its most commonly used - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ when creating adventure games), we must understand posture basics in order to guide character Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio animations for all games, if we want to add an extra feeling of reality. Will a particular character be a Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen happy, sad, or pompous person? Will that character get angry any time? Chapter 3
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 - Magic Animation andthe Speech API is that it's easier than it seems to Each emotion will KindergarteN. be associatedII: with a bodilyTechniques posture, and best part Chapter convey8these - .Netterpillars emotions using II: Multiplayer postures;Games this subject and Directplay has been considered by a great number of people
previously, and we now have a complete guide available in most D-iNfEcT: Multithreading, Nonrectangular Windows, and animation Access to books.
Chapter 9
-
Nonmanaged Code FigureChapter 7-10 shows two frames walking animations for a happy (or proud of itself) character and for a Bonus Porting .Nettrix to from Pocket PC
sad one.A - The State of PC Gaming Appendix Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 7-10: A happy and a sad character—which is which? Postures will reflect directly animation velocity too: A happy character will walk at normal pace, a sad character will usually walk a little slower, a creeping character will walk very slowly, and a character in a hurry, well, it'd usually run. If we extend the concept of character postures, we can encompass under the category "postures" different walking speeds: walking, running, running real fast, and so on. Figure 7-11 shows a sample of a running character.
Figure 7-11: A game character in a hurry In the next section, we'll look at some technical tips and lots of examples to help you in animating your games.
.NET Game Programming with DirectX 9.0 Technical Tips by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton some basic animation concepts, let's discuss some tips and guidelines for using Now that you understand Apress © 2003 (696 pages) them in your games. We'll start with the idea of animating parts of an image. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Animating Parts of an Image
Animating only parts of an image, rather than animating the full drawing, can lead to poor animation. Nothing is worse than a static guy whose mouth opens and closes when he talks, without any additional Table of Contents movement. However, knowing how to animate only specific parts of an image helps us create animations .NET Game with DirectX faster, andProgramming for those of us who aren't9.0 the next Monet, it may even improve the animation quality, as we'll Foreword see in the next paragraphs. Preface
Let's start with the example of the walking man animation cycle, shown earlier in Figure 7-2. If we look at this in detail, we see that the same image can be used for the head and the body; we'd only need to move Chapter 1 - .Nettrix: GDI+ and Collision Detection it up and down as the character walks. Figure 7-12 shows the same character, divided into three different Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites animations: body and head, arms, and legs. Introduction
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Figure 7-12: The walking cycle, divided into three different animations
Appendix B - Motivations in Games
Appendix - How Do I Make artists Games? AlthoughC skilled graphical don't need to use such a trick, it will help the rest of us a lot, since we'll Appendix - Guidelines have no Dproblem tryingfor toDeveloping repeat the Successful same headGames and body; that must look the same regardless of the Index setting. List of Figures
Forofgames List Tables with simple graphics, this tip will work wonderfully. Figure 7-13 shows the different body parts for a sketchy Viking character from an old game of ours.
Figure 7-13: Animations of different body parts for creating game animation cycles Figure 7-14 shows the character's final animation, based on the body parts shown in Figure 7-13.
Figure 7-14: A simple walking cycle, with 4 frames, a shooting animation, and a simple animation of
feet moving
.NET Game Programming with DirectX 9.0
by seen Alexandre Lobão and Ellen While the drawings in theSantos previous figures are very rough,ISBN:1590590511 they do demonstrate the point of creating Hatton animation using body parts. Apress © 2003 (696 pages)
As mentioned at the of this section, one part theitbody that The start authors of this text show how of easy can be todeserves produce special attention is the mouth. interesting Managed 9.0 mouth and If our character must speak multimedia during the games game, using we may wish toDirectX make his move accordingly, and programming Basic .NET on Everett, the latest that's what we'll discuss in the with next Visual section. version of Microsoft's Visual Studio.
Animating the Mouth
Table of Contents
.NET Game Programming with DirectX 9.0characters when speaking is one of the most challenging tasks in a To provide a realistic animation of our Foreword game. The easy part is synchronizing the mouth animations with the sound of the voice; a lot of references
(usually cartoon animation books) are available that will help you in associating the correct mouth position Preface with each syllable. The hard bit is including the gestures that reinforce the words, since every character Introduction must make gesturesGDI+ whenand speaking (unless, of course, it is a mummy or something like that). There are Chapter 1 - .Nettrix: Collision Detection also books explain how to create mouth animations Chapter 2 - that .Netterpillars: Artificial Intelligence and Sprites in 3-D characters, so we can improve the gestures moving the headFirst accordingly. Chapter 3 by - Managed DirectX Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Here we'll -only deal with the easy part, synchronizing mouth movement with sound, as this will suffice for
Chapter 5 - River Pla.Net DirectInput Writing Text to subject Screen for those who wish to study it further. this chapter's game and II: also act as an and introduction to the Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
There are ways of creating mouth animations, ranging from simpler ones (with 4 mouth positions Chapter 7 -various Magic KindergarteN. II: Animation Techniques and Speech API for the 8vowels and 5 mouth positions for groups ofDirectplay consonants) to very complex ones (with more than 20 Chapter - .Netterpillars II: Multiplayer Games and different mouth positions). D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to -
Chapter 9
Nonmanaged Code FigureChapter 7-15 shows a .Nettrix variationtoofPocket the mouth Bonus Porting PC positions used by Disney in its earlier movies (such as Snow
White and the Seven Dwarfs), which is ample for any game featuring speaking characters.
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 7-15: The mouth positions with their associated sounds Note Of course, the images in Figure 7-15 show the mouths for a specific head position; if the character is looking in any different direction (up, down, or wherever) we'll need new drawings, but those in Figure 7-15 are a very good starting point. Talking about starting points, in the next section we'll discuss animation guides, the starting point for any game animation.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming Compiling Animation Guideswith DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton As any good game programmer has his or her own set of game programming libraries, we can't forget the Apress © 2003 (696 pages) samples that will help us to create game-specific animations. importance of having a set of animation Even game artistsThe have such sets, rising to hundreds samples, because it's easier to look at authors of thissometimes text show how easy it can be toofproduce interesting games Managed DirectX andthe bottom up every time you a sample and create a new multimedia animation than to using remember every detail9.0 from programming with Visual Basic .NET on Everett, the latest need a new animation. version of Microsoft's Visual Studio.
While simple animations (like the walking and running samples we saw before) are very straightforward to create, some are not so simple. Figure 7-16 shows a simple guide for a character walking proudly, walking Table of Contents sadly, tiptoeing, and jumping. .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
7-16: A sample animation guide with some walking movements BonusFigure Chapter Porting .Nettrixof toan Pocket PC Appendix A - The State of PC Gaming
To be comprehensive, we must include in our animation guides every animation we can get our hands on: birds flying, four-legged animals moving, and characters using different kinds of objects, like the cyclist in Appendix C - How Do I Make Games? Figure 7-17. Appendix B - Motivations in Games
Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 7-17: An animation guide for bike-riding characters Note It's not in the scope of this book to include every animation guide from our personal libraries, mostly because many of them are samples from different copyrighted commercial games. However, we suggest the same approach: While you can't use copyrighted graphics from other games in your own games, as long as you have bought the games you can copy some animations (any screen capture utility will help with this) to your personal library, so they can serve as a basis for your own original graphics. Next we'll introduce the Speech API, the function set responsible for voice generation and recognition.
Game Programming with DirectX 9.0 Introducing.NET Speech API by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton interfaces (APIs) are present all over the Windows environment, offering high-level Application programming Apress © 2003 (696to pages) interfaces that allow applications access device features. By "device," we mean not only physical devices, such as joysticks The or graphics acceleration boards, but also logical authors of this text show how easy it can be to devices, produce like the ODBC or OLE DB devices interesting gamesthe using Managed DirectX 9.0 and for data access, or the focusmultimedia of this section, interface for speech engines.
programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio. Speech engines are special drivers that control speech recognition and/or speech generation (based on text).
You can buy the speech generation/recognition drivers, as data access drivers, from various providers, but the Speech API (SAPI) hides the specific details from each driver, allowing any application to use a simple set of Table of Contents functions to access every driver. To have access to the Speech API, we must install Microsoft's Speech SDK, .NET Game Programming with DirectX 9.0 which, besides installing the API, installs basic engines for voice recognition and generation. You can download Foreword the Microsoft Speech SDK for free from the Microsoft Web site, at Preface http://msdn.microsoft.com/downloads/default.asp?URL=/downloads/sample.asp? Introduction url=/MSDN-FILES/027/000/781/msdncompositedoc.xml, or simply by searching for the keywords Chapter 1 SDK" - .Nettrix: GDI+ and Collision Detection "Speech at http://msdn.microsoft.com/downloads. Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites Figure 37-18 depicts the relationship between an application and SAPI, Chapter - Managed DirectX First Steps: Direct3D Basics and DirectX vs. also GDI+showing the speech drivers and their
connection Chapter 4 - with RiverSAPI. Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - 7-18: Guidelines Developing Successful Games and speech engines Figure The for relationship between applications Index
As of shown in Figure 7-18, the Speech API provides access to two types of engines, text-to-speech (TTS) List Figures systems (to convert text strings and files into spoken audio) and voice recognition devices (which do the List of Tables opposite, converting human voice into strings and files). To ease access from Visual Basic and other COM applications, Microsoft developed a COM interface to access various functions from the API, which can be done by setting a reference to the SpeechLib DLL, installed with the speech SDK. A managed version has yet to be released at the time of writing this book, so we'll use the COM interface in this chapter. In the next sections we'll discuss the two basic engines provided by the Speech API, and then create a class to handle voice generation for our applications.
API for Speech Recognition A game that speaks is a common thing, but a game that can understand what you are saying is a true novelty. Discussing speech recognition in any great depth is beyond the scope of this book, but in this section we'll explain the basic concepts of recognizers and how they work, and then you can study the topic further in another book dedicated to the subject. All the complexity of speech recognition is handled by the speech engine and accessed by a simple COM interface to the SAPI functions. The main objects used for speech recognition are spInProcRecoContext, which handles a recognizer with full control and speed, and spSharedRecoContext, which shares a recognizer with other applications. Both objects have specific properties, methods, and events to help the programmer when creating a voice recognition application based on previously requested speech recognition events.
After creating the recognition context object and setting the events that will be handled, a speech application .NET Programming with DirectXmethod, 9.0 must create, load, andGame activate the recognition grammar ISpRecoGrammar. We can do this by calling by Alexandre Santos Lobão and Ellen theCreateGrammar method of the recognition context object,ISBN:1590590511 calling LoadDictation or LoadCmdxxx (to Hatton load a dictation utterance grammar or a command and control word grammar) from the grammar object, and Apress © 2003 (696 pages) finally calling SetDictationState or SetRuleState (depending on whether the program loaded a dictation The authors of this text show how easy it can be to produce or a command and control word grammar) to activate the grammar and start voice recognition. interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest The application will then of receive events with Studio. the results of the speech recognized, translated into text. version Microsoft's Visual
In the next section we'll discuss the voice generation engines in enough detail to allow us to create a voice generation application. Table of Contents .NET Game Programming with DirectX 9.0
API for Converting Text to Speech
Foreword Preface
To control text-to-speech (TTS) devices, after setting the proper reference to the SpeechLib reference, all we Introduction need to1do- is.Nettrix: to create an spVoice object and call the Speak method to generate the speech from text data. Chapter GDI+ and Collision Detection The complexity of the speech generation is soand wellSprites hidden from the application that we can create a "Hello Chapter 2 - .Netterpillars: Artificial Intelligence World" speaking application with only three lines, as shown in the next code sample: - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Dim voice As Pla.Net SpeechLib.SpVoice Chapter 5 - River II: DirectInput and Writing Text to Screen Set voice = New SpeechLib.SpVoice Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow voice.Speak "Hello World", SpeechLib.SpeechVoiceSpeakFlags.SVSFlagsAsync - Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 7 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to TheSpeak Chapter 9 - method can be called synchronously (the call of the method will only return after all the voice Nonmanaged Code
generation is done) or asynchronously (the method returns immediately, and the program continues to run while the voice is being generated), according to the second parameter passed to it. In the preceding code Appendix A - The State of PC Gaming sample, we are using the default voice, but we can choose the voice to be used according to the voices installed Appendix B - Motivations in Games method allows us to list all the voices if we want to. on our computer; the GetVoices Bonus Chapter Porting .Nettrix to Pocket PC
Appendix C - How Do I Make Games?
ThespVoice object also has some properties, methods, and events that will help us with controlling some of Appendix D - Guidelines for Developing Successful Games the speaking characteristics (like choosing the synthetic voice, the volume, or the speaking speed). We can also Index getoffeedback List Figures about what is being spoken with events that occur at every word end, at every viseme, or at custom bookmarks from the application. Visemes are mouth animations associated with the various speaking List of Tables sounds, or, as the Speech API help states, "viseme is a unit of speech that is detected in a spoken phrase." The core event we must handle to synchronize our mouth animations with the text being spoken is the Viseme event, which receives the following parameters: SpVoice.Viseme(StreamNumber As Long, StreamPosition As Variant, _ Duration As Long, NextVisemeId As SpeechVisemeType, _ Feature As SpeechVisemeFeature, CurrentVisemeId As SpeechVisemeType)
The parameters in the preceding code function as follows: StreamNumber is a unique number associated with the stream used to generate the voice (useful when the same spVoice object is generating more than one voice at the same time). StreamPosition is the character position where the viseme begins within the input stream. Duration is how much time the viseme will take to be spoken. NextVisemeId and CurrentVisemeType identify the next viseme and the current one, based on the SpeechVisemeType enumeration, which will help us to choose the proper mouth animation. Feature indicates the emphasis or stress of the viseme, being one of three possible values from the SpeechVisemeFeature enumeration: SVF_None (no stress or emphasis), SVF_Stressed (the viseme
is stressed compared to other visemes within the current word), or SVF_Emphasis (the current word has Game Programming with DirectX 9.0 an emphasis.NET in comparison to other words in the phrase). by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton The next code listing shows all possible values of the SpeechLib.SpeechVisemeType enumeration; each Apress 2003 (696 pages) sound for each value. Comparing the sounds of this enumeration with comment represents the© corresponding Thewe authors of this text how easy of it can to produce the mouth positions learned about atshow the beginning thisbe chapter, we see that there is no perfect match; multimedia games usingpositions Managedused DirectX 9.0 andspeaking animations; here we're but, as mentionedinteresting before, there are a lot of mouth to create programming with Visual Basic .NET on Everett, the latest only choosing theversion simplest ones that provide good results. of Microsoft's Visual Studio.
Enum SpeechVisemeType 'silence .NET Game Programming with 'ae DirectX SVP_1 = 1 ax9.0 ah Foreword SVP_2 = 2 'aa PrefaceSVP_3 = 3 'ao Introduction SVP_4 = 4 'ey eh uh ChapterSVP_5 1 - .Nettrix: = 5 GDI+ and 'er Collision Detection = 6 'y iyIntelligence ih ix and Sprites ChapterSVP_6 2 - .Netterpillars: Artificial = 7 DirectX'w ChapterSVP_7 3 - Managed Firstuw Steps: Direct3D Basics and DirectX vs. GDI+ = 8Pla.Net: Tiled 'ow ChapterSVP_8 4 - River Game Fields, Scrolling, and DirectAudio = 9Pla.Net II: 'aw ChapterSVP_9 5 - River DirectInput and Writing Text to Screen = KindergarteN.: 10 'oy Adventure Games, ADO.NET, and DirectShow ChapterSVP_10 6 - Magic SVP_11 = 11 'ay Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API SVP_12 = 12 'h Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay SVP_13 = 13 'r D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterSVP_14 9 = 14 'l Nonmanaged Code SVP_15 = 15 's z Bonus Chapter Porting .Nettrix to Pocket PC SVP_16 = 16 'sh ch jh zh Appendix A - The State of PC Gaming SVP_17 = 17 'th dh Appendix B - Motivations in Games SVP_18 = 18 'f v Appendix C - How Do I Make Games? SVP_19 = 19 'd t n Appendix D - Guidelines for Developing Successful Games SVP_20 = 20 'k g ng Index SVP_21 = 21 'p b m List of Figures End Enum
Table ofSVP_0 Contents = 0
List of Tables
Now we are ready to create a class that will generate speech based on text strings and generate events for calling applications that will allow us to create the mouth animations.
Creating a Speech Generation Game Class To add extra functionality to our speech generation class, besides the speech generation and events we saw in theprevious section, we'll create a method that translates the viseme codes into actual player images, chosen among predefined mouth positions stored as images. To generate these images, we'll simply apply the mouth positions we saw in Figure 7-15 to our character's head. Since the speaking head won't move (it's shown in a square at the bottom of the screen), we won't have to deal with more complex problems, like making the mouth move while the character is walking, or adding gestures that reinforce the speaking animation. Figure 7-19 presents the mouth animation we'll use in our game, drawn by the Brazilian graphical artist Waldivar Cesar.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5 - 7-19: River Pla.Net II:mouth DirectInput and Writing Text to Screen Figure Different animations for Natanael, our game character Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Besides7 a -method to load such images and the event to and handle the visemes, we'll add extra events for each Chapter Magic KindergarteN. II: Animation Techniques Speech API event generated by the spVoice object (for future use, if we want to use this class in other projects) and Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay methods to D-iNfEcT: speak, stop speaking, and pause voice generation. Multithreading, Nonrectangular Windows, and Access to -
Chapter 9
Nonmanaged Code
Table 7-1 shows the interface elements of the PlayerVoice class, which will wrap up the calls to the Speech API.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Table 7-1: PlayerVoice Class Interface Members
Appendix C - How Do I Make Games?
TYPE D - Guidelines NAME for Developing Successful DESCRIPTION Appendix Games Index
Voice
Represents the spVoice object from Speech API (private).
ListProperty of Tables
CurrentMouthType
Indicates a Sprite object that holds the image for the mouth type to be drawn.
Properties
NatanaelMouthxxx
Represent Sprite objects that store each of the possible mouth positions.
Method
New
Constitutes the class constructor, which initializes the spVoice object, chooses which voice will be spoken, and loads the mouth images.
Method
LoadMouthImages
Loads the sprite mouth animations.
Method
ListVoiceNames
Generates the VoiceName event, sending strings with each of the voice names (useful if an application wants to display a list to the user).
Method
Voice_Viseme
Serves as handler for the Viseme event of the spVoice method, sets the CurrentMouthType property, and generates the NewMouthType event.
Method
Speak
Receives a string and generates the speech.
Method
PauseSpeak
Pauses any speech that is running at the same time as another.
Method
ResumeSpeak
Resumes paused speaking.
Property
List of Figures
Method
StopSpeak Stops speaking. .NET Game Programming with DirectX 9.0
Methods
ISBN:1590590511 by Alexandre Santos Lobão and Ellen Voice_xxx Applies to all methods starting with "Voice_", which serve as Hatton handlers for the events generated by the spVoice object. We Apress © 2003 (696 pages) created the interfaces to make our class more complete, but The authors of this text show easy it can be to method produce has actual code. only how the Voice_Viseme
Event
programming with Visual Runs Basic .NET the latest VoiceName onceon forEverett, each voice installed on the machine, and version of Microsoft's Visual Studio. passes to the application a string with the voice name; this event is generated by the VoiceNamemethod.
interesting multimedia games using Managed DirectX 9.0 and
Table of Contents
Event
NewMouthType
.NET Game Programming with DirectX 9.0
Runs every time a new mouth position occurs when speaking; this event is generated by the Voice_Visememethod.
Foreword Preface
The final class interface, including the specific parameters for the spVoice event handlers, is shown in the next Introduction code listing: Chapter 1 - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 -SpeechLib Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Imports Chapter Imports 4 -Microsoft.DirectX.Direct3D River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Public clsPlayerVoice Chapter 6 Class - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ' Speech API objectII:interface Chapter 7 - Magic KindergarteN. Animation Techniques and Speech API WithEvents VoiceGames As SpVoice ChapterPrivate 8 - .Netterpillars II: Multiplayer and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter'9 We'll have two Nonmanaged Codeevents: one to list the existing voices,
' andPorting another that willPCbe fired every time the mouth format changes Bonus Chapter .Nettrix to Pocket Public As String) Appendix A - TheEvent State of VoiceName(VoiceName PC Gaming Public Event in NewMouthType(CurrentMouthImage As clsSprite) Appendix B - Motivations Games Appendix C - How Do I Make Games?
Public CurrentMouthType As clsSprite
Appendix D - Guidelines for Developing Successful Games Index
Private Private List of Tables Private Private Private Private Private Private Private Private Private List of Figures
NatanaelMouthFVD As clsSprite NatanaelMouthU As clsSprite NatanaelMouthLDTh As clsSprite NatanaelMouthWQ As clsSprite NatanaelMouthE As clsSprite NatanaelMouthMPB As clsSprite NatanaelMouthAI As clsSprite NatanaelMouthO As clsSprite NatanaelMouthCDG As clsSprite NatanaelMouthRest As clsSprite NatanaelMouthSilence As clsSprite
Private Sub LoadMouthImages() Private Sub Voice_Viseme(StreamNum As Integer, StreamPos As Object, _ Duration As Integer, VisemeType As SpeechVisemeType, _ Feature As SpeechVisemeFeature, VisemeId As SpeechVisemeType) _ Handles Voice.Viseme Sub New(strVoiceName As String) Sub ListVoiceNames() Sub PauseSpeak() Sub ResumeSpeak() Sub StopSpeak() Sub Speak(strTextToSpeak As String) Private Sub Voice_EndStream(StreamNum As Integer, StreamPos As Object) _ Handles Voice.EndStream
Private Sub Voice_StartStream(StreamNum As Integer, StreamPos As Object) _ .NET Game Voice.StartStream Programming with DirectX 9.0 Handles ISBN:1590590511 by Alexandre Santos Lobão and Ellen Private Sub Voice_VoiceChange(StreamNum As Integer, StreamPos As Object, _ Hatton Token As SpObjectToken) Handles Voice.VoiceChange Apress © 2003 (696 pages) Private Sub Voice_Word(StreamNum As Integer, StreamPos As Object, _ The of this text show how As easyInteger) it can be to Handles produce Posauthors As Integer, Length Voice.Word interesting multimedia games using Managed DirectX 9.0 and End Class programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
We are now ready to code the class methods. Table of Contents
Coding the New and .NET Game Programming withLoadMouthImages DirectX 9.0
Methods
Foreword
Let's start looking at the code from the New and LoadMouthImages methods, where we'll initialize the spVoice object and the sprites with the mouth animations.
Preface
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Sub New(strVoiceName As String) Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites ' Create the voice object - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Try Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Voice = New SpVoice() Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Catch ex As Exception Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow MessageBox.Show("Could not initialize Speech API. Error: " & _ Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API ex.Message, "SAPI Initialization.", MessageBoxButtons.OK, _ Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay MessageBoxIcon.Error) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterEnd 9 -Try Chapter 3
Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
' Change the voice to the selected one
Appendix A - The State of PC Gaming Try Appendix B Voice.Voice - Motivations in Games = Voice.GetVoices("Name = " & strVoiceName).Item(0) Appendix C - How Do I Make Games? Catch Appendix D -'Guidelines for Developing Games If we can't find Successful the named voice, simply pick the first one Index Voice.Voice = Voice.GetVoices().Item(0) List of Figures Finally List of Tables' Load the images for the mouth positions
LoadMouthImages() End Try End Sub Private Sub LoadMouthImages() Try NatanaelMouthFVD = New clsSprite("NatanaelMouthFVD.Bmp", _ New Point(156, 4), clsSprite.enScaleFactor.enScalePixel, NatanaelMouthU = New clsSprite("NatanaelMouthU.Bmp", _ New Point(156, 4), clsSprite.enScaleFactor.enScalePixel, NatanaelMouthLDTh = New clsSprite("NatanaelMouthLDTh.Bmp", _ New Point(156, 4), clsSprite.enScaleFactor.enScalePixel, NatanaelMouthWQ = New clsSprite("NatanaelMouthWQ.Bmp", _ New Point(156, 4), clsSprite.enScaleFactor.enScalePixel, NatanaelMouthE = New clsSprite("NatanaelMouthE.Bmp", _ New Point(156, 4), clsSprite.enScaleFactor.enScalePixel, NatanaelMouthMPB = New clsSprite("NatanaelMouthMPB.Bmp", _ New Point(156, 4), clsSprite.enScaleFactor.enScalePixel, NatanaelMouthAI = New clsSprite("NatanaelMouthAI.Bmp", _ New Point(156, 4), clsSprite.enScaleFactor.enScalePixel, NatanaelMouthO = New clsSprite("NatanaelMouthO.Bmp", _ New Point(156, 4), clsSprite.enScaleFactor.enScalePixel,
72, 72) 72, 72) 72, 72) 72, 72) 72, 72) 72, 72) 72, 72) 72, 72)
NatanaelMouthCDG = New clsSprite("NatanaelMouthCDG.Bmp", _ Game Programming with DirectX 9.0 New.NET Point(156, 4), clsSprite.enScaleFactor.enScalePixel, 72, 72) ISBN:1590590511 by Alexandre Santos Lobão and Ellen NatanaelMouthRest = New clsSprite("NatanaelMouthRest.Bmp", _ Hatton New Point(156, 4), clsSprite.enScaleFactor.enScalePixel, 72, 72) Apress © 2003 (696 pages) NatanaelMouthSilence = New clsSprite("NatanaelMouthSilence.Bmp", _ authors of this4), text show how easy it can be to produce NewThe Point(156, clsSprite.enScaleFactor.enScalePixel, 72, 72) interesting multimedia games using Managed DirectX 9.0 and Catch programming with Visual Basic .NET on Everett, the latest MsgBox(Err.Description ":"Studio. & Err.Number, MsgBoxStyle.OKOnly,_ version of Microsoft's &Visual "Error when loading mouth images") End Try Table Contents End ofSub .NET Game Programming with DirectX 9.0 Foreword
The only novelty in this sample code is the use of the GetVoices() collection of the Voice object to choose a Preface specific voice, according to the voice name, passed as an argument to the New method. The sprite initialization Introduction is the same one we've been using sinceDetection Chapter 4. (After all, that's the beautiful part of object Chapter 1 - .Nettrix: GDI+ and Collision orientation—improve the code andIntelligence reuse it! ) and Sprites Chapter 2 - .Netterpillars: Artificial Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Coding -the ListVoiceNames Method River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4
Chapter - River presumes Pla.Net II: that DirectInput and Writing Textthe to names Screen of the voices installed on the computer. To OurNew5 method the application knows Chapter - Magic KindergarteN.: ADO.NET, and DirectShow provide6a way for the applicationAdventure to get suchGames, a listing, we've added two members to our class: the Chapter 7 - Magic KindergarteN. Techniques and Speech API ListVoiceNames method andII: theAnimation VoiceName event. When the application calls this method, an event is Chapter 8 for - .Netterpillars II: Multiplayer and Directplay triggered each voice installed on theGames computer. The code for these two members is presented in the next
listing:
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
Public Event VoiceName(VoiceName As String)
Appendix A - The State of PC Gaming Appendix B - Motivations in Games Sub ListVoiceNames() Appendix - How Do I Make ' C Return all theGames? voice names through the VoiceName event Appendix D -Token Guidelines Developing Successful Games Dim Asfor ISpeechObjectToken Index List of Figures For Each Token In Voice.GetVoices List of TablesRaiseEvent VoiceName(Token.GetDescription())
Next Token End Sub
Coding the Speech Generation Methods Once the application knows which voice it wants to use and has created the Play-erVoice object, it'll use the methods to play, pause, resume, and stop voice generation as needed. The code for these methods is very simple, and it's shown in the next code listing: Sub PauseSpeak() Voice.Pause() End Sub Sub ResumeSpeak() Voice.Resume() End Sub Sub StopSpeak() ' Cancel current speech and clear internal buffers Voice.Speak(vbNullString, SpeechVoiceSpeakFlags.SVSFPurgeBeforeSpeak) End Sub
Sub Speak(strTextToSpeak As String) .NET Game Programming with DirectX 9.0 Voice.Speak(strTextToSpeak, DefaultSpeakFlags) ISBN:1590590511 by Alexandre Santos Lobão and Ellen End Sub Hatton Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and TheSpeak method of the spVoice object receives twoEverett, parameters: the string containing the text to be spoken, programming with Visual Basic .NET on the latest and a flag that will version tell usofhow Microsoft's to generate Visual the Studio. voice. We created a constant with the default behavior we want:
Generate the voice asynchronously and purge any previous voice being generated if we call the Speak method again. The constant definition is shown in the next code fragment:
Table of Contents
.NET Game Programming with DirectX 9.0
' Speak flags is a combination of bit flags Private DefaultSpeakFlags As SpeechVoiceSpeakFlags = _ Preface SpeechVoiceSpeakFlags.SVSFlagsAsync Or SpeechVoiceSpeakFlags.SVSFPurgeBeforeSpeak Foreword
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter When we 2 -call .Netterpillars: the Speak Artificial method,Intelligence the voice will and then Sprites be generated and our application will start receiving events
from the object. The First mostSteps: important of these events is the Viseme Chapter 3 Voice - Managed DirectX Direct3D Basics and DirectX vs. GDI+event, which is called every time a new sound started. In this event, set the CurrentMouthType Chapter 4 - is River Pla.Net: Tiled Gamewe Fields, Scrolling, and DirectAudio sprite to the corresponding mouth position loaded5previously and generate the NewMouthType event to inform the game that the new mouth position Chapter - River Pla.Net II: DirectInput and Writing Text to Screen must be onKindergarteN.: screen. Chapter 6 drawn - Magic Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Coding -the Viseme Event Handler .Netterpillars II: Multiplayer Games and Directplay
Chapter 8
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to In the next Chapter 9 -code sample we present the Viseme event. Look at the comments in each of the branches of the Nonmanaged Code
Case statement to see the relationship between the constants generated by the Speech API and the mouth positions previously created.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Private Sub Voice_Viseme(StreamNum As Integer, StreamPos As Object, _ Duration As Integer, VisemeType As SpeechVisemeType,_ Appendix D - Guidelines for Developing Successful Games Feature As SpeechVisemeFeature, VisemeId As SpeechVisemeType) _ Index Handles Voice.Viseme List of Figures Static PreviousMouthType As SpeechVisemeType = SpeechVisemeType.SVP_0 List of Tables ' Show different mouth positions according to the viseme Select Case VisemeId Case SpeechVisemeType.SVP_0 'silence CurrentMouthType = NatanaelMouthSilence Case SpeechVisemeType.SVP_3, _ SpeechVisemeType.SVP_10 'ao 'oy CurrentMouthType = NatanaelMouthO Case SpeechVisemeType.SVP_4 'ey eh uh CurrentMouthType = NatanaelMouthU Case SpeechVisemeType.SVP_7 'w uw CurrentMouthType = NatanaelMouthWQ Case SpeechVisemeType.SVP_1, _ SpeechVisemeType.SVP_2, _ SpeechVisemeType.SVP_8, _ SpeechVisemeType.SVP_9 'ae ax ah 'aa 'ow 'aw CurrentMouthType = NatanaelMouthAI Case SpeechVisemeType.SVP_11 'ay CurrentMouthType = NatanaelMouthE Case SpeechVisemeType.SVP_14, _ SpeechVisemeType.SVP_17 'th dh 'l CurrentMouthType = NatanaelMouthLDTh Case SpeechVisemeType.SVP_13, _ SpeechVisemeType.SVP_15, _ Appendix C - How Do I Make Games?
SpeechVisemeType.SVP_16, _ .NET Game Programming with DirectX 9.0 SpeechVisemeType.SVP_20
'r 's z 'sh ch jh zh 'k g ng ISBN:1590590511 by Alexandre Santos Lobão and Ellen CurrentMouthType = NatanaelMouthCDG Hatton Case SpeechVisemeType.SVP_18, _ Apress © 2003 (696 pages) SpeechVisemeType.SVP_19 'f v 'd t n The authors of this text show how easy it can be to produce CurrentMouthType = NatanaelMouthFVD interesting multimedia games using Managed DirectX 9.0 and Case programming SpeechVisemeType.SVP_21 'p b the m latest with Visual Basic .NET on Everett, CurrentMouthType = NatanaelMouthMPB version of Microsoft's Visual Studio. Case Else ' SpeechVisemeType.SVP_6, 'y iy ih ix Table of Contents ' SpeechVisemeType.SVP_12 'h .NET Game Programming with DirectX 9.0 = NatanaelMouthRest CurrentMouthType Foreword End Select Preface Introduction If PreviousMouthType <> VisemeId Then Chapter 1
= VisemeId -PreviousMouthType .Nettrix: GDI+ and Collision Detection
Chapter 2
NewMouthType(CurrentMouthType) -RaiseEvent .Netterpillars: Artificial Intelligence and Sprites
ChapterEnd 3 -If Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
End Sub Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Finishing the Speech Generation Class - Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 7
Chapter 8 -remaining .Netterpillars II: Multiplayer Games and Directplay As for the methods of the PlayerVoice class, which handle the spVoice events, we need to code D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to to the Silence position when the only the9 EndStream and the EndWord events to reset the mouth animation Chapter Nonmanaged Code
engine stops generating the voice. The other methods will be empty, to be coded if we need other features in other voice generation applications.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
The nextBcode piece shows the remaining methods of the PlayerVoice class: Appendix - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Sub Voice_EndStream(StreamNum As Integer, _ Index StreamPos As Object) Handles Voice.EndStream List of Figures ' Reset the mouth to silence position
CurrentMouthType = NatanaelMouthSilence List of Tables RaiseEvent NewMouthType(CurrentMouthType) End Sub Private Sub Voice_StartStream(StreamNum As Integer,_ StreamPos As Object) Handles Voice.StartStream ' Include here any code needed before character starts speaking End Sub Private Sub Voice_VoiceChange(StreamNum As Integer,_ StreamPos As Object, Token As SpObjectToken) Handles Voice.VoiceChange ' Include here any code needed when the voice changes End Sub Private Sub Voice_Word(StreamNum As Integer, StreamPos As Object,_ Pos As Integer, Length As Integer) Handles Voice.Word ' Include here any code needed when a new word is to be spoken End Sub
In the next section we discuss the proposal for the sample game of this chapter, including the concepts discussed in the previous sections.
.NET Game Programming with DirectX 9.0 The Game Proposal by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton For this project we'll extend the Magic KindergarteN. adventure game, including dialogs among the player's characterApress and the © 2003 game (696characters pages) and adding the PlayerVoice class we discussed in the previous section to make our character really speak. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and Visual Basic .NET onchapter, Everett, we'll the latest We won't changeprogramming the storyline with we saw in the previous just add dialogs between Natanael version of Microsoft's Visual Studio. and the mud monster, and add an extra character, a mouse, that will prevent Natanael from getting the magic wand unless he gives something to the mouse—maybe the big cheese on the table? Table of Contents All drawings use in this game were created by Waldivar Cesar (http://wace.cosmo.com.br), a .NET Game Programming with DirectX 9.0 Brazilian graphical artist, unless otherwise stated. Foreword
In the next section we'll discuss the dialogs and what we'll need to add to our game to implement them. Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Game Project by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Our game projectHatton will only describe the updates we must make to the previous chapter's project, plus the Apressbe © 2003 (696 pages) dialogs that now must created between the characters. The authors of this text show how easy it can be to produce
We have excluded the television and included a cheese in itsDirectX place to add interesting multimedia games using Managed 9.0 andan extra puzzle players must programming solve before getting the rod. with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Screens Table of Contents
We Game won't make changes to the screens .NET Programming with DirectX 9.0 created in the previous chapter; but we'll need to remove the dialogs used in the forest clearing from the screen presentation text, as the dialogs will now be performed Foreword when the player applies the Talk action. Preface Introduction
The new text for this screen could be something like this:
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Entering the forest, Natanael meets a mud monster. It seems to be a friendly monster.
Chapter 3 screen - Managed DirectX First the Steps: Direct3D Basics and DirectX vs. GDI+ All other text may remain same. Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
In the next we'll see the modifications to theText game characters. Chapter 5 -section River Pla.Net II: DirectInput and Writing to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
- Magic KindergarteN. II: Animation Techniques and Speech API Characters
Chapter 7 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
The game characters Natanael and Nonrectangular Fiona (the mudWindows, monster)and will Access remaintounchanged; but we'll include a D-iNfEcT: Multithreading, Chapter 9 Nonmanaged Codelives in the mouse hole. new character, a mouse that Bonus Chapter Porting .Nettrix to Pocket PC
The profile image the new character will be as follows: Appendix A - and The the State of PCfor Gaming Appendix B - Motivations in Games Appendix C - How I Make Games? Mouse: ThisDo character is a human-like mouse, named Sidney, that lives in the hole inside the magic Appendix kindergarten D - Guidelines (see for Figure Developing 7-20). He's Successful not a magic Gamesmouse, though. He isn't very friendly, and doesn't Index like visitors inside his hole; but he will get out of the way of the magic wand if he receives something in List ofexchange. Figures List of Tables
Figure 7-20: Sidney, the not-so-friendly mouse Table 7-2 describes the result of each action on Sidney. Table 7-2: Result of Each Action on Sidney the Mouse
ACTION
EXECUTE? TEXT .NET Game DISPLAY Programming with DirectX 9.0
Examine
YesHatton
Take
pages) No Apress © 2003I (696 can't take him!
Walk to
No interesting multimedia He won't let me walk way. DirectX 9.0 and games usingthis Managed
Use
No version of Microsoft's I don't want to fight! Visual Studio.
Talk
Yes
by Alexandre Santos Lobão and Ellen
ISBN:1590590511
It's a HUGE, armed mouse!
The authors of this text show how easy it can be to produce programming with Visual Basic .NET on Everett, the latest
Table of Contents
We'll also Programming need to update the mud monster's actions to allow Natanael to start a conversation with it, while .NET Game with DirectX 9.0 making sure all other objects don't talk. If the player character tries to talk to any nontalking object, we'll Foreword simply show the text "I can't talk with this" on screen. Preface Introduction
Now we'll discuss the updates of the game's active objects.
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Active -Objects Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 3 Chapter 4
River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio The active-objects remain the same, except for the television, which will be replaced by a cheese. Table 7-
Chapter 5 the - River Pla.Net II: DirectInput and Writing Text to Screen 3 shows results of each action on the cheese. Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7 - Results Magic KindergarteN. II: Animation Techniques and Speech API Table 7-3: of Each Action on the Cheese Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
SCREEN D-iNfEcT: OBJECTMultithreading, ACTION Nonrectangular EXECUTE? Windows, DISPLAY TEXT and Access to Chapter 9 1
Nonmanaged Code
cheese
Examine
Yes
It's a big cheese.
Appendix A - The State of PCTake Gaming
Yes
I'll take it, it may be useful.
No
I can't walk into a cheese!
Bonus Chapter Porting .Nettrix to Pocket PC Appendix B - Motivations in Games
Walk to
Appendix C - How Do I Make Games?
Use No Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Use with
Yes (with mouse)
No, thanks, I'm not hungry! The mouse is gone! I hope he enjoys the cheese!
In the next section we'll discuss dialog creation and describe the dialogs for each game character.
Dialogs The dialogs are an essential part of any adventure game; they are one of the main contributors to the ambience of a game, so special care must be taken when writing them to avoid jargon and create dialogs that represent the personality of each character. In a real game, besides many dialog paths we'll have many possible dialogs with each character, depending on the current status of the player. For example, a dialog with a pirate may be different if you have a sword or not in your inventory. Also, some dialog paths may be different according to whether you have talked with a specific character before—for example, you won't introduce yourself every time you start a new conversation. In our game we'll create a simple dialog that doesn't change in any situation, but this should be enough to give anyone the first steps for creating a more complex dialog structure, if needed. More sophisticated games will have different dialog paths associated with each game character, depending on specific conditions; for example, if your character is driving and a policeman asks for that character's license, we will have different dialog paths with the policeman depending on whether the character is carrying a license or not. Basically, we'll create "answer blocks" for each game character. Each of these blocks will be composed of
a question to be chosen by the player, the answer provided by the character, and the next block to be Game Programming with DirectX 9.0 displayed. When .NET starting to talk with a character, we'll present the questions from block number 0, and a by Alexandre Lobão Ellena dialog. ISBN:1590590511 next block with a special valueSantos (let's say -1) and will end Hatton © 2003 (696 pages) For example, let'sApress analyze answer block number 0 for the mud monster, presented in Table 7-4. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and Table 7-4: Mud Monster Answer Block 0 programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.ANSWER QUESTION QUESTION NEXT
NUMBER
ANSWER BLOCK
Table of Contents .NET withmy DirectX 0 Game Programming Hello, name9.0 is Foreword
Hi Natanael! I'm Fiona, your magic teacher!
1
Natanael. Who are you? Ahem ... Excuse me?
Yes? Oh, it's you, Natanael! !
1
Preface
1 Introduction
I'm your teacher, Fiona!
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
3 Chapter 5
Never Bye. and Writing Bloop! - River Pla.Net II:Mind. DirectInput Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
2
Ouch! A mud monster?? Where are you from?
Natanael! ! I'm your magic teacher, Fiona! Respect me!
1 -1
As we can see in this table, we have possible initial questions to ask the mud monster, numbered from 0 to - .Netterpillars II: Multiplayer Games and Directplay 3. The first three present the answer of the mud monster and then go to answer block number 1. The last D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter one interrupts 9 the dialog (next block number equals -1), so after the answer the dialog is over. Chapter 8
Nonmanaged Code
Bonus Portingthe .Nettrix to Pocket TableChapter 7-5 presents full dialog pathsPCfor the mud monster, whereas Table 7-6 presents the dialogs for Appendix A The State of PC Gaming Sidney the mouse. Appendix B - Motivations in Games Appendix C - Mud How Monster Do I MakeDialogs Games? Table 7-5: Appendix D - Guidelines for Developing Successful Games
ANSWER BLOCK
ANSWER SEQUENCE
QUESTION
ANSWER
0
0
Hello, my name is Natanael. Who are you?
Hi Natanael! I'm Fiona, your magic teacher!
1
0
1
Ahem ... Excuse me?
Yes? Oh, it's you, Natanael! !
1
Index
List of Figures List of Tables
NEXT ANSWER BLOCK
I'm your teacher, Fiona! 0
2
Ouch! A mud monster?? Where are you from?
Natanael! ! I'm your magic teacher, Fiona! Respect me!
1
0
3
Never Mind. Bye.
Bloop!
-1
1
0
Fiona? Is it really you? What happened to you?
I became a mud monster when practicing a new magic trick.
2
1
1
No, I can't believe you! How can I be sure?
Oh, please, just believe me!
2
I need your help!
1
2 .NET Game Programming Wow, that'swith great! Can 9.0 Natanael, it's not time DirectX you teach me how for fun! Can you help ISBN:1590590511 by Alexandre Santos Lobão and Ellento become a mud me? Hatton Apress © 2003 (696monster? pages)
2
1
text show how easy it can be to produce 3 The authors of this OK, and I'm Ronald Bye! interesting multimedia games using Managed DirectX 9.0 and Reagan. Bye! .NET on Everett, the latest programming with Visual Basic
-1
2
0
version of Microsoft's Visual Studio.
And how can I help you?
Table of Contents .NET Game Programming with DirectX 9.0
2
1
Foreword
I think I can help you later. Bye!
Preface
Please find my magic wand and bring it to me!
3
OK. But if you find my magic wand, please bring it to me!
-1
Thank you very much! Bye!
-1
Introduction
3 Chapter 1
0 OK, I'llDetection look for it! Bye! - .Nettrix: GDI+ and Collision
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Table 7-6: Sidney the Mouse Dialogs
Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ANSWER ANSWER QUESTION ANSWER Chapter BLOCK 7 - Magic SEQUENCE KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9 0
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to 0 Hello, my name is Humph! My name is Nonmanaged Code
NEXT ANSWER BLOCK 1
Natanael. Who are Bonus Chapter Porting .Nettrix to Pocket PC you? Appendix A - The State of PC Gaming
Sidney. What do you want here?
Appendix B - Motivations in Games Ahem ... Excuse me? 0 1 Appendix C - How Do I Make Games?
No. What do you want?
1
Appendix D - Guidelines for Developing Successful Games
0
2
Get away from here! I want this magic wand!
This is my hole! YOU get away from here!! Bye! !
-1
0
3
Never Mind. Bye.
So long!
-1
1
0
Would you please give me that magic wand?
Of course not! But I can exchange it for something else . . .
2
1
1
I want that magic wand.
Did I hear a "please"?
1
1
2
Get away from here! I want this magic wand!
No way! YOU'RE the one who must get out of here! Bye!
-1
1
3
Never mind. See you!
Bye!
-1
2
0
What do you want for the magic wand?
Just give me anything I can eat and I'll go away! Bye!
-1
2
1
No, I don't have anything for you! Just give me this magic wand!
No way! Get away and find something to trade! Bye!
-1
Index List of Figures List of Tables
2
2 .NET Game Programming No way. Bye! with DirectX 9.0OK, bye! If you have something for me, get ISBN:1590590511 by Alexandre Santos Lobão and Ellen back here! Hatton
-1
Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce
Once we've defined how themultimedia dialog structure work, a nonprogrammer member of the team can easily interesting games will using Managed DirectX 9.0 and create a table with programming possible dialog with paths—preferably, Visual Basic .NET onsomeone Everett, the deeply latestintegrated with the story so that he of Microsoft's Studio.in each dialog. or she can relateversion the correct characterVisual personality Now let's move on to the changes to the technical side of the game.
Table of Contents
.NET Game Programming with DirectX 9.0
User Interface Elements
Foreword Preface
Our game interface will remain the same, but we must define how dialogs will take place.
Introduction
Chapter Dialogs1will- .Nettrix: occur in GDI+ four steps: and Collision Detection Chapter 2 - game .Netterpillars: Artificial Intelligence andcurrent Spritesanswer block, presenting a button to the left of 1. The shows the questions from the Chapter each 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ question. Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio 2. The chooses specific question by clicking corresponding button. Chapter 5 - player River Pla.Net II: aDirectInput and Writing Text to the Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
3. The game presents the question chosen by the player, the answer from the character, and a button - Magic KindergarteN. II: Animation Techniques and Speech API to continue.
Chapter 7 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to 4. The Chapter 9 - player presses the Continue button, and then the game chooses the new answer block and goesNonmanaged back to step Code 1, or ends the dialog if the answer block number is -1. Bonus Chapter Porting .Nettrix to Pocket PC
This description will suffice for you or your team's programmer to add the code needed to control the Appendix A - The State of PC Gaming dialog. InB the next section we'll see the class diagram for the new version of the game. Appendix - Motivations in Games Appendix C - How Do I Make Games?
The Class Diagram
Appendix D - Guidelines for Developing Successful Games Index
We'll use the same classes expressed in the previous chapter, with the exception of the Video class, List of Figures which will be removed because our television was exchanged for a cheese. List of Tables We'll also add an extra class—the PlayerVoice class, presented earlier in this chapter—to handle the interaction with the Speech API. To test speech generation, we'll implement a new dialog feature in our game, so each object in the game will have two extra members: the CanTalk property, which states whether the object can talk, and a AnswerBlock() property array, to store answer blocks, which will be structured to support all data needed in a dialog. Figure 7-21 shows the new class diagram, including the updates discussed.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
BonusFigure Chapter Porting .Nettrix to Pocket PC 7-21: Magic KindergarteN. II class diagram Appendix A - The State of PC Gaming Appendix We'll now B -show Motivations the newindata Games model for our game, generated according to the properties of the game
classes.C - How Do I Make Games? Appendix Appendix D - Guidelines for Developing Successful Games
The Game's Data Model
Index
List of Figures
Figure 7-22 presents the data model for this new version of the game, including an extra table that will List of Tables store the dialog answer blocks.
Figure 7-22: Magic KindergarteN. II data model
.NET Game Programming with DirectX 9.0
by Alexandre Lobão and Ellen to control ISBN:1590590511 Note Our game code will Santos have specific updates the dialog flow, but most of the code will remain Hatton unchanged. Apress © 2003 (696 pages)
In the next sectionThe we'll see what's the how coding ofitMagic KindergarteN. version II. authors of thisnew text in show easy can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 The Coding.NET Phase by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton our coding phase into discrete steps, so we can focus on specific features to see what's Again, we have divided © 2003 pages) being done in thisApress update. The(696 steps in this chapter are simpler than the ones in the previous chapter, since the main code has already been done. We've divided phase into three steps: The authors of this text show how the easycoding it can be to produce games using Managed DirectX 9.0 and 1. First draft:interesting Adapt the multimedia ActiveObject class to handle dialog data, add the extra verb to the mouse programming with Visual Basic .NET on Everett, the latest pointer (atversion the AdvPointer class), and code the cheese puzzle. of Microsoft's Visual Studio.
2. Second draft: Include code for implementing dialogs with the game characters. Table of Contents
3. Final version: Add mouth animation and speech generation to the player character.
.NET Game Programming with DirectX 9.0
Foreword Now let's finish our ActiveObject class by including new properties and ADO.NET code to load data. Preface Introduction
First Draft: Updating the ActiveObject and the AdvPointer Classes, and - .Nettrix: GDI+ and Collision Detection Coding the Cheese Puzzle Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 1 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
In this first step all we need to do is create new properties for the ActiveObjectclass and add code to load - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio the dialog data from the game database.
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Adding -Dialog Support to Active Objects
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter .Netterpillars Multiplayer Games Directplay At first, 8we-must create aII: structure to store theand answer blocks. An active object will have an array of answer D-iNfEcT: Multithreading, Nonrectangular Windows, and Access toto four questions, one to four blocks, where each element will hold a complete block, comprised of one Chapter 9 Nonmanaged answers, and other fieldsCode as described earlier in this chapter. The code definition for the AnswerBlock Bonus Chapter PCcode piece: structure and Porting array is.Nettrix shown to in Pocket the next Appendix A - The State of PC Gaming Appendix B - Motivations in Games Structure stAnswerBlock Appendix C -Dim How Do I Make Games? QuestionNumber As Integer Appendix D -Dim Guidelines for Developing Successful Games PlayerQuestion() As String Index
Dim ObjectAnswer() As String
List of Figures Dim NextAnswerBlock() As Integer List of Tables End Structure
Public AnswerBlock() As stAnswerBlock
We'll load the answer blocks in the LoadData method, created in the previous chapter. The next code sample presents only the new lines of this method: Public Sub LoadData(DataReader As OleDbDataReader) Dim answerBlockCount As Integer = -1 Dim PreviousAnswerBlock As Integer = -1 Dim StrConnection = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & _ Application.StartupPath & "\Data\KinderData.mdb" Dim Conn As OleDbConnection Dim CmdDialog As OleDbCommand Dim DataReaderDialog As OleDbDataReader Dim AnswerSeq As Integer ... CanTalk = DataReader.GetBoolean(Fields.CanTalk) CantTalkText = DataReader.GetString(Fields.NoTalkText) ' Load the Dialog - Use a fixed size of 4, since we don't know previously _
the size of the answer block .NET Game Programming with DirectX 9.0 Conn = New OleDbConnection(StrConnection) ISBN:1590590511 by Alexandre Santos Lobão and Ellen Conn.Open() Hatton CmdDialog = Conn.CreateCommand() Apress © 2003 (696 pages)
The dialogs authors of this show how easyobject it can be number to produce ' Read all fortext the current interesting multimedia games using Managed DirectX 9.0 and CmdDialog.CommandText = "SELECT * on from Dialog where ObjectNumber = " & _ programming with Visual Basic .NET Everett, the latest DataReader.GetInt32(1) & _ version of Microsoft's Visual Studio. " order by AnswerBlock, answerSeq" Table ofDataReaderDialog Contents = CmdDialog.ExecuteReader .NET Game Programming with DirectX 9.0 Do While DataReaderDialog.Read() Foreword
' Create the answer blocks if there's any dialog for the current object If answerBlockCount = -1 Then Introduction ReDim AnswerBlock(4) If GDI+ and Collision Detection Chapter 1 -End .Nettrix: Preface
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
DataReaderDialog.GetInt32(_ -If Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
DialogFields.AnswerBlock)>PreviousAnswerBlock Then - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
= _Writing Text to Screen - RiveranswerBlockCount Pla.Net II: DirectInput and
DataReaderDialog.GetInt32(DialogFields.AnswerBlock) PreviousAnswerBlock = answerBlockCount Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API ReDim AnswerBlock(answerBlockCount).PlayerQuestion(4) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay ReDim AnswerBlock(answerBlockCount).ObjectAnswer(4) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 ReDim AnswerBlock(answerBlockCount).NextAnswerBlock(4) Nonmanaged Code End If Bonus Chapter Porting .Nettrix to Pocket PC AnswerSeq = DataReaderDialog.GetInt32(DialogFields.AnswerSeq) Appendix A - The State of PC Gaming AnswerBlock(answerBlockCount).QuestionNumber += 1 Appendix B - Motivations in Games AnswerBlock(answerBlockCount).PlayerQuestion(AnswerSeq) = _ Appendix C - How Do I Make Games? DataReaderDialog.GetString(DialogFields.PlayerQuestion) Appendix D AnswerBlock(answerBlockCount).ObjectAnswer(AnswerSeq) - Guidelines for Developing Successful Games = _ Index DataReaderDialog.GetString(DialogFields.ObjectAnswer) List of Figures AnswerBlock(answerBlockCount).NextAnswerBlock(AnswerSeq) = _ List of Tables DataReaderDialog.GetInt32(DialogFields.NextAnswerBlock) Loop End Sub Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Note Because we didn't need to modify any of the class interfaces, we won't need to update the code that is creating the active objects; the program is ready to run, but at the moment there is no visible difference.
Creating the Mouse Pointer for the Talk Action To update the mouse pointer, we'll have to add an extra verb to the AdvPointer class; we'll do this by simply copying a line of the code into all methods that deal with the various pointers and adapt it to reflect the change. For example, we'll need to create a new sprite, TalkIcon, to store the new mouse pointer, and add an extra line in the new procedure: TalkIcon = Load("IconTalk.Bmp", Color.FromArgb(255, 255, 0, 255))
Similarly, we'll need to create a new string property, TalkText, to store the verb used for talking (remember, it could be "falar", if we are translating it to Portuguese), and add one extra line to load the verb string from the database in the ReadVerbsprocedure:
TalkText = DataReader.GetString(2) .NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Finally, we'll need to create a new member of the enStatus enumeration to represent the status of the Talk Apress © 2003 (696 pages)
action, and include one extra case clause in the Draw method:
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and with Visual Basic .NET on Everett, the latest Caseprogramming enStatus.Talk version of Microsoft's Visual Studio. objDirect3DDevice.SetTexture(0, TalkIcon)
Table of Contents .NET Game Programming with DirectX 9.0
Since these changes are very simple, we'll not reproduce the complete code of the class here; its logic remains
Foreword the same—we just included one extra state for the mouse pointer. The dialog icon is shown in Figure 7-23. Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Figure- 7-23: The dialog mouse pointer River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 -the Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Coding Cheese Puzzle Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API The last update we'll is to include code implement the cheese puzzle: If the mouse is in our way, we Chapter 8 small - .Netterpillars II: do Multiplayer Games andtoDirectplay
can't take the magic wand. If we giveNonrectangular the cheese to Windows, Stanley, the D-iNfEcT: Multithreading, andmouse Accesswill to go away, and we can then take the Nonmanaged Code wand.
Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC
Since the willGaming only say if a specific object (in this case, the magic wand) simply can or can't be Appendix A database - The Statedata of PC
taken, we'll need an extra variable to control this specific feature in the DoTake method: We'll create a Boolean variable that is false by default, and is set to true only if the cheese is given to the mouse.
Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games The updates to implement the cheese puzzle are described in the next code listings, starting with the code for Index theDoTake method: Add one extra test to see if the MouseIsHere variable is set, and if so, we can't take the List of Figures magic wand. List of Tables
' Status variables to control the puzzle solving ' - as for now, only to control if the mouse in the way Private MouseIsHere As Boolean = True Sub DoTake(clickedObject As clsActiveObject) If clickedObject.CanTake Then ' If it is the magic wand, we only can take it if there's no mouse ' in the way If clickedObject.Name = "magic rod" And _ MouseIsHere Then Say(clickedObject.CantTakeText) Else ... End Sub
Then we'll need to add some lines of code to the DoUseWith method to reset this variable: one extra test to see if we can use something with the mouse (only the cheese can be used with the mouse), and if so, set MouseIsHere to false. Sub DoUseWith(Object1 As clsActiveObject, clickedObject As clsActiveObject, _ RightHand As Boolean)
If Object1.UsesWith.ObjectName = clickedObject.Name Then Programming with DirectXwith 9.0 the mouse,_ '.NET If Game we are using the cheese ISBN:1590590511 by Alexandre Santos Lobão and Ellen solve the puzzle by setting the variable Hatton If Object1.UsesWith.ObjectName = "mouse" Then Apress © 2003 (696 pages) MouseIsHere = False The authors of this text show how easy it can be to produce End If interesting multimedia games using Managed DirectX 9.0 and ... programming with Visual Basic .NET on Everett, the latest End Sub version of Microsoft's Visual Studio. Table Contents This of kind of code, which adds one variable to control a game state, may not appear to be obvious straight away. .NET In fact, Game it's Programming not, but there's with noDirectX other way 9.0 to deal with special situations in the game. We'll create a generic class
that will handle most of the situations, and eventually we'll need to create a "state" class that will store the Foreword control variables for all special cases. Preface Introduction
To include all state variables in a class will help us with controlling these exceptions, but since here we have - .Nettrix: GDI+ and Collision Detection only one special case, we implement the control in a variable. The use of classes to control these situations Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites also has an added attraction: It gets easier to implement a saved game feature that stores the current player Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ status. Chapter 1
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter Figure 57-24 - River presents Pla.Net ourII: first DirectInput test on this and version Writing ofText the game, to Screen when we are just about to give the cheese to the
mouse.6 Chapter
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 7-24: There's nothing like cheese to get a mouse out of the way. In the next section, we'll code the dialog logic, and then we'll see the new data we are loading into the active objects.
Second Draft: Coding the Dialogs If we review the code from the MouseUp event from the previous chapter, we'll see that we have a simple Select Case statement that executes the corresponding functions that will do the real work for each verb action. Our dialog will start the same way: If the player clicks an active object with the Talk mouse pointer, we'll call the DoTalk method, which will start the dialog control. The next code listing presents the updated version of the MouseUp event of the KinderEngine class: Sub Mouse_MouseUp(X As Integer, Y As Integer, Button As ClsMouse.enButton) _ Handles Mouse.MouseUp Dim clickedObject As clsActiveObject
If Button = ClsMouse.enButton.Left And GameStatus = enGameStatus.Normal Then .NET Game Programming with DirectX 9.0 Cursor.NextStatus() ISBN:1590590511 by Alexandre Santos Lobão and Ellen Else Hatton TestCollision(clickedObject) Apress © 2003 (696 pages) If Not clickedObject Is Nothing Then The authors of this text show how easy it can be to produce Select Case Cursor.Status interesting multimedia games using Managed DirectX 9.0 and Case clsAdvCursor.enStatus.Examine programming with Visual Basic .NET on Everett, the latest DoExamine(clickedObject) version of Microsoft's Visual Studio. Case clsAdvCursor.enStatus.Take DoTake(clickedObject) Table of Contents Case clsAdvCursor.enStatus.Use .NET Game Programming with DirectX 9.0 DoUseAlone(clickedObject) Foreword Case clsAdvCursor.enStatus.Walk Preface DoWalk(clickedObject) Introduction Case clsAdvCursor.enStatus.Talk 0) Chapter 1 - .Nettrix: GDI+ and DoTalk(clickedObject, Collision Detection Case clsAdvCursor.enStatus.Object1 Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites DoUseWith(Cursor.Object1, True) Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectXclickedObject, vs. GDI+ Case Chapter 4 - River Pla.Net: TiledclsAdvCursor.enStatus.Object2 Game Fields, Scrolling, and DirectAudio DoUseWith(Cursor.Object2, Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen clickedObject, False) End Select Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow End If Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API End If Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Sub Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State will of PC Gaming TheDoTalk method execute the first of the four steps in a dialog control, as we saw previously in this Appendix B Motivations in Games chapter; it'll receive the number of the answer block to present on screen. Since we'll always start with block Appendix How Do the I Make Games? number C0,-we zero second argument when calling it to start a dialog. Appendix D - Guidelines for Developing Successful Games Index Presenting
the Dialog Choices on Screen
List of Figures
Before entering the code of DoTalk and the other helper methods, let's review the four steps of a dialog:
List of Tables
1. The game shows the questions from the current answer block, with a button at the left side of each question. 2. The player chooses a specific question by clicking the corresponding button. 3. The game presents the question chosen by the player, the answer from the character, and a button to continue 4. The player presses the Continue button, and the game then chooses the new answer block and goes back to step 1, or ends the dialog if the answer block number is -1. To implement these steps, we'll code the following methods in the KinderEngine class: DoTalk: If we can talk with the object, this method presents the questions and buttons on screen and stores the object we are trying to talk to in a variable so we can use it later in other methods. DoSimpleClick: This method will handle the player's click of a specific question button and present the corresponding answer on screen, implementing steps 2 and 3. It'll also check if the button clicked is the Continue button and, if so, call the DoTalk method again and pass the next answer block as a parameter, or call the EndDialog method to end the dialog. EndDialog: This method cleans up the code and displays the screen presentation text again, resetting the
game from dialog mode to normal mode.
.NET Game Programming with DirectX 9.0
ISBN:1590590511 Alexandre Santos and Ellen Besides creating by these methods, we'llLobão also need to make some updates to many other methods. For instance, to implement theHatton DoTalk method as discussed, we'll need to add extra class members (the buttons) and add Apress © 2003 pages) code to the Initialize and(696 Draw methods to create and draw the buttons on screen (four buttons for dialog The"continue" authors ofbutton), this textwhen showthey how are easyvisible. it can We'll be to produce answers, one extra also need an extra class member to store the games using Managed DirectX 9.0 and current object weinteresting are talkingmultimedia to.
programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Therefore, to implement the DoTalk method, the updates to the KinderEngine class are shown in the subsequent code fragment: Table of Contents .NET ' Dialog Game Programming control buttons with DirectX 9.0
Private DlgButton() As clsActiveObject Foreword ' The Object we are talking to Preface Private DlgObject As clsActiveObject Introduction ' Dialog control helper variables Chapter 1 - .Nettrix: GDI+ and Collision Detection Private As Integer Chapter 2 -CurrentAnswerBlock .Netterpillars: Artificial Intelligence and Sprites Private -NextAnswerBlock As Integer Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Function Initialize(Owner as Windows.Forms.Control) As Boolean - River Pla.Net II: DirectInput and Writing Text to Screen Redim DlgButton(4) Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ... Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API ' Initialize the game text fields and buttons Chapter For 8 - .Netterpillars i = 0 To II: 3 Multiplayer Games and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - Text(i) = New ClsGameFont("Microsoft Sans Serif", 14, Space(120), _ Nonmanaged Code New Point(252, 525 + i * 18)) Bonus Chapter Porting .Nettrix to Pocket PC ' Load the dialog control buttons Appendix A - The State of PC Gaming DlgButton(i) = New clsActiveObject("button.bmp",_ Appendix B - Motivations in Games New Point(232, 5 + i * 18), _ Appendix C - How Do I Make Games? clsSprite.enScaleFactor.enScalePixel, 16, 16) Appendix D - Guidelines for Developing Successful Games DlgButton(i).Name = "Dialog " & (3 - i).ToString Index DlgButton(i).Visible = False List of Figures Next ' Initialize the button for controlling the dialog List of Tables DlgButton(4) = New clsActiveObject("button.bmp", New Point(232, 5), _ clsSprite.enScaleFactor.enScalePixel, 16, 16) DlgButton(4).Name = "Continue" DlgButton(4).Visible = False End Function Chapter 5
Public Sub Draw() Dim i As Integer ... ' Draw the dialog buttons (will be drawn only if visible) For i = 0 To 4 DlgButton(i).draw() Next End Sub Sub DoTalk(clickedObject As clsActiveObject, AnswerBlock As Integer) Dim i As Integer If clickedObject.CanTalk Then DlgObject = clickedObject CurrentAnswerBlock = AnswerBlock For i = 0 To DlgObject.AnswerBlock(0).QuestionNumber - 1 Text(i).Text = _
DlgObject.AnswerBlock(CurrentAnswerBlock).PlayerQuestion(i) .NET Game Programming with DirectX DlgButton(i).Visible = True9.0 by Alexandre Santos Lobão and Ellen Next
Else
ISBN:1590590511
Hatton Apress © 2003 (696 pages)
Say(clickedObject.CantTalkText) End If End Sub
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
As we can see in the preceding code, the DoTalk procedure will check whether the object can talk, and if so, Table of Contents update the screen text with the questions read from the answer block depending on which number is received .NET as aGame parameter. Programming The procedure with DirectX also9.0 sets the visible property of the question buttons to true, so the next call to
theDraw method will show the updated text and buttons. In the Drawmethod, we don't need to test for the Foreword visible property, since this test is already done inside the Sprite class—when a sprite is not visible, it simply Preface won't draw its image automatically. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
As you can see, the buttons have been named "Dialog 0" to "Dialog 3" and "Continue". These names are - .Netterpillars: Artificial Intelligence and Sprites important because we'll need them to check which button has been pressed in the DoSimpleClick method.
Chapter 2 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 the - River Pla.Net:Choose Tiled Game Fields, Scrolling, andSpeech DirectAudio Letting Player the Character's Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
The next implement, DoSimpleClick, will process click of any of the buttons and will also Chapter 6 method - Magic to KindergarteN.: Adventure Games, ADO.NET, andthe DirectShow involve modifying other points of the KinderEngine class, such as the TestCollision method, which will Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API need to include one special treatment for clicking the objects. We need to do this update because the buttons Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay aren't related to a specific screen, and the code we created for the TestCollision method only tests the D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 active objects on the current screen. Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
Having two sets of objects when calculating the collision detection raises an interesting question: What happens if the player, in the middle of a dialog, clicks another object on screen, executing another action or even starting Appendix B - Motivations in Games a new dialog? Appendix A - The State of PC Gaming
Appendix C - How Do I Make Games?
Appendix D - Guidelines Successful Games The answer is simple: for WeDeveloping can't let the player start any other action when in conversation with a character. In Index order to know whether the player character is talking or not, we'll include a new control, the game state, which List willofbasically Figures allow the player to click the objects on screen only if not in dialog mode. List of Tables
To create this state, we'll need to define a new enumeration and create a variable that will store the current game status, as shown in the next code listing: ' Control the game status - normal or dialog Enum enGameStatus Normal = 0 Dialog = 1 End Enum Public Shared GameStatus As enGameStatus = enGameStatus.Normal
We'll also need to create a new state in the advPointer class, an arrow pointer, which will be used when in dialog mode. The changes to this class are simple and follow the same pattern discussed previously to include the dialog icon. Figure 7-25 presents the icon used for the arrow pointer.
Figure 7-25: The arrow mouse pointer In the DoTalk procedure, we'll need to add two extra lines when showing the dialog buttons to set the proper game state and mouse pointer.
GameStatus = enGameStatus.Dialog .NET Game Programming with DirectX 9.0 Pointer.Status = clsAdvPointer.enStatus.Arrow ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton © 2003 pages) This variable will Apress be reset only(696 in the EndDialog method, when the dialog ends, and must be checked in the The authors this text how when easy itthe canleft be button to produce MouseUp event so the mouseofstate isn'tshow changed is pressed, and the DoSimpleClick multimedia games using andin the Render method to refrain method is called interesting if the right button is pressed. We'll Managed also needDirectX to add9.0 code programming with Visual Basic .NET on Everett, the latest from updating theversion status of line, even if the mouse pointer moves over a button—the button's name is not to be Microsoft's Visual Studio.
visible to the player! The code to be included in these functions is as follows:
Table Contents Sub ofMouse_MouseUp(X As Integer, Y As Integer, Button As ClsMouse.enButton) _ .NET Game Programming with Mouse.MouseUp DirectX 9.0 Handles Foreword Dim clickedObject As clsActiveObject Preface Introduction If Button = ClsMouse.enButton.Left And GameStatus = enGameStatus.Normal Then Chapter 1 -Pointer.NextStatus() .Nettrix: GDI+ and Collision Detection ChapterElse 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
TestCollision(clickedObject) - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
Not Tiled clickedObject Is Nothing Then - RiverIf Pla.Net: Game Fields, Scrolling, and DirectAudio
Chapter 5
Select Case Pointer.Status - River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
CaseAdventure clsAdvPointer.enStatus.Examine - Magic KindergarteN.: Games, ADO.NET, and DirectShow
DoExamine(clickedObject) ... Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Case clsAdvPointer.enStatus.Arrow D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 DoSimpleClick(clickedObject) Nonmanaged Code End Select Bonus Chapter Porting .Nettrix to Pocket PC End If Appendix A - The State of PC Gaming End If Appendix B - Motivations in Games ... Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games
End Sub
Index List of Figures Sub Render() List of Tables ...
' Updates the status line only if we are not in Dialog mode If GameStatus = ClsKinderEngine.enGameStatus.Normal Then StatusText.Text = StatusText.Text & Pointer.PointerText If Not ClickedObject Is Nothing Then StatusText.Text = StatusText.Text & ClickedObject.Name End If End If End Sub
Now we are finally ready to update the TestCollision method to test the buttons, when in dialog mode, so we can have the right "clicked object" variable in the MouseUp event. The next code listing shows the full code for TestCollision so that we can compare the collision algorithm for the buttons (first if clause) with the algorithm for the active objects (the else clause). As we can see, they are almost the same; the only difference is that in the first case we are checking the mouse pointer coordinates against the DlgButton array, and in the second, we are checking the CurrentScreen.ActiveObjects array. Private Sub TestCollision(ByRef ClickedObject As clsActiveObject) Dim i As Integer ClickedObject = Nothing If GameStatus = ClsKinderEngine.enGameStatus.Dialog Then
' Test the collision with the dialog buttons Programming with DirectX 9.0 For i.NET = 0Game To 4 ISBN:1590590511 by Alexandre Santos Lobão and Ellen With DlgButton(i) Hatton If Pointer.X >.X And _ Apress © 2003 (696 pages) Pointer.X <.X + .Width Then The authors of this text show how it can be since to produce ' We increment the Y easy position the coordinates are inverted interesting multimedia games using Managed DirectX 9.0 and ' (Ywith equals 0 on.NET theonlower of the image) programming Visual Basic Everett,part the latest IfofPointer.Y + Pointer.PointerHeight > .Y And _ version Microsoft's Visual Studio. Pointer.Y + Pointer.PointerHeight < .Y + .Height Then If .Visible Then Table of Contents ClickedObject = DlgButton(i) .NET Game Programming with End DirectX If9.0 Foreword End If Preface End If Introduction End With Chapter 1 -Next .Nettrix: GDI+ and Collision Detection ChapterElse 2 - .Netterpillars: Artificial Intelligence and Sprites Test the collision with the active objects on the screen Chapter 3 -'Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ = 0 To - 1 Chapter 4 -For RiveriPla.Net: TiledCurrentScreen.ActiveObjectsNumber Game Fields, Scrolling, and DirectAudio NotII:CurrentScreen.ActiveObjects(i) Is Nothing Then Chapter 5 - RiverIf Pla.Net DirectInput and Writing Text to Screen With CurrentScreen.ActiveObjects(i) Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow If Not .IsOnInventory Then Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API ' If the Pointer is an arrow, _ Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay ' the hot spot is the upper left corner, D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 ' otherwise it is the center Nonmanaged Code ' Test the colision with the active objects Bonus Chapter Porting .Nettrix to Pocket PC If Pointer.CenterX >.X And _ Appendix A - The State of PC Gaming Pointer.CenterX <.X + .Width Then Appendix B - Motivations in Games If Pointer.CenterY > .Y And _ Appendix C - How Do I Make Games? Pointer.CenterY <_.Y + .Height Then Appendix D - Guidelines for Developing Successful Games ClickedObject=CurrentScreen.ActiveObjects(i) Index End If List of Figures End If List of Tables End If End With End If Next End If End Sub
At this time, you are probably thinking that there are just too many details to consider and maybe even to allow us to maintain a complete view of what we are trying to do. Just keep one thing in mind: When you are coding your own game, on your own or with a team, you'll probably forget some of these details.
Reviewing the Code Written up to This Point We can't avoid forgetting small details when coding, but after coding a game we must pass it through a complete set of tests that will try to discover all bugs and strange behaviors. For instance, if we didn't included the code to avoid the status text update, the status text would present the object names (no verbs, since the arrow has no associated text) when our arrow pointer moves over them. So we must try to think about every possible eventuality, and correct the problems for the ones that we didn't think about. Anyway, let's review what we have done up to now to implement the dialog feature in our game: We created a game state that will tell us if we are in dialog mode or in normal mode.
We created four (invisible) buttons on the left-hand side of each text line on screen in the game initialization. .NET Game Programming with DirectX 9.0
ISBN:1590590511 Santosclass Lobãotoand Ellen two new icons: We updated by theAlexandre mouse pointer include the dialog icon (to start a dialog) and the arrow icon (toHatton choose a question when in conversation). We have also updated the MouseUp event to © 2003 (696 pages) handle clicksApress with these two new pointers, calling the DoTalk and the DoSimpleClick methods, The authors of this text show how easy it can be to produce respectively.
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest When the user clicks one active object with the dialog icon, we call the DoTalk method, which will check version of Microsoft's Visual Studio.
whether the object can talk, and if so, set the proper variables, including the game state to Dialog and the mouse pointer to Arrow. The DoTalk method will also present the dialog phrases on screen and set the visible property of the buttons to true. Table of Contents .NET Game Programming with DirectX 9.0
We updated the Draw method to show the buttons, and the TestCollision method to test the collision of the mouse pointer with the buttons, since this was only calculating a collision with the active objects Preface associated with the current screen. Foreword
Introduction
Chapter - .Nettrix: GDI+ and Collision Detection We1 also added a test to the Render method to avoid updating the status line text when we click the buttons Chapter 2 - .Netterpillars: or move over them. Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ When dialog mode,Tiled withGame the arrow icon pointer, if the player clicks one of the buttons, the MouseUp event Chapter 4 -inRiver Pla.Net: Fields, Scrolling, and DirectAudio
will call the DoSimpleClick method, which will handle the next steps of the dialog flow. - River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 5
Chapter 6 - before, Magic KindergarteN.: Adventure Games, ADO.NET, As we saw when we code the DoTalk procedure, alland we DirectShow do is make the dialog response buttons visible, Chapter 7 Magic KindergarteN. II: Animation Techniques and Speech APIto some of the KinderEngine class set the proper game status, and make the corresponding adjustments Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay procedures. Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Now, it's up Nonmanaged to the player Code to click the buttons so the DoSimpleClick event will run and we can present the Bonus Chapter Porting to Pocketresponse, PC chosen question, the .Nettrix corresponding and the Continue button, which will end the dialog or call the DoTalkAprocedure again the new answer block number as a parameter. Appendix - The State of PCwith Gaming Appendix B - Motivations in Games
Analyze the code for the DoSimpleClick, shown in the following listing, and refer to the dialog control steps we presented before to understand exactly what is being done. The code is extensively commented to improve Appendix D - Guidelines for Developing Successful Games its readability. Appendix C - How Do I Make Games? Index
List of Figures
Sub DoSimpleClick(clickedObject As clsActiveObject) Dim i As Integer Dim DialogNumber As Integer
List of Tables
Select Case clickedObject.Name Case "Dialog 0", "Dialog 1", "Dialog 2", "Dialog 3" DialogNumber = Right(clickedObject.Name, 1) ' Set the number of the next answer block, which will be handled ' when the player presses the "continue" button With DlgObject.AnswerBlock(CurrentAnswerBlock) NextAnswerBlock = .NextAnswerBlock(DialogNumber) ' Show the question chosen by the player_ ' in the first line on the screen Text(0).Text = .PlayerQuestion(DialogNumber) ' Show the character's answer on the second line on the screen Text(1).Text = .ObjectAnswer(DialogNumber) End With ' The third line is blank Text(2).Text = "" ' Show the text "continue" on the forth line. ' The "continue" button always appear on _ ' the left side of the forth line Text(3).Text = "< Continue >" ' Hide the question buttons
For i = 0 To 3 .NET DlgButton(i).Visible Game Programming with DirectX 9.0 = False ISBN:1590590511 by Alexandre Santos Lobão and Ellen Next Hatton ' Show the "continue" button Apress © 2003 (696 pages) DlgButton(4).Visible = True authors of this text show how easy it can be to produce Case The "Continue" interesting multimedia games using Managed DirectX 9.0 and 'programming If the next answer is latest -1, we'll end the dialog with Visual Basicblock .NET onnumber Everett, the If NextAnswerBlock -1 Then version of Microsoft's Visual=Studio. EndDialog() Else Table of Contents ' Else, go back to the DoTalk method to _ .NET Game Programming with ' DirectX show 9.0 the next answer block phrases Foreword DoTalk(DlgObject, NextAnswerBlock) Preface End If Introduction End Select End Sub Chapter 1 - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Let's take a closer look at one line of code to try to understand it better:
Text(0).Text = _ Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow DlgObject.AnswerBlock(CurrentAnswerBlock).PlayerQuestion(DialogNumber) Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: and(Text(0).Text) Access to In the chosen line, weMultithreading, are setting theNonrectangular first text line onWindows, the screen to the phrase chosen by the Chapter 9 Nonmanaged Code
player. The player's choice is passed to the DoSimpleClickmethod as the DialogNumber parameter; and theDlgObject is a variable set in the DoTalk method to hold a reference to the object that was clicked to Appendix A - The State of PC Gaming start a dialog. In order to make it clearer, let's try to translate the assignment in the previous code to plain Appendix Motivations in Games like this: English.BIt -would read something Bonus Chapter Porting .Nettrix to Pocket PC
Appendix C - How Do I Make Games?
"Assign D the- Guidelines first sentence on the screen to the question Appendix for Developing Successful Games chosen by the player (PlayerQuestion(DialogNumber)) from the set of possible question-answer options, that is, the current Index answer block (AnswerBlock(CurrentAnswerBlock)). This answer block was read from the character on List of Figures screen for which we are establishing a conversation (DlgObject)." List of Tables It's quite a long sentence, but not totally incomprehensible.
Finishing a Dialog The last helper method to control the dialog is EndDialog, which will reset all that was done in the DoTalk method to allow the game to return to normal mode without any problems. The code for the EndDialog method is shown in the next listing: Sub EndDialog() Dim i As Integer ' Reset all dialog variables NextAnswerBlock = 0 CurrentAnswerBlock = 0 For i = 0 To 4 DlgButton(i).Visible = False Next DlgObject = Nothing GameStatus = enGameStatus.Normal 'Show the current screen text ShowScreenText() End Sub
We are now finally ready to test our dialog routines. Figure9.0 7-26 shows the result of clicking the mud monster .NET Game Programming with DirectX with the dialog icon pointer. ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 - 7-26: River Pla.Net: Scrolling, and DirectAudio Figure Talking Tiled to theGame mud Fields, monster Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter Figure 67-27 - Magic showsKindergarteN.: the second screen Adventure in a dialog: Games,the ADO.NET, question and weDirectShow chose, the answer of the monster, and the
Continue Chapter 7 button. - Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 7-27: Getting an answer from the mud monster In the next section, we'll include the code in the KinderEngine class to generate a voice and update the mouth positions when Natanael is speaking.
Final Version: Including Voice Generation Since we have already coded the PlayerVoice class, including voice generation in any game will be very simple—just a matter of including three lines: the object definition, the object creation, and a call to the Speak method. In our game, these steps will be done in the KinderEngine class by calling the Speak method inside the DoSimpleClick procedure, so the player will only hear Natanael speaking when he or she chooses a question to ask a game character. The following code listing presents all the updates we must do to generate voices in our game. We choose the "LH Michael" voice, which is installed with the Speech API SDK, because it appears to be the most appropriate for Natanael. If the player's computer doesn't have this voice, the code in the New method will use the
computer's default voice.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Private WithEvents PlayerVoice As clsPlayerVoice Hatton Apress © 2003 (696 pages)
Function Initialize(Owner as Windows.Forms.Control) As Boolean The authors of this text show how easy it can be to produce ... interesting multimedia games using Managed DirectX 9.0 and ' Initialize programmingthe with player's Visual Basic .NET voice on Everett, objectthe latest version of Microsoft's Visual Studio. PlayerVoice = New clsPlayerVoice("LH Michael") ... End Function
Table of Contents
.NET Game Programming with DirectX 9.0
Sub DoSimpleClick(ByVal clickedObject As clsActiveObject) Dim i As Integer Preface Dim DialogNumber As Integer Foreword
Introduction Chapter 1
-Select .Nettrix: GDI+ Collision Detection Caseand clickedObject.Name
Chapter 2 Chapter 3
- .Netterpillars: Artificial Intelligence and Sprites Case "Dialog 0", "Dialog 1", "Dialog 2", "Dialog 3" - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ DialogNumber = Right(clickedObject.Name, 1)
Chapter 4
- River Pla.Net: TiledDlgObject.AnswerBlock(CurrentAnswerBlock) Game Fields, Scrolling, and DirectAudio With
Chapter 5
- River Pla.Net II:NextAnswerBlock DirectInput and Writing = Text NextAnswerBlock(DialogNumber) to Screen
Chapter 6
' Show the question chosen by the player_ - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
' in Animation the first line and on Speech the screen - Magic KindergarteN. II: Techniques API
Chapter 8
= and .PlayerQuestion(DialogNumber) - .Netterpillars II:Text(0).Text Multiplayer Games Directplay
Chapter 9
-
' Speak Nonrectangular player textWindows, and Access to D-iNfEcT: Multithreading, PlayerVoice.Speak(.PlayerQuestion(DialogNumber)) Nonmanaged Code
... Chapter Porting .Nettrix to Pocket PC Bonus End Sub Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games?
To include the mouth animations in our game is even simpler, since we coded the PlayerVoice with specific images for our game: All we need to do is update the screen image with the image received as a parameter in Index theNewMouthType event, since this event is generated every time a new mouth position is needed. The List of Figures following listing shows the event code that will make our character's mouth move: Appendix D - Guidelines for Developing Successful Games
List of Tables
Sub PlayerVoice_NewMouthType(CurrentMouthImage As clsSprite) _ Handles PlayerVoice.NewMouthType TalkingHead.SpriteImage = CurrentMouthImage.SpriteImage End Sub
If we want to use this class in other games, we can update the images inside it, or, even better, store the animations outside the class so that they will be easy to access from other classes. In this game, we chose to include the mouth animations in the PlayerVoice class in order to have most of the speaking-related code inside a single program module, thereby making the explanations clearer. Figure 7-28 shows Natanael's mouth moving whilst he speaks to Sidney the mouse.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction
Figure 7-28: Natanael's mouth moves as he talks—as expected.
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 for - .Netterpillars: andpresent Sprites some ideas on how we could improve our game to That's all this game! InArtificial the nextIntelligence section, we'll Chapter make it3even - Managed better. DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Adding the .NET Final Touches by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton game is mostly a question of improving the puzzles and storyline, as we discussed Improving an adventure Apress © (696 pages) in the previous chapter. Of2003 course, astonishing graphics and animations will help a lot with first impressions—which is really important. without a good storyline and puzzles, the game will never be a The authors of this text But show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and hit. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visualto Studio. After the storyline, the next steps of a team improve this game could be the following:
Table of Contents Including full animation of the game: Using the animation guides, a first step could be to make .NET Game Programming with DirectX 9.0 place to another. After that, specific animations could be created Natanael walk on screen from one Foreword to represent every action, for every game character. Preface Introduction
Including an opening sequence and an ending sequence: Including some full-screen drawings, or
Chapter 1 - .Nettrix: GDI+ and if possible an animation toCollision start andDetection end the game, has become an essential part of every adventure. Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Including voices for all characters: Since the speech SDK offers some different voices, male and - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio female, it'd be very interesting to update the "talking head" graphic with the faces of each character, Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen including different voices and specific mouth animations for each one. Chapter 4 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 -see, Magic KindergarteN. Animation Techniques and Speech API As we can that's a lot to doII: before we can call the game created in these last two chapters an Chapter 8 -game, .Netterpillars Multiplayer Games and Directplay adventure but theII: most important concepts of adventure creation are presented here; all we need D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to now is some Chapter 9 - talented graphical artists, storyline writers, and sound effect producers—most of the Nonmanaged Code programming logic is complete. Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Summary
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton In this chapter, we improved the Magic KindergarteN. adventure game created in the previous chapter by © 2003 (696feature pages) of an adventure that we hadn't coded before: the dialog control including the last Apress main important between the player's character and the game's characters. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest We also discussed the following: version of Microsoft's Visual Studio.
Basic concepts about drawing effective animated graphics, including how to associate mouth animations with speech.
Table of Contents
.NET Game Programming with DirectX 9.0 The Speech API, which lets us generate voice from text and generate text when recognizing voice Foreword input. We implemented voice generation in a new game class for our library. Preface
We used all these concepts, including mouth animation, in our dialogs when the player character is speaking.
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 -chapter, .Netterpillars: Artificial Intelligence and DirectX Sprites component set members, DirectPlay, which will In the next we'll introduce the last of the Chapter 3 Managed DirectX First Steps: Direct3D Basics andversion DirectX of vs.the GDI+ help us to create network games, and use it to build a new .Netterpillars game, the sample Chapter 4 - River Pla.Net: Tiled game created in Chapter 2. Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Chapter .NET 8: .Netterpillars II: Multiplayer Games and ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Directplay Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio. In this chapter, we'll improve the .Netterpillars game created in Chapter 2 to include multiplayer features
Overview
(see Figure 8-1). We'll create two new options: Host a Death Match and Join a Death Match, which will respectively set up a DirectPlay session to receive connections from other computers and connect to a Table of Contents DirectPlay session on a remote computer, allowing two players to compete against one another across the .NET Game Programming with DirectX 9.0 network. Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter Figure 9 - 8-1: .Netterpillars II, this chapter's sample game Nonmanaged Code Bonus .Nettrix Pocketthe PC main challenges we face when creating multiplayer games, and In theChapter comingPorting sections, we'll to discuss Appendix A The State of PC Gaming then introduce DirectPlay, the set of components on DirectX that allow us to easily add connectivity to our Appendix games. B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Introducing.NET Multiplayer Games by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton All articles and books in which you'll read about multiplayer games (also known as network-enabled © 2003 (696 pages) games or simply Apress networked games) agree on one thing: Coding multiplayer games is really hard. Once you code your first multiplayer game, you'll discover why is. This type of game is so hard to code The authors of this text show how easy it this can be to produce interesting multimedia games using Managed DirectX 9.0 and because there are just too many extra problems to deal with—challenges that stem from creating a programming with Visual Basic .NET parts on Everett, the latest program with different and sometimes independent that must work together seamlessly. version of Microsoft's Visual Studio.
Your program will receive messages from the host or other players, send messages back to them, process the player input, and perform the physics and artificial intelligence calculations, all while not letting Table of Contents the screen freeze between each frame drawn. This is the worst thing that can happen in a multiplayer .NET Game Programming with DirectX 9.0 game. Foreword
Preface Fortunately, DirectPlay can help you with solving some of the problems you'll come across, like controlling Introduction the message flow between players and host to guarantee that no message is lost and all messages arrive Chapter 1 - .Nettrix: GDI+ and Collision Detection there will still be some problems to solve. in the same order they were sent. Nevertheless, Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites
Before 3discussing theDirectX detailsFirst of DirectPlay, let's look at some basic vs. concepts Chapter - Managed Steps: Direct3D Basics and DirectX GDI+ about networked games and some of the most common problems faced when coding such games, in the next sections. - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Choosing the Connection Type Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
The most common types of connections between players we must think about when coding multiplayer - .Netterpillars II: Multiplayer Games and Directplay games are peer-to-peer and client-server connections.
Chapter 8 Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Peer-to-Peer Connections
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
In peer-to-peer connections, every player is aware of every other player in the game, sending messages to
Appendix B - Motivations in from Games and receiving messages all players, as illustrated in Figure 8-2. Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 8-2: Peer-to-peer connections The most obvious benefit of using this network organization is that we don't need a dedicated server to play the game, so players within a group can play it within their own local area network (LAN), or even through the Internet, as long as they know the addresses of the other members of the group.
In this type of connection, one of the players acts as a host, so all the new players will connect to his or her Game Programming with DirectX 9.0 system, but once.NET connected the messages will flow directly from one player to all the others. by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton The main problem we face when coding peer-to-peer games is that we can't afford to have too many Apress © 2003 (696 pages) players in the same game session, since the number of messages will increase exponentially with every The authors of this in text show 8-2 howwe easy it can to produce new player that joins. For instance, Figure have fourbeplayers, so every time a player needs to multimedia games using Managed DirectX 9.0 we andhave four players, during each update his or herinteresting status (e.g., move), we'll have three messages. Since programming with Visual Basic .NET on Everett, the latest turn of a player we'll exchange 12 messages (4 × 3 = 12). Making the same calculations with a five-player version of Microsoft's Visual Studio. game increases this figure to 30 messages per turn (6 × 5 = 30); and in a six-player game, it reaches 56 messages (7× 6 = 56). Table of Contents
Usually, more than players .NET Gamehaving Programming withten DirectX 9.0in the same game session isn't suggested, because every message can take dozens of bytes, and we'll consume the bandwidth available in our network very quickly. But it's Foreword
still possible, as long as we deal with very small messages. The most famous example of a game that uses this approach is LucasArt's X-Wing versus Tie Fighter, which runs peer-to-peer across the Internet. Introduction The game developer team manages to reduce the messages to (in most cases) only the players' input, so Chapter 1 - .Nettrix: GDI+ and Collision Detection the game on every player's machine calculates everything else from this input. Preface
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Client-Server Connections Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter The second 5 - River mostPla.Net common II: game DirectInput network andtopology Writing Text is the to client-server Screen connection. In this kind of network,
all players to a dedicated host system. ThisADO.NET, system processes the messages and does the Chapter 6 -connect Magic KindergarteN.: Adventure Games, and DirectShow synchronization all players, sending messages back toand each of them, Chapter 7 - MagicofKindergarteN. II: Animation Techniques Speech API as presented in Figure 8-3. Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 8-3: Client-server connection Client-server games consume a lot less bandwidth per player, which allows us to send more data to the players (and maybe create a more complex game); on the other hand, the player depends on having a host to connect to (so he or she can't usually play on a private LAN). When coding client-server games, we must decide which actions will take place on the host, and which actions will take place on the client machines. Is it better to put all the game physics and intelligence on the players' machines, using a host just as a forwarder of messages? Or is it better to include all the game code on the host, leaving just the input gathering and rendering code to the players? There is no right answer to this question, but the optimum would probably be somewhere between the two. When making our decision, we'll have to take into account how many players we'll have connected to the host, and how much it will cost the host processor to perform each activity (for all players). We'll also have to consider the cost of each player's machine doing its own calculations, and what impact passing results between the host and players will have on the bandwidth. Even when a specific operation could be better done by the host, we may decide to run it on the clients if passing the results of the operation to the
players' machines will use a large amount of the available bandwidth. .NET Game Programming with DirectX 9.0
by Alexandre Santos Lobão and Ellen Other Options
ISBN:1590590511
Hatton Apress (696 pages) we have other types of network organization. Some are useful in Besides these two types©of2003 topologies, The others authorsaren't. of thisFor textexample, show how it can be to produce game development, ineasy a ring topology, each player sends messages to one interesting multimedia games using Managed 9.0 and specific player, creating a ring that will eventually return to theDirectX first player in the sequence, as shown in programming with Visual Basic .NET on Everett, the latest Figure 8-4. version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Figure network topology Appendix C - 8-4: How Ring Do I Make Games? Appendix D - Guidelines for Developing Successful Games
This network organization is usually not practical for games, since the first player in the sequence would have to wait for the message to go around to every other player before it gets back to him or her, which List of Figures can easily lead to unacceptable waiting times. Index
List of Tables
Another example of a different approach is using network groups. Each group of players will exchange messages only with the other players in his or her group, and the host (or a specific player, if it's a peer-topeer game) will exchange information with other groups, where needed. The group organization must be designed so that the number of messages passed within the group is as small as possible. Figure 8-5 illustrates a game network topology based on groups.
Figure 8-5: A group-based network topology This approach is very common in network games, and it's an improvement on the client-server and peerto-peer topologies, since it has the benefits of each one while also allowing us to consume less bandwidth when we have a larger number of players.
There are also other network technologies that can help us improve our games; broadcasting is possibly .NET Game Programming with DirectX 9.0 the most important one. Usually, to send a message to all players in a game, we'll send a message to ISBN:1590590511 by Alexandre Santos Lobão and Ellen of players each one, consuming extra bandwidth as the number grows. With broadcasting, when we need Hatton to send the same message to different players, all we have to do is to add extra destination addresses to Apress © 2003 (696 pages) our message, and it'll be routed to all of the destinations, just like an e-mail, which can be sent to different authors of this text show how easy it can be to produce people without usThe having to worry about copying it. The problem is that not all networks support interesting multimedia games using Managed DirectX 9.0 and broadcasting. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Fortunately, DirectPlay will use the network resources available, hiding the internal complexities from us. So, if the network supports broadcast, DirectPlay will use it; if not, it'll simply send a single message to Table Contents eachofplayer. .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game ProgrammingSurrounding with DirectX 9.0 a Network Game Project Making Choices: Decisions by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton There are many decisions to make when planning a network game. In the following sections, we'll discuss © 2003 (696 pages) some choices weApress must make when producing our network game project. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Choosing Between Turn-Based and Real-Time Games This is probably one of the first decisions when thinking about multiplayer games, and the one that will have the most impact on our game project. Table of Contents
In turn-based games, each .NET Game Programming with player DirectXwill 9.0think about his or her move, do the proper action, and then pass the control to the next player. Although the first type of game that comes to mind is board games like chess or Foreword Monopoly, there are very sophisticated action games based on turns, such as the X-COM series, where Preface players move each soldier (using his energy to walk or fire), and then the aliens move, using the same rules.
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 this - .Netterpillars: Artificial Intelligence and Spriteswhen trying to deal with the latency between our Choosing approach will save us a lot of headaches Chapter 3 Managed DirectX First Steps: Direct3D and DirectX vs. GDI+ game messages, especially when running acrossBasics the Internet, but may lead to a less than optimal Chapter 4 -if River Pla.Net: Tiled Game and DirectAudio gameplay the project isn't very wellFields, writtenScrolling, or the game doesn't run well in turns. Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen
Tip6Never choose this approach if you have many players (say, more than three or four, depending on Chapter - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow game KindergarteN. pace), because each player needs toand wait more API than a couple of minutes to move Chapter 7the - Magic II: ifAnimation Techniques Speech
again, the game will rapidly become uninteresting—except, of course, if the players actually - .Netterpillars II: Multiplayer Games and Directplay expect a delay, like in a chess match. A practical idea is letting the players communicate with each D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9other (by voice orCode by typing a message), even when it isn't their turn, so that you can improve the Nonmanaged interaction between and Bonus Chapter Porting .Nettrix players to Pocket PC make the waiting less boring. Chapter 8
Appendix A - The State of PC Gaming
Creating continuous action multiplayer games, such as Doom or Quake, is very challenging, mainly
Appendix - Motivations in Games becauseBwe must transfer a certain amount of data (which we have to attempt to minimize) within very Appendix C How Do I Make Games? tight time frames, which unfortunately depends on the response time of something beyond our control— Appendix D - Guidelines for Developing Successful Games the network. At the same time, we need to make sure that all players have synchronized information, Index especially in fast-paced action games where players are fighting against each other. List of Figures
One List of possible Tables approach is to send all of the data updates to each of the players, so that we can ensure that everyone has the most recent events on their machines. However, this approach will obviously consume the entire bandwidth available with even a few players, even on an intranet. In the other extreme, we can carefully calculate exactly which information should be sent to each player, and then send the minimum data needed. For instance, if another player is behind us or in another part of the labyrinth, we can't see him or her, so we don't need to receive information from him or her. But this kind of approach will consume most of the CPU's capacity on the players' machines by calculating the data to send, leaving fewer cycles to calculate the game physics and draw the graphics. Then again, the best approach is to find a balance according to our game requirements. There is no right answer; just minimize the data while trying not to expend too much processing time on this minimization, and always keep in mind that the game will be run on slower machines and may facing unpredictably bad network response times. In the next section, we'll discuss another point we must think about when coding a multiplayer game: whether to make it context-based or not.
Choosing Between Constant World or Context-Based Peer-to-peer games are inherently context based, since we don't have a server to host a world even when no players are connected. Client-server games, on the other hand, may or may not have constant conditions.
Games like Multitude's FireTeam provide some arenas in which players can connect and play together, .NET Game Programming with DirectX 9.0 but once the game ends, the server won't maintain any information about the previous game—except, ISBN:1590590511 by Alexandre Santos Lobão and Ellen maybe, for statistical data in some games.
Hatton Apress © 2003 pages) Other games allow players to (696 control one or many characters and interact with a preexisting world on the The besides authors of show other how easy it can bethat to produce server that includes, its this owntext physics, characters may be controlled by the computer or interesting games Managed 9.0 and data is saved somewhere other players. Once a playermultimedia disconnects fromusing the host, his orDirectX her character programming with Visual Basic .NET on Everett, the latest while the world continues normal existence. A good example of this kind of game is Ultima Online, version ofits Microsoft's Visual Studio.
which creates a large world where players can interact and improve their own character's skills. The experimental game Terrarium, from the GotDotNet site Table Tip of Contents
(http://www.gotdotnet.com/terrarium), is also an example of a game based in a .NET Game Programming with DirectX 9.0 Foreword continuous world. In this game, the players create animals or plants by using a wizard or coding
from the ground up. Then players release their creations into the game environment to see the result of natural selection among all other "life beings" on the host. It's a game for programmers, Introduction and it's really worth a look. Preface
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 the - .Netterpillars: Intelligence and Sprites Possibly most difficult Artificial challenge we face when creating games with constant worlds is doing our best Chapter 3 Managed DirectX First Steps: Direct3D Basics and DirectX vs.into GDI+ to avoid cheating. There are many hackers who will attempt to break a game server, especially if there Chapter River Pla.Net: Tiled Game Fields, and DirectAudio is a fee4to -connect to it, and there is no 100 Scrolling, percent foolproof method of preventing them from doing this. Chapter 5 River Pla.Net II: DirectInput and Writing Text Screen We must therefore define recovery routines to return thetogame to a playable state, and backup and Chapter restore6procedures - Magic KindergarteN.: for when there Adventure is no dynamic Games,recovery ADO.NET, possible. and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
This and other technical and economical problems will arise in every multiplayer game, and continuous - .Netterpillars II: Multiplayer Games and Directplay worlds add some extra issues to our ever-growing list.
Chapter 8 Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
In the next section, we'll list technical tips that may help us when creating this kind of project.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 Technical Tips by Alexandre Santos Lobão and Ellen
ISBN:1590590511
In this section, weHatton look at some technical tips we must keep in mind when coding a multiplayer game. © 2003 (696we pages) Although this list Apress isn't exhaustive, have asked the opinion of many game developers about the most common problems to make sure we touch onhow the easy important The authors of this text show it canpoints. be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Plan the Game Carefully Before Starting
If creating a good project is important to every game, when talking about multiplayer games a detailed Table of Contents project is a must. Since we'll have different programs, or at least different parts of the same program, .NET Game Programming with DirectX interacting through the network, we 9.0 must define every single message that will be exchanged and every Foreword way in which the programs will process them. Preface
It's crucial to the success of the game that we define where and when each process will occur, in order to guarantee that each player is synchronized. Programmers tend to forget these details, since in standChapter 1 - .Nettrix: GDI+ and Collision Detection alone programs everything occurs directly after the command is processed. In multiplayer games this isn't Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites the case. For example, in a real-time game, one player may be shooting at another player's character and, Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ almost at the same time, the other player's character may be moving out of the firing range of the first Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio player. If all processing occurs locally on each player's machine, the first player will see a successful hit, Chapter 5 his - River Pla.Net DirectInput Writing with Text the to Screen just after or her shot. II: Meanwhile, theand message shot information won't reach the other player's Chapter 6 the - Magic KindergarteN.: Adventure ADO.NET, machine, remote player having jumpedGames, out of the way, soand theDirectShow remote player will see the shot missing Chapter 7 character. - Magic KindergarteN. II: Animation Techniques and Speech API his or her Introduction
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
So devising D-iNfEcT: an algorithm that will guarantee synchronization as Access important Multithreading, Nonrectangular Windows,isand to as not using a lot of Chapter 9 bandwidth. Considering Nonmanagedthat Code we may face very bad response times when running across the Internet, this is veryChapter challenging. Bonus Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
AlwaysB Code frominthe Ground Appendix - Motivations Games
Up
Appendix C - How Do I Make Games?
Every programming team that has ever tried to adapt a stand-alone game to run multiplayer will agree with this tip: It's far better to code everything from the ground up than to try to simply adjust the stand-alone Index game's code. Even in a simple program, such as this chapter's sample game, we'll face situations that List of Figures could be done better if the whole game was created from scratch. Appendix D - Guidelines for Developing Successful Games
List of Tables
So, if you ever try to write a multiplayer game on your own at home, remember this tip and you'll be okay. As mentioned, we are creating a multiplayer version of the .Netterpillars game in this chapter, which we originally created as a stand-alone game in Chapter 2. Although we have planned the game to be multiplayer, and although the game is very simple, we'll probably see some bits that would've been better served by starting with the multiplayer version.
Define Carefully the Message Types and Sizes Bandwidth is a rare and expensive thing, so use it sparingly. After defining all messages that our programs will exchange, in the project phase, we must go back and draw the complete flow of a typical game cycle (the game's main loop), so we'll be able to see if we are forgetting anything important. We must create this flow for at least two to three players, plus the host, if any exists, since there are some situations that will occur with three players that won't occur with two. After being sure that we aren't forgetting anything, we must go back and recheck every message to see if we are using the minimum space possible for each message, especially those that will be exchanged most frequently. For example, a single bit can be used as a flag, so a byte can comprise up to eight flags; and a byte takes 256 different values, so if our values are within this range, we can use the byte data type instead of the int16 one, which will take 2 bytes. A final word on this: Be sure that you know the real size of the data types you are using. An integer, for example, usually takes up 4 bytes, but in old 16-bit operating systems, it took 2 bytes, and in 64-bit
machines it takes 8 bytes. Another interesting item of note involves strings: They do not occupy the same .NET Game Programming with DirectX 9.0 amount of bytes as the number of characters. They have extra internal control bytes that help to define, for ISBN:1590590511 by Alexandre Santos Lobão about and Ellen example, their length; and if we are talking Unicode strings, the strings will use 2 bytes per Hatton character. Apress © 2003 (696 pages)
The authors this text easy itcountries, can be to produce Note ANSI strings are theofdefault forshow mosthow Western but this doesn't suffice for writing every interesting multimedia games Managed DirectX 9.0Japanese and character in Eastern countries, suchusing as the characters in the and Chinese languages, programming with Visual Basic .NET on Everett, the latest since we have only 256 possible characters in ANSI.. UNICODE is the default for such countries, version of Microsoft's Visual Studio. and in this case every character could be one of up to 65,536 different values, enough for any language. So if you are reading this book some-where in Asia, please be sure to use arrays of Table of Contents bytes instead of strings, unless you want to send text in local characters only. .NET Game Programming with DirectX 9.0
Hide the Foreword
Latency from the Player
Preface
Latency is the single worst enemy of every multiplayer game programming team. And, what is worse, we can't simply provide a solution. It's not a bug, it's a fact of life, so we must learn to live with it.
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 never - .Netterpillars: Artificial Sprites Since we know for sure howIntelligence much timeand we'll need to receive the next message, we can use some Chapter - Managed DirectXwhile Firsthe Steps: Direct3D Basics and DirectX GDI+is similar to Ensemble Studios' tricks to3 distract the player or she waits. For example, if ourvs. game Chapter - River the Pla.Net: Tiled Fields, to Scrolling, and DirectAudio Age of 4Empires, player canGame give orders game characters, but the characters will only move after the Chapter client machine 5 - River receives Pla.Net information II: DirectInput from and the Writing host that Textthe to command Screen has been received. We can make our
characters "Yes, Master! " (this sounds Games, very innovative ...)and justDirectShow after the command is issued, so the Chapter 6 - say Magic KindergarteN.: Adventure ADO.NET, player has impression that the is immediate, although it willAPI really occur (hopefully) a number of Chapter 7 -the Magic KindergarteN. II: result Animation Techniques and Speech milliseconds later. Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -idea can be used with animations instead of sounds. The game character can start a little This same Nonmanaged Code
animation, like picking up some object or moving his head around as if looking for a way to start the command. This kind of trick is very effective.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Appendix - Motivations in when Games Another Bthing we can do facing extra long waiting times for the next message is let our program Appendix C How Do I Make Games? continue the action based on the last input, maybe at a lower rate. For example, if we know the speed and Appendix D - Guidelines for players' Developing Successful Gamesbattle game, we can suppose that they are still the direction of the other starships in a space Index moving in the same direction, and move them a little using this supposition. But as soon as the new List message of Figures arrives, we must check and correct all the positions of the other players. This can be very
challenging, List of Tables even for experienced programmers, and can lead to problems in the game, like a spaceship "jumping" from one place to another. Such a problem can be solved with a smoothing trick, adjusting the position in more than one game cycle, but this trick will add extra complexity to our game. The important thing about latency is that while it'll probably always be a problem, players did not, do not, and will not ever understand latency. So your team will have to expend some hours on this topic during the game's project stage, if you are planning to do a serious multiplayer game.
Include Artificial Intelligence in Your Multiplayer Game Many players don't like to play games with other players, or simply don't have the money or the time to do so. Most of the games that only run over a network are a failure, so be careful if you want to follow this approach. We'll give a simple example: Just imagine if games like Doom or Quake were only multiplayer. What is a single player, without a network card, meant to do in them? Run around the corridors and rooms with no opposition? These games would definitely not be as successful if they didn't have intelligent computercontrolled characters to play against. And we must remember that having computer-controlled characters is useful even in network games.
Create a Community for Your Game Every game should have a community, and in multiplayer games, this is a must. Creating a site where players can enter and interact brings many benefits to our game: The site helps to create a group of loyal
players who will always play the game and help the game team by providing fast feedback if anything goes .NET Game Programming with DirectX 9.0 wrong with the game, quickly fixing the problem and informing other users. by Alexandre Santos Lobão and Ellen
ISBN:1590590511
The site can alsoHatton add extra value to our games, because we can include game statistics, records, and 2003us (696 add-ons to it, andApress it can ©help topages) create our own statistics, if there are special zones (for example, the The authors this text show howby easy it canwho be toregister producetheir games. add-ons download area) thatof are only accessible players
Prevent
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Players from Cheating version of Microsoft's Visual Studio.
You'll be surprised to know how determined hackers are when they want to be. It's hard to avoid cheating, but we must at least try to discourage it, since nothing is worse for the players than to feel cheated. And Table of Contents believe us,Programming they will blame not the .NET Game withyou, DirectX 9.0 cheater. Foreword
The bare minimum we must do is to check each message received on the client and on the server (if we have one) to see if it's valid. We must not try to encrypt or include checking codes on our messages, Introduction because even if such security measures are good for preventing cheating, they'll consume a lot of Chapter 1 -and .Nettrix: GDI+ and Collisionand Detection bandwidth CPU cycles to decrypt check. Instead, we must try to imagine the simplest checks we Chapter Artificial Intelligence and Sprites can do 2that- .Netterpillars: will gain the best results. For example, we want to check whether the current player position Chapter 3 - Managed DirectX First Steps: Direct3D Basics and vs. GDI+ and ammunition received in a message are compatible withDirectX the previous ones, so a player can't "teleport" Chapter Rivermode" Pla.Net: Game and DirectAudio his or her messages. or enter4 in-"god (allTiled guns and Fields, ammo)Scrolling, by simply manipulating Preface
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Test, 6Test, Test! Chapter - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Multiplayer games have extra sources of errors, and sometimes these errors are harder to find and fix, so - .Netterpillars II: Multiplayer Games and Directplay starting testing from the very beginning is a real must.
Chapter 8 Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
The first test we must do is with message delivery. In theory, TCP (the protocol used by DirectPlay) will guarantee that the messages always arrive at the destination, and always arrive in the same order in which Appendix A -sent, The State of PCour Gaming they were but doing own test to check this will help with creating statistical information about the Appendix B Motivations in Games latency times and exposing bottlenecks on the network. The same test can show bottlenecks in our game, Appendix - How done. Do I Make Games? when it'sCnearly Bonus Chapter Porting .Nettrix to Pocket PC
Appendix D - Guidelines for Developing Successful Games
Hackers and curious programmers that want to "explore" the game messages may try to send modified Index messages just "to see what happens," so we must never use a message's contents before checking if the List of Figures message is valid. We've seen some game servers go down because of a single message with invalid List of Tables values, due to no checking and weak error trapping on the host program, so we must be careful.
Another scary statistic has to do with multiplayer game reliability. Just imagine that we have created a game that has an uptime of 99.9 percent, which means that our game can run on the average for 23 hours and 59 minutes without crashing, or a minute out on each day. If we have ten players in our game, they won't crash at the same time, so we can divide 24 hours by 10 and see that every 2 hours and 24 minutes we'll have a crash. If our program is good enough, the other players can continue playing, but it will be very frustrating for all of the players if they are playing in team, because from time to time a player will simply disappear from the team. And we are only talking about the players. If we consider the host, and the errors that can arise from errors on the client machines, it gets even worse. So our tip is simply this: Test, test, test. And after that, test all over again.
Include Different Threads This is a simple but important tip. Having a specific thread dedicated to message sending and receiving and another thread or threads to deal with game physics and artificial intelligence will give us more flexibility to hide the latency and get the most from our hardware. A simple example of using different threads, called DataRelay, can be found in the DirectX SDK: A thread receives messages and pushes them into a queue (a simple message array inside the program), while another thread keeps removing the messages from this queue. Understanding this program's details is a
good step to being able to create multithreaded multiplayer games. .NET Game Programming with DirectX 9.0
by Alexandre Santos Lobão and Ellen Create a Balanced Game
ISBN:1590590511
Hatton Apressgame © 2003 a (696 pages)can win 100 percent of the time if he or she plays hard enough, in While in a stand-alone player The authors of with this text show how easy it canas behard to produce multiplayer games two players the same skills, playing as they can, will win 50 percent of the interesting multimedia games using Managed DirectX 9.0 and matches on the average. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Although it looks like a simple thing, finding the proper balance in multiplayer games can be a very tricky challenge. There can be no "golden path," no way that ensures the victory of any one player. The game levels be balanced so that there's no place in the game field that provides a large tactical advantage, Table ofmust Contents and there aren't any guns orDirectX tricks that .NET Game Programming with 9.0 allow a player to remain at an advantage to the others. Foreword
Another important detail is to provide some mechanism that will allow the player to indicate his or her skill level, or to choose a group with the same skill to play against, so that newbies will have a fair chance to Introduction play as well as experts. Preface
Chapter 1
- .Nettrix: GDI+ and Collision Detection The game canArtificial help the game team lot with the task of finding and fixing any unbalanced Chapter 2 -community .Netterpillars: Intelligence anda Sprites
aspects3 of-the game,DirectX so creating beta testing groups before releasing final version of a game will help Chapter Managed First Steps: Direct3D Basics and DirectX vs. the GDI+ with correcting such problems, while Fields, at the same timeand creating a group of loyal users even before the Chapter 4 - River Pla.Net: Tiled Game Scrolling, DirectAudio game hit shelves. Chapter 5 the - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Never Trust the Internet! - Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 7
Chapter 8 - .Netterpillars II: Multiplayer Games and The Internet is untrustworthy, and unfortunately weDirectplay can't fix it. Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Nonmanaged Code While we can expect times from 20 to 150 milliseconds (ms) on a good intranet (with an average of about Bonus Chapter .Nettrix Pocket PC a very bad average time to deliver a message, about 500 ms. 100 ms), overPorting the Internet wetocan expect Appendix - The State of PC Gaming can take 1, 5, and even 20 seconds to arrive, and some messages Another Aproblem is that messages Appendix simply never B - Motivations arrive. in Games Appendix C - How Do I Make Games?
DirectPlay uses the TCP protocol to send messages, which ensures message delivery and arrival order. However, this can be a problem on the Internet, because if a message gets lost along the way, when the Index next message arrives the remote computer will ask for the lost one. This is why we sometimes face such List of Figures bad delivery times. Appendix D - Guidelines for Developing Successful Games
List of Tables
Most multiplayer games rely on User Datagram Protocol (UDP), a simpler protocol that guarantees neither message delivery nor arrival order. In this case, the program controls the order (usually, a simple counter on the messages allow the remote machine to check the order) and packets lost, which sometimes can simply be forgotten, if the next message gives enough information to "reconstruct" the lost message on the remote machine. It's a good idea to start by creating simpler TCP-based games, which give us enough knowledge to create games that are more advanced later. And that's what we'll do in this chapter-create a simple DirectPlay class to deal with message handling as shown in the next section.
Game Programming with DirectX 9.0 Introducing.NET DirectPlay by Alexandre Santos Lobão and Ellen
ISBN:1590590511
DirectPlay is a setHatton of functions and components within the DirectX architecture that enables the creation of 2003 (696 pages) multiplayer gameApress hosts ©(which other players can connect to), handles the connection between players and the host, and includes many extra features, such built-in for Network Address Translation The authors of this text show howas easy it cansupport be to produce interesting games using Managed DirectX 9.0 and (NAT) and firewall traversal,multimedia and also support for voice communications. programming with Visual Basic .NET on Everett, the latest
version of Microsoft's Visual Studio. DirectPlay also supports group creation (through CreateGroup and related methods), which allows game developers to use broadcasting if the network supports it without any extra lines of code. Broadcasting, as mentioned earlier in this chapter, is the network support to send one single message to Table of Contents different destinations, saving bandwidth and CPU cycles. .NET Game Programming with DirectX 9.0
Foreword Note It's not our goal here to explore every single feature available with DirectPlay; instead we'll create Preface a simple class to illustrate the basic features needed to implement simple multiplayer games. Introduction
Although a complete game may be challenging, the basic steps for creating a Chapter 1 coding - .Nettrix: GDI+ andmultiplayer Collision Detection multiplayer to which players connectand areSprites very simple. The game host can be a player, in a peerChapter 2 - host .Netterpillars: Artificial can Intelligence to-peer3game, or a server machine, if weDirect3D are using the client-server approach. There are four steps to Chapter - Managed DirectX First Steps: Basics and DirectX vs. GDI+ create a host: - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio 1. Choose the service andand store its address. Chapter 5 - River Pla.Net II:provider DirectInput Writing Text to Screen Chapter 4 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
2. Create a session, defining its unique identifier and name.
Chapter 8 the - .Netterpillars II: Multiplayer Games and Directplay 3. If host is a player, set the player name. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Nonmanaged Code game host. 4. Create the multiplayer Bonus Chapter Porting .Nettrix to Pocket PC
Similarly, canState resume creation of a game client in five simple steps, which will be valid for both Appendix A we - The of PCthe Gaming peer-to-peer and client-server games.
Appendix B - Motivations in Games
1. Choose Appendix C - Howthe Do service I Make provider Games? and store its address. Appendix D - Guidelines for Developing Successful Games
2. Choose the host to connect to.
Index
List of 3. Figures Choose the session to join. List of Tables
4. Set the player information. 5. Join the session. Before presenting any code, let's look at each of the objects that are implicitly or explicitly described in the previous lists.
Understanding Service Providers The first step with the client-server approach is choosing which service provider we'll use in our game. The service provider is the registered "network service type" we can use to communicate with other computers. The most common service providers are the TCP-IP provider, the modem provider, and the serial provider. Unless you plan to provide some serial cable or connect directly via modem, we suggest you use the TCP-IP provider. In a real game, we can fix this option in the code, or let the player choose the connection type with a special configuration program, since it's not common to deal with different service providers in the same game. In DirectPlay, the object used to manage service providers is called ServiceProvider. Each service provider has a unique address that the game will use in order to access this service provider. DirectPlay offers a specific object to store and perform any operations with this address, the Address object.
Understanding Sessions .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
The next important concept regarding multiplayer games is the session. A session is a group of players Hatton that will be exchanging among themselves, using a host or not. A host computer can control Apressmessages © 2003 (696 pages) one or more sessions, so after choosing the host, the clients must choose the session. This approach is The authors of this text show how easy it can be to produce especially useful interesting if we are planning to offer different sessionsDirectX for users different abilities. The object in multimedia games using Managed 9.0of and DirectPlay used to control sessions is called ApplicationDescription. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
When creating a session, the host must give its name, which will be presented to the clients when they ask for the session name on the host, and a unique identifier that will be used by the computers to define this Table of Contents particular session. This unique identifier is a GUID, or Global Unique Identifier, used by Windows to .NET Game Programming with DirectX 9.0 uniquely define each installed application. Foreword
The client computers on a client-server game or all the computers in a peer-to-peer game must identify Preface themselves as players to the host, setting the player data through a DirectPlay's Player object. The Introduction player data- is usually only the player name, but the Player object allows us to add some status .Nettrix: GDI+ and Collision Detection information too, if we need to. Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 1 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Understanding - River Pla.Net:Hosts Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Another important concept mentioned in the preceding steps is the host. The host computer is the one Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow responsible for storing the sessions and controlling the users connecting to each session. The Host Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API method of the Peer object is used to create a host, and can be used to implement client-server games, Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay where the host machine also controls the message flow between all players, and to create peer-to-peer D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter games,9where the host is also a player and doesn't have any influence on the exchange of messages. Nonmanaged Code Bonus Chapter Porting .Nettrix toisPocket PC important object in a DirectPlay game, since it will create the ThePeer object, as we'll see, the most Appendix A The State of PC Gaming host and connect to the host, and also provides methods to send data and events and receive data from Appendix B - Motivations in Games the Peer as the object that represents a specific machine, server, or other players. We can understand Appendix C How Do I Make Games? client, in a multiplayer game, and almost all the important operations in DirectPlay depend on this object. Appendix D - Guidelines for Developing Successful Games
DirectPlay also offers a specific object to create clients that can access massive multiplayer games in Index
lobbies, the Lobby object. Lobby servers are specific applications located on a remote host (usually on the Internet) that offers, besides the host facilities described previously, other features like chat rooms, List of Tables game statistics, game merchandizing, etc. Since DirectPlay doesn't offer any support for lobby server creation, we won't go into any details about the Lobby object in this book. List of Figures
In the next section, we'll explore the objects and concepts involved in making DirectPlay-based games by creating the NetworkGame wrapper class, which will simplify the use of network features in our games.
.NET Game Programming with DirectX 9.0 Defining the NetworkGame Class by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Since most of theHatton operations we'll perform on a server, like sending and receiving data, setting player Apress © 2003 pages)provider, will also occur on a client program, there's no point in creating information, and choosing the (696 service two different classes for accessing features. create a single class, the interface for which is The authors of this DirectPlay text show how easy itWe'll can be to produce interesting multimedia games using Managed DirectX and part is specific to the host and shown in Figure 8-6, including comments in the code to make it clear9.0 which programming which is used only by the client.with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 8-6: The NetworkGame class implements access to the DirectPlay features. As we can see in Figure 8-6, the NetworkGame class won't implement any processing of the message data; this handling will be done by derived classes, which will include code for the ProcessGameMessage method. DirectPlay also uses a lot of events and event handlers to control connections and messages, as presented in Figure 8-6. We'll discuss each of them when discussing the details of the NetworkGame class. The class interface derived from the previous class diagram is presented in the next code listing: Imports Microsoft.DirectX.DirectPlay Public Class ClsNetworkGame ' The main DirectPlay object Public WithEvents DPPeer As Peer = Nothing ' The Address object used to create and locate hosts
Public DPAddress As Address = Nothing .NET Game Programming with DirectX ' The unique identifier for our game - 9.0 a random number ISBN:1590590511 by Alexandre Santos Lobão and Ellen Protected GameGuid As Guid = New Guid(7530573, 15564, 7321, _ Hatton 2, 15, 7, 9, 13, 11, 6, 5) Apress © 2003 (696 pages)
authors of this text show how easy it can be to produce ' Player The Properties interesting multimedia games using Managed DirectX 9.0 and Public PlayerName As String programming with Visual Basic .NET on Everett, the latest Public PlayerID As Integer version of Microsoft's Visual Studio. Public PlayerCount As Integer = 1 ' Start Counting the local player Table of' Contents The session name .NET Game Programming with DirectX Public SessionName As 9.0 String Foreword Preface' Event used to enumerate hosts to connect Introduction Public Event EnumHost(AppDesc As ApplicationDescription, _ Chapter 1
host As Address, device As Address) - .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
used to First handle transfering Chapter'3 Events - Managed DirectX Steps:message Direct3D Basics and DirectX vs. GDI+ Event DataArrived(strData As String) ChapterPublic 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Event AsText ResultCode) ChapterPublic 5 - River Pla.NetSendError(errCode II: DirectInput and Writing to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
' Events used to handle connections - Magic KindergarteN. II: Animation Techniques and Speech API Public Event ConnectionResult(connected As Boolean, errcode As ResultCode) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Public Event SessionTerminated(msg As TerminateSessionMessage) Chapter 7
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
' Events used to handle Players Public Event NewPlayer(Name As String, ID As Integer) Appendix A - The State of PC Gaming Public Event RemovePlayer(PlayerId As Integer) Appendix B - Motivations in Games Public Sub New() Appendix C - How Do I Make Games? ' --------------------------------------------------------Appendix - Guidelines to for Developing Successful ' D Functions help choose the Games Service Provider Index ' --------------------------------------------------------List of Figures Public Function ChooseServiceProvider() As Boolean List of Tables Public Sub SetServiceProviderGUID(SPGUID As Guid) Bonus Chapter Porting .Nettrix to Pocket PC
' --------------------------------------------------------' Functions that handle connections ' --------------------------------------------------------Public Function Connect(AppDesc As ApplicationDescription, _ host As Address, device As Address) As Boolean Private Sub ConnectResult(sender As Object, _ dpMsg As ConnectCompleteEventArgs) _ Handles DPPeer.ConnectComplete Private Sub SessionFinished(sender As Object, _ dpMsg As SessionTerminatedEventArgs) _ Handles DPPeer.SessionTerminated ' --------------------------------------------------------' Functions that handle player creation and destruction ' --------------------------------------------------------Private Sub PlayerDestroyed(sender As Object, _ dpMsg As PlayerDestroyedEventArgs) _ Handles DPPeer.PlayerDestroyed Public Sub SetUserInfo(Optional strPlayerName As String = "") Private Sub PlayerCreated(sender As Object, _
dpMsg As PlayerCreatedEventArgs) _ .NET Game Programming with DirectX 9.0 Handles DPPeer.PlayerCreated ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton ' --------------------------------------------------------Apress © 2003 (696 pages)
' Functions used to enumerate the hosts to the client, The to authors of thisthe text show how easy can be to produce ' Helping choose session to itjoin interesting multimedia games using Managed DirectX 9.0 and ' --------------------------------------------------------programming with Visual Basic .NET on Everett, the latest Public Function ChooseSessionToJoin() As Boolean version of Microsoft's Visual Studio. Public Sub EnumHosts() Private Sub EnumResponseMsg(sender As Object, _ Table of Contents dpMsg As FindHostResponseEventArgs) _ .NET Game Programming with DirectX 9.0 Handles DPPeer.FindHostResponse Foreword Public Sub EnumHostsCancel() PrefacePrivate Sub CancelAsync(sender As Object, _ Introduction dpMsg As AsyncOperationCompleteEventArgs) _ Chapter 1 - .Nettrix: GDI+ Handles and CollisionDPPeer.AsyncOperationComplete Detection Overrides Finalize() ChapterProtected 2 - .Netterpillars: Artificial Sub Intelligence and Sprites Chapter'3 --------------------------------------------------------- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ that read Scrolling, a data and packet when it arrives Chapter'4 Functions - River Pla.Net: Tiled will Game Fields, DirectAudio Chapter'5 --------------------------------------------------------- River Pla.Net II: DirectInput and Writing Text to Screen Private Sub MessageReceived(sender As Object, _ Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow dpMsg As ReceiveEventArgs) _ Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Handles DPPeer.Receive Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Protected Overridable Sub ProcessGameMessage(message As NetworkPacket) Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
' --------------------------------------------------------' Functions that will send a data packet to the target server Appendix A - The State of PC Gaming ' --------------------------------------------------------Appendix B - Motivations in Games Private Sub SendComplete(sender As Object, _ Appendix C - How Do I Make Games? dpMsg As SendCompleteEventArgs) _ Appendix D - Guidelines for Developing Games Handles Successful DPPeer.SendComplete Index Protected Sub SendData(message As NetworkPacket) List of Figures ' --------------------------------------------------------List of Tables ' Functions used on the host to create a session. ' If a name is not provided, we'll display a dialog ' to prompt for it ' --------------------------------------------------------Public Function CreateSession() As Boolean Public Function CreateSession(strSessionName As String) As Boolean Public Sub CloseConnection() End Class Bonus Chapter Porting .Nettrix to Pocket PC
It's quite a long class, but, referring to the class diagram in Figure 8-6, note that most of the methods are event handlers, and the most important ones match exactly the simple steps given earlier in this chapter to follow when creating DirectPlay games. Our methods are divided in to logical groups, surrounded by comments in the previous code listing. The only exception is the New procedure, which isn't related to any specific operation. In this method, we'll just create the Peer object, which will be used by many other methods, as shown in the following piece of code: Public Sub New() ' Create the main directplay object DPPeer = New Peer() End Sub
In the next sections we'll discuss the coding of those methods. .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
Coding theHatton Service Provider Methods
ISBN:1590590511
Apress © 2003 (696 pages)
For both client and server, the very first job is to choose the network service provider. Since there may be many The authors of this text show how easy it can be to produce service providers,interesting and each multimedia one is identified a unique GUID, we must list the service providers for the player gamesby using Managed DirectX 9.0 and to let him or her choose programming the desired with Visual one. Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
To do this, we'll create a simple window, with a list box and two buttons (OK and Cancel), so all we need to do in the code for the ChooseServiceProvider method is present our window, as shown in the next code Table of Contents listing: .NET Game Programming with DirectX 9.0 Foreword
Public Function ChooseServiceProvider() As Boolean Dim winChooseProvider As frmServiceProviders Introduction ChooseServiceProvider = True Preface
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter'2 The - .Netterpillars: Sprites DialogBoxArtificial will Intelligence call theand SetServiceProviderGUID to set Chapter'3 the - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ chosen service provider ChapterwinChooseProvider 4 - River Pla.Net: Tiled = Game Scrolling, and DirectAudio NewFields, frmServiceProviders() ChapterIf 5 winChooseProvider.ShowDialog() - River Pla.Net II: DirectInput and Writing Text <> toDialogResult.OK Screen Then
FalseADO.NET, and DirectShow -ChooseServiceProvider Magic KindergarteN.: Adventure=Games, End If Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API End Function Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Chapter 6
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
We will write the code for listing and choosing the service provider in the frmServiceProviders window, but since we'll need our class to store information about which service provider is chosen, we'll code the Appendix A - The State of PC Gaming SetServiceProvider method to receive the GUID and create an Address object pointing to the specified Appendix B - Motivations in Games service provider, as presented in the following code snippet: Bonus Chapter Porting .Nettrix to Pocket PC
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games
' This function will be called by the ChooseServiceProvider method Public Sub SetServiceProviderGUID(SPGUID As Guid) List of Figures ' Create a new address object with this service provider List of Tables DPAddress = New Address() 'Set the address's service provider (this will be the device address) DPAddress.ServiceProvider = SPGUID End Sub Index
TheSetServiceProvider method gives us the flexibility to set the GUID in the window or in any other code in the program that uses this class; so if we create a more sophisticated program, we can store the service provider in the registry and only present the window in the setup or under a configuration menu. Now let's see the code for the window. This window will have to present a list of all service providers registered on the system, which can be done by calling the GetServiceProviders method of the DPPeer object (created in the New method). This window is a separate part of our project, so we'll have to pass a reference to the current NetworkGame object from it so that it'll be able to list the service providers. The next code portion presents the customization we'll need to make to the New method of the window to receive this object and store it in a local variable for later use: Dim WithEvents objGameClient As ClsNetworkGame Public Sub New(GameClient As ClsNetworkGame) MyBase.New() objGameClient = GameClient
'This call is required by the Windows Form Designer. .NET Game Programming with DirectX 9.0 InitializeComponent() ISBN:1590590511 by Alexandre Santos Lobão and Ellen End Sub Hatton Apress © 2003 (696 pages)
The authors of our thisChooseServiceProvider text show how easy it can be to produce Of course, we'll need to adjust method by adding a reference to the current interesting multimedia games usingThe Managed DirectX 9.0method and object when calling the constructor of the window. new line in this will be as follows: programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
winChooseProvider = New frmServiceProviders(Me) Table of Contents .NET Once Game we make Programming the Peer with object DirectX accessible 9.0 to the window, we can code the Loadevent to add the items to the Foreword service providers list, as presented in the next code listing: Preface Introduction Sub frmServiceProviders_Load(sender As Object, e As EventArgs) _ Chapter 1 - .Nettrix: GDI+ and Collision Detection Handles MyBase.Load ChapterDim 2 -i.Netterpillars: As Integer Artificial Intelligence and Sprites
As ServiceProviderInformation() ChapterDim 3 -dpPeerSPInfo Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
up Pla.Net our list box with service providers Chapter'Fill 5 - River II: DirectInput and the Writing Text to Screen = objGameClient.DPPeer.GetServiceProviders(False) ChapterdpPeerSPInfo 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow = 0KindergarteN. To dpPeerSPInfo.Length - 1 and Speech API ChapterFor 7 -iMagic II: Animation Techniques lstServiceProviders.Items.Add(dpPeerSPInfo(i)) - .Netterpillars II: Multiplayer Games and Directplay Next D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 End Sub Nonmanaged Code Chapter 8
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B -see Motivations Games listing, the GetServiceProviders method of the Peer object returns a list As we can from theinprevious Appendix C How Do I Make Games? ofServiceProviderInformation objects that have the name GUID, and flags for each service provider. Appendix D -type Guidelines forimplements Developing Successful Games Since this of object the ToString method, it can be converted to strings and used by the list Index box. List of Figures
IN In Visual Basic .NET, we can add any type of object as an item of a list box, as long as it List ofNEW Tables .NET
implements the ToString method. This new feature is very useful, since we can build our own complex structures and classes and present them directly to the user. In the previous version, we had to create a separate array to store the objects, and search the array for a specific item.
In Figure 8-7, we can see the window that allows us to choose the service provider already listing the available service providers.
Figure 8-7: The Service Provider window To complete our window, the code for the Cancel button will simply close the window, setting the appropriated result, and the code for the OK button will call the SetServiceProviderGuid of the NetworkGame class and then close, as we can see in the following code sample: Sub btnCancel_Click(sender As Object, e As EventArgs) Handles btnCancel.Click
DialogResult = DialogResult.Cancel .NET Game Programming with DirectX 9.0 End Sub ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Sub btnOK_Click(sender As Object, e As EventArgs) Handles btnOK.Click Apress © 2003 (696 pages)
Try
The authors of this text show how easy it can be to produce objGameClient.SetServiceProviderGUID(lstServiceProviders.SelectedItem.guid) interesting multimedia games using Managed DirectX 9.0 and Catch programming with Visual Basic .NET on Everett, the latest MessageBox.Show("Please select a service provider before clicking OK.", _ version of Microsoft's Visual Studio. "No Service Provider", MessageBoxButtons.OK, _ MessageBoxIcon.Information) Table of Contents Return .NET Game with DirectX 9.0 End Programming Try Foreword DialogResult = DialogResult.OK Preface End Sub Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection If we want add registry Artificial support Intelligence to our window, Chapter 2 -to.Netterpillars: andmaking Sprites it store in the registry the last service provider chosen
and select-itManaged when theDirectX window is open next time, we can use the registry access objects present in the First Steps: Direct3D Basics and DirectX vs. GDI+ Microsoft.Win32 namespace.
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5 -we'll Riverneed Pla.Net II: DirectInput and Writing Screen and store the value chosen by adding extra To do this, to add an "Imports" clause Text in thetowindow, Chapter KindergarteN.: ADO.NET, and DirectShow code to6the- Magic OK button, as shownAdventure in the nextGames, code sample: Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 -Microsoft.Win32 .Netterpillars II: Multiplayer Games and Directplay Imports Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Sub btnOK_Click(sender As Object, e As EventArgs) Handles btnOK.Click ... Appendix - The State of PC Gaming ' ACreate a registry key with the service provider GUID Appendix B Motivations Games Dim RegKey AsinRegistryKey = _ Appendix C -Registry.CurrentUser.CreateSubKey("Software\\Games\\NetterpillarsII") How Do I Make Games? Appendix - Guidelines for Developing Successful Games IfD Not (RegKey Is Nothing) Then Index RegKey.SetValue("GameGuid", lstServiceProviders.SelectedItem.guid()) List of Figures RegKey.Close() End If List of Tables Bonus Chapter Porting .Nettrix to Pocket PC
We'll also need to include extra code in the Load method to read the value in the registry if the window has previously been used. The lines to be inserted open the registry keys and select the corresponding service provider from the window list, and are presented in the following listing: Sub frmServiceProviders_Load(sender As Object, e As EventArgs) _ Handles MyBase.Load . . . 'Get the default Service Provider from the registry if it exists Dim RegKey As RegistryKey = _ Registry.CurrentUser.OpenSubKey(_ "Software\\Games\\NetterpillarsII") If Not (RegKey Is Nothing) Then Try Dim DefaultGuid As Guid = RegKey.GetValue("ServiceProviderGUID", 0) For i = 0 To lstServiceProviders.Items.Count - 1 If lstServiceProviders.Items(i).GUID.Equals(DefaultGuid) Then lstServiceProviders.SelectedIndex = i End If Next
RegKey.Close() Catch.NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen lstServiceProviders.SelectedIndex = 0 Hatton End Try Else
Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce lstServiceProviders.SelectedIndex = 0 interesting multimedia games using Managed DirectX 9.0 and End If programming with Visual Basic .NET on Everett, the latest End Sub version of Microsoft's Visual Studio.
Table ofnext Contents In the section, we'll write the code for creating game sessions and joining them. .NET Game Programming with DirectX 9.0 Foreword
Coding the Session Methods
Preface
Introduction Although we are coding a single class, for the sessions there'll be specific methods executed by the host and Chapter others used 1 - .Nettrix: by the client. GDI+We'll and Collision discuss Detection these methods in separated sections so that we won't confuse the two. Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Creating and Destroying Chapter 3 - Managed DirectX First Sessions Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
To create a session in DirectPlay, we simply call the Host method of the Peer object, passing the appropriated - River Pla.Net II: DirectInput and Writing Text to Screen parameters, which enables us to receive connections from other computers.
Chapter 5 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 method - Magic KindergarteN. II:parameters: Animation Techniques and Speech API TheHost will receive two an ApplicationDescription object, which will give the Chapter game GUID 8 - .Netterpillars and the session II: Multiplayer name, andGames the Address and Directplay object, which points to the service provider to be used: Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Public Function CreateSession(strSessionName As String) As Boolean Try Appendix A -'The State of the PC Gaming Create application description object Appendix B -Dim Motivations in AppDescGames As New ApplicationDescription() Appendix C -AppDesc.GuidApplication How Do I Make Games? = GameGuid Appendix D -AppDesc.SessionName Guidelines for Developing Successful Games = strSessionName Index ' No special flags List of Figures AppDesc.Flags = 0 List of Tables'Host a game on DPAddress as described by AppDesc DPPeer.Host(AppDesc, DPAddress) CreateSession = True Catch e As DirectPlayException MessageBox.Show("Error when creating a session: " & e.ErrorString & _ " - " & e.ErrorString, "clsGameServer.CreateSession") CreateSession = False End Try End Function Bonus Chapter Porting .Nettrix to Pocket PC
We must follow here a rule of thumb for any program: Close what you opened. So we'll add code for the CloseConnection method, which can be called if the program wants to explicitly close the connection to other computers. Public Sub CloseConnection() DPPeer.Dispose() End Sub
These two methods will be used only by the Host, and they are all we need to create and destroy game sessions. Since many games will need a configuration screen to receive the session name from the player, we can add an extra Create-Session method that receives no parameter and presents a window that will ask for
the session name.
.NET Game Programming with DirectX 9.0
ISBN:1590590511 byan Alexandre Santos Lobãoisand Ellen The code for such overloaded method given in the next code section:
Hatton Apress © 2003 (696 pages)
Public Function CreateSession() As Boolean The authors of this text show how easy it can be to produce Dim WinCreateSession As frmCreateSession interesting multimedia games using Managed DirectX 9.0 and CreateSession = True programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
WinCreateSession = New frmCreateSession(Me) If WinCreateSession.ShowDialog() <> DialogResult.OK Then Table of Contents CreateSession = False .NET Game with DirectX 9.0 End Programming If Foreword End Function Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection The window that will receive the session nameand contains Chapter 2 - .Netterpillars: Artificial Intelligence Spritesonly a text box and two buttons, as shown in Figure 8-8. Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Figure 8-8: Entering a session name in the Server Configuration window D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
We'll add code in this window to receive the NetworkGame object and store the previous session name in the
Bonus Chapter Porting to Pocket PC window. We'll also call the CreateSession method in the registry, as shown in .Nettrix the Service Provider Appendix A The State of PC Gaming NetworkGame object to effectively create the session. The full code for this window is shown in the following Appendix listing: B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
Private objGameClient As ClsNetworkGame
Index List of Figures Public Sub New(GameClient As ClsNetworkGame) List of Tables MyBase.New()
'This call is required by the Windows Form Designer. InitializeComponent() objGameClient = GameClient 'Get the default session from the registry if it exists Dim RegKey As RegistryKey = _ Registry.CurrentUser.OpenSubKey(_ "Software\\Games\\NetterpillarsII") If Not (RegKey Is Nothing) Then txtSession.Text = RegKey.GetValue("DirectPlaySessionName", Nothing) RegKey.Close() End If End Sub Sub btnOK_Click(sender As Object, e As EventArgs) Handles btnOK.Click If ((txtSession.Text = Nothing) Or (txtSession.Text = "")) Then MessageBox.Show(Me, "Please enter a session name before clicking OK.", _ "No sessionname", MessageBoxButtons.OK, MessageBoxIcon.Information) Return End If ' Save the session name to the registry as a new default
Dim RegKey As RegistryKey = _ .NET Game Programming with DirectX 9.0 Registry.CurrentUser.CreateSubKey(_ ISBN:1590590511 by Alexandre Santos Lobão and Ellen "Software\\Games\\NetterpillarsII") Hatton If Not (RegKey Is Nothing) Then Apress © 2003 (696 pages) RegKey.SetValue("DirectPlaySessionName", txtSession.Text) The authors of this text show how easy it can be to produce RegKey.Close() interesting multimedia games using Managed DirectX 9.0 and End If programming with Visual Basic .NET on Everett, the latest If objGameClient.CreateSession(txtSession.Text) Then version of Microsoft's Visual Studio. Me.DialogResult = DialogResult.OK Else Table of Contents Me.DialogResult = DialogResult.Cancel .NET Game with DirectX 9.0 End Programming If Foreword End Sub Preface Introduction
In the next present the code that will run on the client side used to list all sessions on a specific Chapter 1 -section, .Nettrix:we'll GDI+ and Collision Detection host. 2 Chapter
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Listing Existing Sessions on a Remote Computer - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 4
Chapter 5 - River Pla.Net on II: a DirectInput and knowing Writing Text Screen To connect to a session host involves the to server name and the session name and GUID we want Chapter 6 -to, Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow to connect since all these pieces of information when used together uniquely define a session. We'll also Chapter - Magic KindergarteN. Techniques need to7get the player name as II: an Animation input so we can pass and it to Speech the hostAPI when connecting. Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay
OurChooseSessionToJoin method will be very similar to the one; it will only D-iNfEcT: Multithreading, Nonrectangular Windows, andChooseServiceProvider Access to create a window that prompts for the user name and presents a list of available sessions in a given host, as Nonmanaged Code presented in the next code listing: Bonus Chapter Porting .Nettrix to Pocket PC Chapter 9
Appendix A - The State of PC Gaming Appendix PublicB Function - MotivationsChooseSessionToJoin() in Games As Boolean
Dim As frmJoin Appendix C -WinJoin How Do I Make Games? ChooseSessionToJoin = True Appendix D - Guidelines for Developing Successful Games Index
WinJoin = New frmJoin(Me) List of Figures If WinJoin.ShowDialog() <> DialogResult.OK Then List of Tables ChooseSessionToJoin = False End If End Function
As in the ChooseServiceProvider method, we'll also pass the current object as a parameter to the window, which will be stored in a variable to be used in the window. However, as we'll see, connecting to a remote session takes a lot more effort than simply choosing a service provider. Figure 8-9 presents the window interface that will allow us to choose the session on the remote computer.
Figure 8-9: Join a session window The first problem in this window arises from the transitory nature of the sessions. We can't simply list all the sessions in a host when the window loads, because while the user types his or her name or reads the available
session names, the remote computer may already have closed some of them. We can work around this .NET Game Programming with DirectX 9.0 problem by inserting a timer in the window and including code for refreshing the list to remove items that are no ISBN:1590590511 Alexandre Santos longer valid, whilebyinserting new ones.Lobão and Ellen
Hatton Apress © 2003 (696 pages) Looking back at the GameNetwork class definition, we'll see that there is already a method that will list the Thecalled authors of this text show be Load to produce hosts and sessions, EnumHosts, so wehow caneasy callitit can in the event of the form and in the Tick event of interesting multimedia games using Managed DirectX 9.0 and the timer. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
TheEnumHosts method of our class will use the FindHosts method of the Peer class to loop through the sessions running on a specific host. Table of Contents
Tip TheFindHosts method enumerates sessions in a host, not hosts in a network, despite its name.
.NET Game Programming with DirectX 9.0
Foreword TheFindHosts method will receive the ApplicationDescription with information about the application Preface we are looking for, including its unique identifier, the Address that points to the service provider, and a handle Introduction that will be used to control the operation-which is asynchronous by default. The method also receives the Chapter Address 1 -of.Nettrix: the host, GDI+ which and is Collision optional,Detection and an enumeration value. Through this value we can set some method Chapter execution 2 -directives, .Netterpillars: forcing Artificial the method Intelligence to runand synchronously, Sprites to not use broadcasting if it's available, and to ask
for extra needed (forSteps: example, the host name if it's notvs. provided). Chapter 3 information - Managed if DirectX First Direct3D Basics and DirectX GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
FindHosts won't produce any visible results when called; we must code another function to handle the - River Pla.Net II: DirectInput and Writing Text to Screen FindHostResponse event of the Peer object, which will be called once for each session present on the Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow remote computer. To allow our NetworkGame class to pass information to the calling application, in this case Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API the window shown in Figure 8-9, we'll run an event on our handler function. Chapter 5
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Let's look atD-iNfEcT: all of these Multithreading, pieces one by Nonrectangular one, starting Windows, with the EnumHosts and Access to method, which will set the appropriate Chapter 9 Code parameters Nonmanaged and call the FindHosts method. Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Private EnumHostsAsyncHandle as integer
Appendix B - Motivations in Games Appendix - HowEnumHosts() Do I Make Games? PublicC Sub Appendix D -desc Guidelines for Developing Successful Games = New ApplicationDescription() Dim As ApplicationDescription Index ' Get the current game GUID from the class property List of Figures desc.GuidApplication = GameGuid List of Tables
'Try to enum the game hosts Try DPPeer.FindHosts(desc, Nothing, DPAddress, Nothing, Timeout.Infinite, _ 0, Timeout.Infinite, EnumHostsAsyncHandle, _ FindHostsFlags.OkToQueryForAddressing) Catch e As DirectPlayException MessageBox.Show("Error when looking for hosts: " & e.ErrorString) End Try End Sub
When we call the FindHosts method, it will present a window to the user asking for the host name, because we don't provide a specific host name. There's no way of customizing this window, which is shown in Figure 810. However, we can create our own window and pass the host name as the second parameter of the FindHosts method, which is receiving Nothing in the previous code listing.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and with method Visual Basic .NET Everett, the latest Figure 8-10:programming TheFindHosts asking foronthe host name version of Microsoft's Visual Studio.
In the following code sample, we see the event's definition (as shown in the class definition, earlier in this
Table of Contents chapter) and the code for the EnumResponseMsg method. This method is the handler of the .NET Game Programmingevent, with DirectX FindHostResponse which 9.0 will be triggered by DirectPlay when we call FindHosts. Foreword Preface
' Event used to enumerate hosts to connect
Introduction Public Event EnumHost(AppDesc As ApplicationDescription, _ Chapter 1 - .Nettrix: GDI+ and sender Collision Detection As Address, device As Address) Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 - Managed DirectX First Steps: Basics and DirectX vs. GDI+ Sub EnumResponseMsg(sender AsDirect3D Object, dpMsg As FindHostResponseEventArgs) _ Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Handles DPPeer.FindHostResponse Chapter'5 Generate - River Pla.Net an II: event DirectInput to and Writing Text to Screen
EnumHost(dpMsg.Message.ApplicationDescription, _ ChapterRaiseEvent 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow dpMsg.Message.AddressDevice) Chapter 7 dpMsg.Message.AddressSender, - Magic KindergarteN. II: Animation Techniques and Speech API End Sub Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
With these two methods, we'll be able to call EnumHosts from the window and receive events with the session data so we can update our list box; but three extra methods are needed to allow proper control of the Appendix A - The State of PC Gaming asynchronous session listing. Bonus Chapter Porting .Nettrix to Pocket PC Appendix B - Motivations in Games
Appendix C - one Howmethod Do I Make Games? We'll need to allow the main program to cancel the enumeration if it needs to, and another method Appendix D -the Guidelines Successful Games to receive result offor theDeveloping asynchronous operation when it's completed. Finally, we must explicitly cancel the Index asynchronous operation if the NetworkGame object has been destroyed to avoid errors that can arise if List of Figures DirectPlay sends an event and the calling object is no longer valid. List of Tables
The code for these methods is shown in the next listing: Public Sub EnumHostsCancel() If (EnumHostsAsyncHandle <> 0) Then DPPeer.CancelAsyncOperation(EnumHostsAsyncHandle) End If End Sub Private Sub AsyncComplete(sender As Object, _ dpMsg As AsyncOperationCompleteEventArgs) Handles _ DPPeer.AsyncOperationComplete If (dpMsg.Message.AsyncOperationHandle = EnumHostsAsyncHandle) Then EnumHostsAsyncHandle = 0 End If End Sub Protected Overrides Sub Finalize() MyBase.Finalize() If (EnumHostsAsyncHandle <> 0) Then DPPeer.CancelAsyncOperation(EnumHostsAsyncHandle) End If End Sub
With all these methods in place, we can now go to the window we created to list the sessions and start adding Programming with DirectX 9.0 code to the Load.NET eventGame and the Tick event of the timer, and coding the handler of the NetworkGame object ISBN:1590590511 by Alexandre Santos Lobão and Ellen that will update the list box in the window. Hatton Apress © 2003 (696us pages) The simplest code that will allow to list the sessions as shown in Figure 8-9 is given in the following code The authors of this text show how easy it can be to produce sample: interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Sub form_Load(sender version of Microsoft's As Object, Visual Studio. e As EventArgs) Handles MyBase.Load
'Enum the game hosts lstSession.Items.Clear Table of Contents objGameClient.EnumHosts() .NET EndGame Sub Programming with DirectX 9.0 Foreword Preface Sub ListHosts(AppDesc As ApplicationDescription, _ Introduction sender As Address, device As Address) Handles objGameClient.EnumHost Chapter lstSession.Items.Add(SessionInfo) 1 - .Nettrix: GDI+ and Collision Detection Chapter End Sub 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Sub tmrUpdateConnections_Tick(sender As System.Object, _ Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
e As II: System.EventArgs) tmrUpdateConnections.Tick - River Pla.Net DirectInput and WritingHandles Text to Screen 'Enum the game hosts Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ChapterlstSession.Items.Clear 7 - Magic KindergarteN. II: Animation Techniques and Speech API objGameClient.EnumHosts() Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Sub Chapter 5
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Although very simple, this code isn't effective, since the list box is cleared on each tick of the timer, creating a "flashing" effect for the player; the items are removed and included again at every timer cycle, making it Appendix C - for How Doplayer I Make impossible the toGames? select a specific session from the list. We need to store some extra information in Appendix D - to Guidelines forwhen Developing Successful the list box determine a specific item is Games included, so that it's only removed after a specific time-out (say, Index 2 seconds). Appendix B - Motivations in Games
List of Figures
The problem with this approach is that we are storing only the session names in the list box, whereas we'll List of main Tables need the host address and the device address (received as parameters by the ListHosts method), in addition to the inclusion time value, to allow us to connect to a remote session. We'll need to improve our routines to store all the information we need in the list box. We don't need to create an object for this-we can use a simple structure, as defined in the next code sample: Private Structure stSessionInfo Public LastEnumTime As Integer Public AppDesc As ApplicationDescription Public host As Address Public device As Address Public Overrides Function ToString() As String If AppDesc.MaxPlayers > 0 Then Return AppDesc.SessionName & " (Players: " & _ AppDesc.CurrentPlayers & "/" & AppDesc.MaxPlayers & ")" Else Return AppDesc.SessionName & " (Players: " & _ AppDesc.CurrentPlayers & ")" End If End Function 'ToString End Structure
.NET Game Programming with DirectX 9.0 get an error when trying to include the object in In this structure, the ToString method is mandatory, or we'll ISBN:1590590511 by box Alexandre Ellen the list box. The list alwaysSantos looks Lobão for thisand conversion method to find out what to show the user. Hatton
© 2003 (696 pages) The new version Apress of the ListHosts method that will store all values in the list box is shown in the next listing:
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
Sub ListHosts(AppDesc As ApplicationDescription, _ programming with Visual Basic .NET on Everett, the latest hostversion As Address, device As Address) Handles objGameClient.EnumHost of Microsoft's Visual Studio. Dim Found As Boolean = False Dim i As Integer Table of Contents Dim SessionInfo As stSessionInfo = New stSessionInfo() .NET Game with DirectX 9.0 WithProgramming SessionInfo Foreword .AppDesc = AppDesc Preface .device = device Introduction .host = host Environment.TickCount Chapter 1 -.LastEnumTime .Nettrix: GDI+ and = Collision Detection End With Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ the listTiled of Game items first and and see if this one already exists Chapter'Check 4 - River Pla.Net: Fields, Scrolling, DirectAudio
For -iRiver = 0Pla.Net To lstSession.Items.Count - 1 II: DirectInput and Writing Text to Screen If SessionInfo.AppDesc.GuidInstance.Equals( _ Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow lstSession.Items(i).AppDesc.GuidInstance) Then Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API lstSession.Items(i) = SessionInfo Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Found = True D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -End If Nonmanaged Code Next Chapter 5
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
'If the item is not on the list, add it If Not Found Then Appendix C -lstSession.Items.Add(SessionInfo) How Do I Make Games? Appendix D -If Guidelines for Developing Successful Games End Index End Sub Appendix B - Motivations in Games
List of Figures List of Tables
In the previous code sample, we checked for repeated items before including any values in the list, since now we won't clear the items from the list every time we want to enumerate the sessions. TheTick event of the timer will also need to be updated to check for timedout items and remove them from the list, as we can see in the following code listing: Sub tmrUpdateConnections_Tick(sender As System.Object, _ e As System.EventArgs) Handles tmrUpdateConnections.Tick Dim i As Integer ' Remove any timed-out sessions For i = 0 To lstSession.Items.Count - 1 'Check to see if this session has expired (every 2 seconds) If (Environment.TickCount - lstSession.Items(i).LastEnumTime > 2000) Then lstSession.Items.RemoveAt(i) Exit For End If Next 'Enum the game hosts objGameClient.EnumHosts() End Sub
Since we are now removing only the timed-out items and including only extra sessions in the list, we can set the .NET Game Programming with DirectX 9.0 timer to do updates at shorter time intervals- for example, every 500 ms (although we should keep it at every ISBN:1590590511 by are Alexandre Santos Lobão and Ellen second or two if we using the Internet). Hatton Apress 2003how (696 to pages) In the next section, we'll ©see connect to a remote session using the data collected when we listed all The authors of this text show how easy it can be to produce sessions on a host. interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Connecting to a Remote Session version of Microsoft's Visual Studio.
Once we have the remote host address, the address of the device, and the ApplicationDescription that uniquely defines a remote session, we can connect to the host by calling the Connect method of the Peer Table of Contents object, as we can see inwith the DirectX next code .NET Game Programming 9.0 snippet: Foreword
Public Function Connect(AppDesc As ApplicationDescription, _ Preface host As Address, device As Address) As Boolean Introduction ChapterDPPeer.Connect(AppDesc, 1 - .Nettrix: GDI+ and Collision host, Detectiondevice, Nothing, _
ConnectFlags.OkToQueryForAddressing) - .Netterpillars: Artificial Intelligence and Sprites End Function Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 2 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5 object - River will Pla.Net II: an DirectInput Writing Textsaying to Screen ThePeer trigger event to and the application that the connection has been completed. Since Chapter 6 - Magic KindergarteN.: Adventurethe Games, ADO.NET, and DirectShow ourNetworkGame class is encapsulating features from DirectPlay, we'll also trigger an event to the main Chapter 7 so - Magic Techniques Speech API program that it KindergarteN. will know thatII: theAnimation connection has beenand completed. Besides the connection result code, we'll Chapter - .Netterpillars II: Multiplayer Games and Directplay send a 8Boolean value indicating the connection result (true for connected, false for error) so the application can D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to easily check Chapter 9 - if it's connected or not. Nonmanaged Code
The following code sample Bonus Chapter Porting .Nettrixpresents to Pocketthe PC event definition and the handler for the ConnectComplete event of thePeerAobject: Appendix - The State of PC Gaming Appendix B - Motivations in Games Appendix PublicC Event - How Do ConnectionResult(connected I Make Games? As Boolean, errcode As ResultCode) Appendix D - Guidelines for Developing Successful Games
Private Sub ConnectResult(sender As Object, _ Index dpMsg As ConnectCompleteEventArgs) Handles DPPeer.ConnectComplete If (dpMsg.Message.ResultCode = 0) Then List of Tables RaiseEvent ConnectionResult(True, dpMsg.Message.ResultCode) Else RaiseEvent ConnectionResult(False, dpMsg.Message.ResultCode) End If End Sub List of Figures
The last thing we must do to complete the coding that deals with connections is to write the event handler for theSessionTerminated event of the Peer object so we can inform the main application that the session has been terminated, which usually happens when we face a network problem or the remote computer has disconnected. Public Event SessionTerminated(msg As TerminateSessionMessage) Private Sub SessionFinished(sender As Object, _ dpMsg As SessionTerminatedEventArgs) Handles DPPeer.SessionTerminated ' Well, this session is being terminated, let the user know RaiseEvent SessionTerminated(dpMsg.Message) End Sub
In the next section, we'll see the code that will enable us to access the features in DirectPlay to manage players.
.NET Game Programming with DirectX 9.0
Managing Players by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton There are three operations we must code to equip our NetworkGame class with basic user management Apress © 2003 (696 pages)
capabilities:SetUserInfo, which will enable the program to give the local player's name; PlayerCreated, The authors of this text show how easy it can be to produce which will trigger interesting events in the main application to inform the DirectX host that a and new player has connected to a given multimedia games using Managed 9.0 session; and PlayerDestroyed, which Basic will be.NET called when a player has disconnected. programming with Visual on Everett, the latest version of Microsoft's Visual Studio.
The next code listing presents the first of these methods, which will call the SetPeerInformation method of thePeer object to set the player data. This same method can be used to set information about the server and Table of Contents groups, if we need it to. .NET Game Programming with DirectX 9.0 Foreword Public Sub SetUserInfo(Optional strPlayerName As String = "") PrefaceIf strPlayerName <> "" Then Introduction PlayerName = strPlayerName ChapterEnd 1 -If .Nettrix: GDI+ and Collision Detection ChapterPlayerInfo.Name 2 - .Netterpillars: Artificial Intelligence and Sprites = PlayerName ChapterDPPeer.SetPeerInformation(PlayerInfo, 3 - Managed DirectX First Steps: Direct3D Basics andSyncFlags.PeerInformation) DirectX vs. GDI+
End Sub Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
The following listing presents the code for the event handlers that will manage the player events sent by the - Magic KindergarteN. II: Animation Techniques and Speech API Peer object. We'll also use these methods to update the PlayerCount property, which will store the number Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay of players in the current session. Chapter 7
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Public PlayerCount AstoInteger Bonus Chapter Porting .Nettrix Pocket PC = 1 ' Start Counting the local player Appendix A - The State of PC Gaming
' Events used to in handle Appendix B - Motivations Games Players Public Event NewPlayer(Name As String, ID As Integer) Public Event RemovePlayer(PlayerId As Integer)
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index
Private Sub PlayerDestroyed(sender As Object, _ dpMsg As PlayerDestroyedEventArgs) Handles DPPeer.PlayerDestroyed List of Tables ' Send an event informing that the player is out from our session RaiseEvent RemovePlayer(dpMsg.Message.PlayerID) ' Update our number of players PlayerCount -= 1 End Sub List of Figures
Private Sub PlayerCreated(sender As Object, _ dpMsg As PlayerCreatedEventArgs) Handles DPPeer.PlayerCreated ' Get the PlayerInfo and store it Dim dpPlayerInfo As PlayerInformation dpPlayerInfo = DPPeer.GetPeerInformation(dpMsg.Message.PlayerID) If Not dpPlayerInfo.Local Then ' This isn't me, send an event with this player data RaiseEvent NewPlayer(dpPlayerInfo.Name, dpMsg.Message.PlayerID) ' Update our number of players PlayerCount += 1 Else ' Store our player ID number PlayerID = dpMsg.Message.PlayerID End If End Sub
We are now able.NET to create and list hosts, create session 9.0 and connect to a remote one, and manage players in Game Programming withaDirectX ourNetworkGame class. All we need to do now to complete our class is to code the message handling ISBN:1590590511 by Alexandre Santos Lobão and Ellen routines, which we do in the next section. Hatton Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce Handling Messages interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
Both the host andversion the clients will have to include code for methods to send messages and to handle received of Microsoft's Visual Studio. messages. To send messages is simply a matter of calling the SendTo method of the Peerobject. This method receives Table of Contents a network packet with the message content to send, the chosen timeout, and the ID of the remote player. We .NET Game Programming with DirectX 9.0 can send messages to all other players by specifying zero as the remote player ID. The last parameter in this method lets us specify the message characteristics, like the priority or whether the message will loop back to Preface the sender or not. The flags used in the following code sample will suffice for any simple game: Foreword
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Protected Sub SendData(message As NetworkPacket) - .Netterpillars: Artificial Intelligence and Sprites ' timeout 200 ms Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ ' Server ID = 0 send messages to everyone Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio DPPeer.SendTo(0, message, 200, SendFlags.NoLoopback Or SendFlags.NoCopy) Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen End Sub Chapter 2
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter DirectPlay 8 -gives .Netterpillars the result II:ofMultiplayer the send operation Games andbyDirectplay firing the SendCompleteevent of the Peer object. We
can handle- this D-iNfEcT: event Multithreading, and generate an Nonrectangular error event for Windows, the application and Access if anything to goes wrong, as presented in Nonmanaged Code the next code listing:
Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC Appendix - The State of PC Gaming PublicA Event SendError(errCode As ResultCode) Appendix B - Motivations in Games Appendix C -Sub How Do I Make Games? Private SendComplete(sender As Object, _ Appendix D - Guidelines forAs Developing Successful Games dpMsg SendCompleteEventArgs) Handles DPPeer.SendComplete Index ' Send an error event if we couldn't send the packet List of Figures If dpMsg.Message.ResultCode <> 0 Then List of TablesRaiseEvent SendError(dpMsg.Message.ResultCode)
End If End Sub
As for the arriving messages, we won't include any special treatment in the NetworkGame class, since every game must define its own set of messages. We'll instead include the code for an overridable function that receives a network packet, and that will effectively be coded in the derived classes, as presented in the following code sample: Private Sub MessageReceived(sender As Object, _ dpMsg As ReceiveEventArgs) Handles DPPeer.Receive ProcessGameMessage(dpMsg.Message.ReceiveData) End Sub Protected Overridable Sub ProcessGameMessage(message As NetworkPacket) ' This function must be coded by the derived classes ' that will handle the message received according to ' the game needs End Sub
This concept of creating an overridable function isn't new; we used it when creating the GameEngine class in .NET Game Programming with DirectX 9.0 Chapters 4 through 7. This special function type allows us to define in the base class a function that is coded by by but Alexandre Lobãoin and the derived classes called Santos by methods theEllen base class. ISBN:1590590511 Hatton Apress © 2003 (696 pages) In the next section, we take a look at a simple example that will help us to put all the concepts we have seen here together. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Testing the NetworkGame Class
In this section, we'll create a very simple example that will help us understand and test the NetworkGame class. Table of Contents .NET We'll Game create Programming a window with withthree DirectX buttons 9.0 and two text boxes that allows us to create a host, connect to a host,
and send messages between client and server. Figure 8-11 presents the window we'll use in the sample. Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 8-11: The window to test our NetworkGame class The first step to using our NetworkGame class is to include this class in our project, as well as the windows that are used by it when choosing service providers, sessions, and setting the session name. The next step is to create a class to handle the game-specific messages derived from the NetworkGame class. In our example, we'll create a simple class that sends a message composed of two numbers, the player ID and a message code, which will be entered by the user. The following code presents a full listing of the NetworkGameTest class, used in our sample: Inherits ClsNetworkGame Private Structure GameMsg Public PlayerId As Integer Public MessageCode As Integer End Structure
Public Event .NET MessageArrived(PlayerID Game Programming with DirectX As Integer, 9.0 MessageCode As Integer) by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton ' ----------------------------------------------------------------Apress © 2003 (696 pages) ' The next function processes the arrived messages ' ----------------------------------------------------------------The authors of this text show how easy it can be to produce interesting Sub multimedia games using Managed DirectX 9.0As andNetworkPacket) Protected Overrides ProcessGameMessage(Message programming with Visual Basic .NET on Everett, the latest Dim Msg As GameMsg version of Microsoft's Visual Studio. Msg = CType(Message.Read(GetType(GameMsg)), GameMsg)
RaiseEvent MessageArrived(Msg.PlayerId, Msg.MessageCode) Table of Contents EndGame Sub Programming with DirectX 9.0 .NET Foreword
Public Sub SendMessage(message As Integer) Preface Dim Msg As GameMsg Introduction Dim -gameMsgPacket As New NetworkPacket() .Nettrix: GDI+ and Collision Detection
Chapter 1 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
' Fill the message fields - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Msg.MessageCode = message Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Msg.PlayerId = Me.PlayerID Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen ' Put the message on a packet and send it ChaptergameMsgPacket.Write(Msg) 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ChapterSendData(gameMsgPacket) 7 - Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Sub Chapter 3
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix As we can A -see, The State all weofneed PC Gaming to include in the derived class is the code for dealing with the game-specific
messages. other features will be obtained from the base class. Appendix B - All Motivations in Games Appendix C - How Do I Make Games?
In the example window, we'll need to define an object from our class using the WithEvents clause, so we can handle the MessageArrived event, defined in the previous code sample.
Appendix D - Guidelines for Developing Successful Games Index
List of Figures
Public WithEvents NetworkGameTest As clsNetworkGameTest
List of Tables
The code for the Create Host button will simply call the ChooseServiceProviderand the CreateSession methods, and the class will present any necessary windows to gather user information, so we can create our host with only two lines of code. Of course, our program will usually include some error checking to display messages to the user if anything goes wrong. The next code listing presents the full code for the Create Host button: Sub cmdHost_Click(sender As Object, e As EventArgs) Handles cmdHost.Click NetworkGameTest = New clsNetworkGameTest() ' Choose the service provider If Not NetworkGameTest.ChooseServiceProvider() Then MessageBox.Show("Error when choosing tyhe service provider") Me.Close() Else ' Create the session If Not NetworkGameTest.CreateSession() Then MessageBox.Show("Error when creating a session") Me.Close() Else ' Enable the send button cmdSend.Enabled = True
End If End If .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen End Sub
ISBN:1590590511
Hatton Apress © 2003 (696 pages)
The authors of this text show how it can to produce The Connect to Host button will be very similar: Byeasy calling thebe ChooseServiceProvider and interestingmethods, multimedia using DirectX 9.0 andhost, as presented in the next code ChooseSessionToJoin wegames are able to Managed connect to the remote programming with Visual Basic .NET on Everett, the latest sample: version of Microsoft's Visual Studio.
Sub cmdConnect_Click(sender As Object, e As EventArgs) Handles cmdConnect.Click Table ofNetworkGameTest Contents = New clsNetworkGameTest() .NET Game Programming DirectXprovider 9.0 ' Choose the with service Foreword If Not NetworkGameTest.ChooseServiceProvider() Then Preface MessageBox.Show("Error when choosing tyhe service provider") Introduction Me.Close() ChapterElse 1 - .Nettrix: GDI+ and Collision Detection Chapter 2
Not NetworkGameTest.ChooseSessionToJoin() Then -If .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
MessageBox.Show("Error a session") - Managed DirectX First Steps: Direct3D when Basics connecting and DirectX vs. to GDI+
Chapter 4
- RiverMe.Close() Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
-Else River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
Enable theAdventure send button - Magic'KindergarteN.: Games, ADO.NET, and DirectShow
cmdSend.Enabled = True End If Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End If D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 End Sub Nonmanaged Code Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
With two extra lines of code, we'll be able to send and receive messages from the remote player. The next
Appendix B - Motivations Games listing presents the finalinlines of our simple example: Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games
Sub cmdSend_Click(sender As Object, e As EventArgs) Handles cmdSend.Click NetworkGameTest.SendMessage(CInt(txtSendMessage.Text)) List of Figures End Sub Index
List of Tables
Sub NetworkGameTest_MessageArrived(PlayerID As Integer, MessageCode As Integer) _ Handles NetworkGameTest.MessageArrived txtArrivedMessage.Text = "PlayerID: " & PlayerID & " Value: " & MessageCode End Sub
The full code for this sample is on the accompanying CD-ROM. It's the project named NetworkGameTest inside the Chapter 8 directory. In the next section, we'll discuss the proposal for the sample game of this chapter, where we exercise the concepts discussed in the previous sections.
.NET Game Programming with DirectX 9.0 The Game Proposal by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton As we've said, we're going to create a multiplayer version of the .Netterpillars game, built in Chapter 2. Apress © 2003 (696 pages)
It's not typically aThe good approach to text convert game from single player to multiplayer. However, although authors of this showa how easy it can be to produce we didn't say this interesting in Chaptermultimedia 2, the game is already designedDirectX to be multiplayer. Even so, if we analyze the games using Managed 9.0 and programming onbe Everett, the latest code phase in detail, we'll see with that Visual some Basic things.NET could done better if we had decided to make a version Microsoft's Visual Studio. multiplayer version of theofgame from scratch. In the multiplayer version, we'll have two extra options: Host a Death Match, which will prompt the player for the session name and enable his or her machine to receive remote connections, and Join a Death .NET Game Programming 9.0connect to a remote player machine. Match, which will enablewith theDirectX player to
Table of Contents Foreword
A death match will be a special type of game in which two players can play one another, in a mediumPreface sized game field, with a fixed number of mushrooms. In this case, there won't be any configurations for the Introduction number1 of-players, game size,Detection or the quantity of mushrooms. Chapter .Nettrix:the GDI+ andfield Collision Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
The criteria for ending this game will also be different from the stand-alone version: The game will only - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ end when a player dies, even if the players have eaten all the mushrooms.
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter - River Pla.Net II: DirectInput Writing screen Text to Screen Besides5 this additional feature, we'll addand a specific at the game's end that will display the name of Chapter the winner 6 -and Magic theKindergarteN.: length of each Adventure player's netterpillar. Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Refer back- to the game proposal in Chapter 2 to review all the details from the first version of the game, .Netterpillars II: Multiplayer Games and Directplay which will still be valid in this chapter sample.
Chapter 8 Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
In the next section we'll discuss some technical details about our game.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Game Project by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton We'll follow the same project created in Chapter 2, adding the class diagram we saw in the section Apress ©earlier 2003 (696 "Introducing DirectPlay" in pages) this chapter. The authors of this text show how easy it can be to produce
To complete the interesting project for multimedia our multiplayer game, we need to do 9.0 is clearly games usingall Managed DirectX and define the message flow programming with and Visual ontype Everett, the latestwe'll use in our game. between the server and the client, to Basic define.NET each of message version of Microsoft's Visual Studio.
Table 8-1 presents all the game messages with details. Table of Contents
Table 8-1: .Netterpillars II Messages
.NET Game Programming with DirectX 9.0
MESSAGE Foreword Preface
SyncGameField
Introduction
ORIGIN
DESTINATION
MEANING
DATA
Server
Client
Synchronize the mushroom positions.
Array with mushroom positions
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
OkToStartGame Client First Steps: ServerDirect3D Basics Inform the server that the Chapter 3 - Managed DirectX and DirectX vs. GDI+ Chapter 4
game field is - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
synchronized. - River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow NetterDirection Both Both Send the local player Chapter 7
- Magic KindergarteN. II: Animation Techniques and API input toSpeech the remote
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay machine.
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 EndDeathMatch Both Both Inform the remote player Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
that the local player is dead.
N/A
Direction of the movement ID of the dead player
Appendix B - Motivations in Games Appendix C - How Do I Make Games? TheEndDeathMatch message may seem unnecessary: Because the game fields are synchronized, the Appendix D - Guidelines for Developing Successful Games remote player will already know that the local player is dead when he or she hits a wall. Nevertheless, it's Index useful when a local player quits, because one player can wait forever for the next message if we don't List of Figures inform him or her that the other player is leaving the game. List of Tables
In the next steps, we describe the game's basic flow, including the message exchange between server and client: 1. The server creates a session and creates a game field, populating it with mushrooms. 2. The client connects to the session, and creates an empty game field. 3. The server receives the information from DirectPlay that a remote player has connected. 4. The server sends an array with the position of all mushrooms to the client (SyncGameField message). 5. The client populates its game field with the mushrooms in the same position as the mushrooms on the game field of the server. 6. The client informs the server that it has finished the synchronization (OkToStartGame message). 7. The server gets the input from the local player and sends it to the client (NetterDirection message). 8. The client receives the information about the remote player's movements, and gets the input from the local player. 9. The client updates the netterpillar positions in the game field, and sends the local player's movement information to the server. 10.
9. 10. The host receives the information about the remote player's movements, and updates the .NET Game Programming with DirectX 9.0 netterpillar positions in the game field. by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton 11. Steps 7 through 10 repeat until a player is dead. Apress © 2003 (696 pages)
12. When a player is deadof(client or server), theeasy local the EndDeathMatch message The authors this text show how it machine can be to sends produce interesting multimedia games using Managed DirectX 9.0 and to the remote machine. programming with Visual Basic .NET on Everett, the latest version of the Microsoft's Visual Studio. 13. Both machines end game at the same time.
Tip Review these steps until you are sure you understand exactly what we'll do in the coding phase.
Table of Contents
.NET Programming DirectX 9.0entering the code phase is redefining the main program workflow, OneGame last point we must with explore before Foreword which changed with the inclusion of multiplayer features. Figure 8-12 presents the previous flow, used in Preface Chapter 2 for the standalone version of the game. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 8-12: The main program workflow for the stand-alone version of .Netterpillars Our aim is to include the multiplayer options without modifying the main program workflow, so we could use most of the code from the previous version without making any huge adjustments. Figure 8-13 presents the proposed workflow for the main program of .Netterpillars II.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Figure The main program workflow for the multiplayer version of .Netterpillars Appendix B - 8-13: Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
As we can see, apart from the inclusion of the extra options to the introduction screen, all we did was
Index include a different game over screen. List of Figures
In the next section, we'll code this chapter's sample game. List of Tables
Game Programming with DirectX 9.0 The Coding.NET Phase by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton In this chapter, we won't present all the code for .Netterpillars II, since most of it was developed in Chapter 2 © 2003 (696 and is replicated Apress here without any pages) significant updates. We'll instead focus on the modifications we need to do to adapt the game to run as a multiplayer The authors of this text game. show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and with Visualthe Basic .NETphase on Everett, the latest As in the previousprogramming chapters, we'll divide coding into discrete steps so that it'll be easier to understand version of Microsoft's Visual Studio. each of them:
1. First draft: Code the splash (opening) screen and the main program. Table of Contents
2. Second draft: Code the class that will handle the game messages.
.NET Game Programming with DirectX 9.0
Foreword 3. Third draft: Add multiplayer features to the GameEngine class. Preface
4. Fourth draft: Write the multiplayer message handlers. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
5. Final version: Code the game over screen.
Chapter 3 -section Managed DirectX Steps: the Direct3D Basics DirectX vs. GDI+ In the next we'll start First discussing first draft of and our game. Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen First Draft: Coding the Splash Screen and the Main Program Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter Magic KindergarteN. Animation Techniques and Recall 7that- the splash screen weII:created in Chapter 2 has noSpeech code, API except for the call to the configuration Chapter 8 .Netterpillars II: Multiplayer Games and Directplay screen when pressing the Config button. Both Exit and Play buttons don't have any code; we simply set their D-iNfEcT: Multithreading, Nonrectangular Windows, andwindow Access automatically. to DialogResult to "Cancel" and "OK" values, so they close the Chapter 9 Nonmanaged Code Bonus We'll Chapter follow the Porting same.Nettrix approach to Pocket with the PC new buttons we need to create: the Host a Death Match button and the
Join a Death Match Since there are no appropriate values to represent this type of result, we'll simply set Appendix A - The Statebutton. of PC Gaming theirDialogResult property to Yes and No. This could be any other value, as long as it's different from those Appendix B - Motivations in Games already used; theDo main program will deal with the various dialog return values. Appendix C - How I Make Games? Appendix D - Guidelines for Developing Successful Games
Figure 8-14 presents the new splash screen, including the two additional buttons and a slightly different background image.
Index
List of Figures List of Tables
Figure 8-14: .Netterpillars II splash screen
In the main routine, we'll have only two updates: setting the game network type (host, client, or none) according .NET Game Programming with DirectX 9.0 to the result of the splash screen, and presenting the proper game over screen according to the network type. by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton To store the game network type, we'll create a new enumeration and a new property in the GameEngine class, Apress 2003 (696 pages) as presented in the next©code sample: The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and 'Update to NetWork Gaming: NewBasic enum tooncontrol network types programming with Visual .NET Everett, the latest Public Enum enNetWorkGame version of Microsoft's Visual Studio.
No = 0 Host = 1 Table of Contents Client = 2 .NET Game Programming with DirectX 9.0 End Enum Foreword 'Update to NetWork Game: variable to store the network gaming type Preface Public NetWorkType As enNetWorkGame Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites The next listing DirectX shows the main procedure. The updates are marked with comments in the code; Chapter 3 code - Managed Firstupdated Steps: Direct3D Basics and DirectX vs. GDI+
if you have- any doubts about any other part of the procedure, refer to Chapter 2 for a full explanation of this River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio routine.
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Sub main() Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Dim -WinSplash As frmSplash .Netterpillars II: Multiplayer Games and Directplay Dim WinGameField As frmGameField D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterDim 9 -WinGameOver As New frmGameOver() Nonmanaged Code Dim WinDeathMathGameOver Bonus Chapter Porting .Nettrix to Pocket PCAs New FrmDeathMatchGameOver() Dim LastTick As Integer, DesiredFrameRate As Single = 10 Appendix A - The State of PC Gaming Dim SplashResult As DialogResult Appendix B - Motivations in Games ' Create the game engine object Appendix C - How Do I Make Games? objGameEngine = New clsGameEngine() Appendix D - Guidelines for Developing Successful Games WinSplash = New frmSplash() Chapter 8
Index
List of Figures ' Loop until the user selects "Exit" on the main screen List of Tables Do While True
' Update to network gaming: handle different results ' from the opening screen: ' DialogResult.Cancel = Close game ' DialogResult.OK = Start a new standalone game ' DialogResult.Yes = Host a death match game ' DialogResult.No = Join a death match game SplashResult = WinSplash.ShowDialog() Select Case SplashResult Case DialogResult.OK objGameEngine.NetWorkType = clsGameEngine.enNetWorkGame.No Case DialogResult.Yes objGameEngine.NetWorkType = clsGameEngine.enNetWorkGame.Host Case DialogResult.No objGameEngine.NetWorkType = clsGameEngine.enNetWorkGame.Client Case DialogResult.Cancel Exit Do End Select WinGameField = New frmGameField() WinGameField.Show() Application.DoEvents() 'Creates a copy of the background image to allow erasing the sprites
objGameEngine.BackgroundImage = WinGameField.PicGameField.Image.Clone .NET Game Programming with DirectX 9.0 objGameEngine.CreateGameField(WinGameField.PicGameField.Handle) ISBN:1590590511 by Alexandre Santos Lobão and Ellen Do While Not objGameEngine.GameOver Hatton If Not objGameEngine.Paused Then Apress © 2003 (696 pages) ' Force a Frame rate of 10 frames per second on maximum The authors of this text show how easy it can be to produce If System.Environment.TickCount LastTick >= _ interesting multimedia games using Managed DirectX 9.0 and 1000 / Basic DesiredFrameRate Then programming with Visual .NET on Everett, the latest MoveComputerCharacters() version of Microsoft's Visual Studio. objGameEngine.Render() LastTick = System.Environment.TickCount Table of Contents End If .NET Game Programming with DirectX 9.0 End If Foreword Application.DoEvents() Preface Loop Introduction ' Close the current connection, if it's open Chapter 1 -Try .Nettrix: GDI+ and Collision Detection objGameEngine.GameClient.CloseConnection() Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Chapter 3 -Catch Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Ignore errors Chapter 4 - River 'Pla.Net: Tiledany Game Fields, Scrolling, and DirectAudio Chapter 5 -End RiverTry Pla.Net II: DirectInput and Writing Text to Screen ' Update to Network game: different game over screens Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow If objGameEngine.NetWorkType = clsGameEngine.enNetWorkGame.No Then Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API WinGameOver.ShowDialog() Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Else D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 WinDeathMathGameOver.ShowDialog() Nonmanaged Code End If Bonus Chapter Porting .Nettrix to Pocket PC WinGameField.Dispose() Appendix A - The State of PC Gaming Loop Appendix B - Motivations in Games objGameEngine = Nothing Appendix C - How Do I Make Games? WinSplash.Dispose() Appendix D - Guidelines for Developing Successful Games WinGameOver.Dispose() Index End Sub List of Figures List of Tables
In the next section, we'll code the NetworkNetterpillars class, the class derived from the GameNetwork class that will handle our game-specific messages.
Second Draft: Coding the NetworkNetterpillars Class As we discussed earlier in this chapter when coding the GameNetwork class, each game has its own set of messages, so every game that wants to use this class must code its own derived class, which must code the ProcessMessage method to manage its messages. In our case, we'll create a class named NetworkNetterpillars. Referring to our game project, we'll see that we planned four different messages for this game: SyncGameField,OkToStartGame,NetterDirection, and EndDeathMatch. For each of these messages to really encapsulate the networking details from our program, we'll have to create methods to send messages to the remote player and to process the incoming messages. Both methods from each message will heavily depend on the message format, so the first step to coding our class must be to code the message structures. We'll create an enumeration to define the message type. Following the guide given in Table 8-1, in the game project we'll create a specific structure for each message, plus a generic structure used to read the message type.
The next code presents the enumeration plus the structures for each message: .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Private Enum Hatton gameMessageType SyncGameField 0 (696 'Message containing one array to sync the game field Apress ©=2003 pages) OkToStartGame = 1 'Message to start the game The authors of this text show how easy it can be to produce NetterDirection = 2 interesting multimedia games using Managed DirectX 9.0 and EndDeathMatch programming = 3 with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio. End Enum ' ----------------------------------------------------------------' We need to create one specific structure to read each message type; Table of Contents ' plus one structure that will be used for reading the message type code. .NET Game Programming with DirectX 9.0 ' ----------------------------------------------------------------Foreword ' Structure used only for reading the message type Preface Private Structure GameMsg_Generic Introduction Public Type As gameMessageType 'What type of packet is this? ChapterPublic 1 - .Nettrix: GDI+ and Detection PlayerId AsCollision Integer ' Who sent this message? Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites End Structure Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 - Riverused Pla.Net: Tiled for Gameinforming Fields, Scrolling, and DirectAudio of the next ' Structure only the direction Chapter ' movement 5 - River ofPla.Net the II: Netterpillar DirectInput and Writing Text to Screen
Private GameMsg_NetterDirection Chapter 6 -Structure Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Type As gameMessageType 'What and type of packet is this? ChapterPublic 7 - Magic KindergarteN. II: Animation Techniques Speech API PlayerId Integer ' Who sent this message? ChapterPublic 8 - .Netterpillars II: As Multiplayer Games and Directplay Public Direction As Byte D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to End Structure Nonmanaged Code
Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC
' Structure usedof only for informing about the end of the Death Match Appendix A - The State PC Gaming Private Appendix B -Structure Motivations inGameMsg_EndDeathMatch Games Public As gameMessageType 'What type of packet is this? Appendix C - HowType Do I Make Games? Public PlayerId As Integer ' Who sent this message? Public PlayerKilled As Byte Index End Structure Appendix D - Guidelines for Developing Successful Games List of Figures List of Tables
In the previous code sample, we used the generic message structure to send any messages that only need to include the message code (such as the OkToStartGame message). We'll also use the generic message type to send messages that can't fit into a structure, such as messages that have strings or arrays (for example, the SyncGameField message). Let's start looking at the logic of sending the messages to the remote player.
Creating the Methods That Send Messages Looking back at the GameNetwork class, we can see that we already have a function that will send generic data through the network: the SendData method. This method receives a NetworkPacket variable as a parameter. Note ANetworkPacket is similar to a common stream used to write files, with the only difference being that it's defined by DirectPlay with the specific purpose of sending a packet of data through the network. To code specific functions to send data, we need to create a method that receives the data that will be sent as a parameter, create the structure, fill it with the proper data, write it to a network packet using the Write method, and finally send the packet using the base class SendData method. The next code sample shows the method created to send the netterpillar's direction to the remote player:
Public Sub SendNetterDirection(Direction .NET Game Programming with DirectXAs 9.0Byte) Dim Msg As GameMsg_NetterDirection ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Dim gameMsgPacket As New NetworkPacket() Apress © 2003 (696 pages)
' Fill the fields The message authors of this text show how easy it can be to produce multimedia games using Managed DirectX 9.0 and Msg.Type interesting = gameMessageType.NetterDirection programming with Visual Basic .NET on Everett, the latest Msg.PlayerId = PlayerID version of Microsoft's Visual Studio. Msg.Direction = Direction ' Contents Put the message in a packet and send it Table of gameMsgPacket.Write(Msg) .NET Game Programming with DirectX 9.0 SendData(gameMsgPacket) Foreword End Sub Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites The methods to send OkToStartGame and EndDeathMatch will follow the same structure as this, and will be Chapter 3 Managed DirectX First Steps: Direct3D Basics and The DirectX vs.for GDI+ calledSendOkToStartGame and SendEndDeathMatch. code these methods is included on the Chapter 4 - River Pla.Net: Tiled Fields, accompanying CD-ROM, alongGame with the fullScrolling, code for and this DirectAudio chapter's sample game. Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen
The method to send the SyncGameField message has a little Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, andpeculiarity DirectShowthat we must look at carefully: We can't use Write method of the NetworkPacket to and writeSpeech a structure Chapter 7 the - Magic KindergarteN. II: Animation Techniques API that has strings or arrays as members, since DirectPlay can't compute a valid size forand the Directplay structure. This happens because strings can have any Chapter 8 - .Netterpillars II: Multiplayer Games extension, and arrays can be redimensioned by the program, so the message size can't be calculated. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Chapter 9
-
Nonmanaged Code
To work around this problem, we'll use the generic message structure to write the player ID and the message Bonus Chapter Porting .Nettrix to Pocket PC type, and use the Write method to write the array after the message basic structure on the packet. The full Appendix A - The State of PC Gaming code for the SendSyncGameField method is presented in the following listing: Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
Public Sub SendSyncGameField(ArrMushrooms(,) As Byte) Dim Msg As GameMsg_Generic Index Dim gameMsgPacket As New NetworkPacket() Appendix D - Guidelines for Developing Successful Games List of Figures
List of Tables ' Fill the message fields
Msg.PlayerId = PlayerID Msg.Type = gameMessageType.SyncGameField ' Put the message on a packet and send it gameMsgPacket.Write(Msg) gameMsgPacket.Write(ArrMushrooms) ' The previous code line corresponds to the following code piece: 'Dim i As Integer 'For i = 0 To 74 ' ' Write the bytes for the X,Y position for each mushroom ' gameMsgPacket.Write(ArrMushrooms(i, 0)) ' gameMsgPacket.Write(ArrMushrooms(i, 1)) 'Next SendData(gameMsgPacket) End Sub
Creating the Methods That Receive Messages To process the game messages received from the remote player, we'll override ProcessMessage from the base class and include a Select Case command that will call a specific function to process each type of message. Each of these functions will read the message data and send an event to the game, so we'll also have to create four events-one for each message type. One extra method will be necessary to read the
message type from the incoming network packet.
.NET Game Programming with DirectX 9.0
ISBN:1590590511and the ReadMessageType The next code listing by Alexandre shows the Santos events Lobão declaration, and Ellenthe ProcessMessage, method used for Hatton reading the message type.
Apress © 2003 (696 pages)
Public Public Public Public
authors of this text show how easy it can be to produce Event The SyncGameField(playerId As Integer, ArrMushrooms(,) As Byte) interesting multimedia games using Managed DirectX 9.0 and Event programming StartDeathMatch() with Visual Basic .NET on Everett, the latest Event version EndDeathMatch( PlayerKilled As Integer) of Microsoft's Visual Studio. Event NetterDirection( playerId As Integer, Direction As Integer)
Table of Contents Overrides Sub ProcessGameMessage(Message As NetworkPacket) .NET Game Programming with DirectX 9.0 Select Case ReadMessageType(Message) Foreword
Case gameMessageType.SyncGameField ' Call the function that will process the SyncGameField message Introduction ProcessSyncGameField(Message) Chapter 1 -Case .Nettrix: gameMessageType.OkToStartGame GDI+ and Collision Detection ProcessStartDeathMatch(Message) Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites gameMessageType.NetterDirection Chapter 3 -Case Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Call Tiled the Game function that will process the NetterDirection message Chapter 4 - River'Pla.Net: Fields, Scrolling, and DirectAudio Chapter 5 - RiverProcessNetterDirection(Message) Pla.Net II: DirectInput and Writing Text to Screen gameMessageType.EndDeathMatch Chapter 6 -Case Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ' Call the function that will process the NetterMovement message Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API ProcessGameOver(Message) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Select D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 End Sub Nonmanaged Code Preface
Bonus Chapter Porting .Nettrix to Pocket PC
Function ReadMessageType(Message As NetworkPacket) As gameMessageType Dim Msg As GameMsg_Generic Appendix B - Motivations in Games ' We'll always reset the packet, so we don't need to Appendix C - How Do I Make Games? ' care if it was read before calling the current function Appendix D - Guidelines for Developing Successful Games Message.Position = 0 Appendix A - The State of PC Gaming
Index List of Figures Msg = CType(Message.Read(GetType(GameMsg_Generic)), GameMsg_Generic) List of Tables Return Msg.Type
End Function
AllProcess ... methods are analogous to the ReadMessageType method, with the only difference being that they will be raising a method-specific event by the end of each method. The ProcessSyncGameField method will be the only slightly different one, reading the array sent byte by byte instead of using a specific structure for it, due to the problems with array deliverance that we have already talked about. The code for ProcessSyncGameField method is given in the following listing: Sub ProcessSyncGameField(ByVal Message As NetworkPacket) Dim Msg As GameMsg_Generic Dim i As Integer Dim ArrMushrooms(75, 2) As Byte ' We'll always reset the packet, so we don't need to ' care if it was read before calling the current function Message.Position = 0 Msg = CType(Message.Read(GetType(GameMsg_Generic)), _ GameMsg_Generic) For i = 0 To 74
' Write the bytes for the X,Y position for each mushroom .NET Game Programming with DirectX 9.0 ArrMushrooms(i, 0) = Message.Read(GetType(Byte)) ISBN:1590590511 by Alexandre Santos Lobão and Ellen ArrMushrooms(i, 1) = Message.Read(GetType(Byte)) Hatton
Next Apress © 2003 (696 pages) RaiseEvent SyncGameField(Msg.PlayerId, ArrMushrooms) The authors of this text show how easy it can be to produce End Sub interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
In the next section, we'll discuss the updates we need to make to the GameEngine class to include multiplayer features in our game. Table of Contents .NET Game Programming with DirectX 9.0
Third Draft: Adding Multiplayer Features to the Game Engine
Foreword
Preface The next step to make our game multiplayer is updating our CreateGameFieldmethod of the GameEngine Introduction class to initialize DirectPlay. Chapter 1
- .Nettrix: GDI+ and Collision Detection We'll also to initializeArtificial any new variables and used by this version of the game, such as the byte array with the Chapter 2 -need .Netterpillars: Intelligence Sprites
mushroom positions that will be sent by the SyncGameField message.
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 adjustment - River Pla.Net: Tiled Game Fields, DirectAudio One last refers to adding a new Scrolling, property and to the Netterpillar class, IsRemote, which will Chapter 5 River Pla.Net II: DirectInput and Writing Text to Screen control the drawing of the netterpillars (the remote player character is green, while the local one is yellow). To Chapter - Magicwe'll KindergarteN.: Adventure Games, ADO.NET, and DirectShow set this6property, add an extra parameter to the Netterpillar New method. Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter Updating 8 - .Netterpillars the CreateGameField II: Multiplayer Games Class and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -code listing we present the updates made to the CreateGameField method. Look for the "Update In the next Nonmanaged Code
to network game" comments see where Bonus Chapter Porting .Nettrix totoPocket PC extra code was added; the full code for this procedure, including extra comments, is available on the CD-ROM that accompanies this book. Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Sub CreateGameField(ByVal Appendix C - How Do I Make Games? WinHandle As System.IntPtr) ReDim arrGameField(width, height) Appendix D - Guidelines for Developing Successful Games . . . Index List of Figures
' Create the Netterpillars for standalone game List of Tables Select Case NetterpillarNumber Case 1 objNetterpillars(0) = New clsNetterpillar(Int(Me.width / 2), _ Int(Me.height) / 2, clsSprite.enDirection.South, False, False) Player1 = objNetterpillars(0) Case 2 ' Update to network game: Inform which netterpillar is remote ' if we are client on a deathmatch game, ' we will control the second Netterpillar ' OBS: The last two parameters of the New method set the properties ' IsComputer and IsRemote of the Netterpillar, respectively Select Case NetWorkType Case enNetWorkGame.Client objNetterpillars(0) = New clsNetterpillar(Int(Me.width/3), _ Int(Me.height) / 2, clsSprite.enDirection.South, _ False, True) objNetterpillars(1) = New clsNetterpillar(Int(Me.width/3)*2,_ Int(Me.height) / 2, clsSprite.enDirection.North, _ False, False) Player1 = objNetterpillars(1) Case enNetWorkGame.Host objNetterpillars(0) = New clsNetterpillar(Int(Me.width/3),_ Int(Me.height) / 2, clsSprite.enDirection.South, _
False, False) .NET GameobjNetterpillars(1) Programming with DirectX 9.0 clsNetterpillar(Int(Me.width/3)*2,_ = New ISBN:1590590511 by Alexandre Santos Lobão and Ellen Int(Me.height) / 2, clsSprite.enDirection.North, _ Hatton False, True) Apress © 2003 (696 pages)
Player1 = objNetterpillars(0)
The authors this text show how easy it can be to produce Case of enNetWorkGame.No interesting multimedia games using Managed DirectX 9.0 and objNetterpillars(0) = New the clsNetterpillar(Int(Me.width/3),_ programming with Visual Basic .NET on Everett, latest Int(Me.height) / 2, clsSprite.enDirection.South, _ version of Microsoft's Visual Studio.
False, False) objNetterpillars(1) = New clsNetterpillar(Int(Me.width/3)*2,_ Table of Contents Int(Me.height) / 2, clsSprite.enDirection.North, _ .NET Game Programming with True, DirectX 9.0 False) Foreword Player1 = objNetterpillars(0) Preface End Select Introduction ... ChapterEnd 1 -Select .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
... 3 Chapter
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio 'Update NetWork If we client a death match, Chapter 5 -to River Pla.Net II:Game: DirectInput and are Writing Text to on Screen
' do not- Magic create the mushrooms, they will be created by the host KindergarteN.: Adventure Games, ADO.NET, and DirectShow If NetWorkType <> enNetWorkGame.Client Then Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API ' Create the mushrooms Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay objMushrooms = New clsMushroom() D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterFor 9 -i = 0 To MushroomNumber - 1 Nonmanaged Code ' Check to seek if we are not creating the mushrooms Bonus Chapter Porting .Nettrix to Pocket PC ' over other objects Appendix A - The State of PC Gaming Do Appendix B - Motivations in Games x = Int(Rnd(1) * (Me.width - 2)) + 1 Appendix C - How Do I Make Games? y = Int(Rnd(1) * (Me.height - 2)) + 1 Appendix D -Loop Guidelines for Developing Successful Games While arrGameField(x, y) <> enGameObjects.Empty Index arrGameField(x, y) = enGameObjects.Mushroom Chapter 6
List of Figures List of Tables'Update to NetWork Game: Create an array with the mushrooms positions
If NetWorkType <> enNetWorkGame.No Then arrMushrooms(i, 0) = x : arrMushrooms(i, 1) = y End If Next Redraw() End If 'Update to NetWork Game: Create our DirectPlay client object If NetWorkType <> enNetWorkGame.No Then GameClient = New clsNetworkNetterpillars() ' Choose the service provider If Not GameClient.ChooseServiceProvider() Then GameOver = True Return End If If NetWorkType = enNetWorkGame.Host Then ' Create the session If Not GameClient.CreateSession() Then GameOver = True Return End If Else 'NetWorkGame = enNetWorkGame.Client
' Join a session .NET Game Programming with DirectX 9.0 If Not GameClient.ChooseSessionToJoin() Then ISBN:1590590511 by Alexandre Santos GameOver = Lobão True and Ellen Hatton Return Apress © 2003 (696 pages) End If The authors of this text show how easy it can be to produce End If interesting multimedia games using Managed DirectX 9.0 and Redraw() programming with Visual Basic .NET on Everett, the latest End If version of Microsoft's Visual Studio. End Sub Table of Contents .NET There's Game nothing Programming essentially withnew DirectX to us 9.0 in the previous sample code, since we have already seen the details of the
DirectPlay initialization when we created the NetworkGame class. Foreword Preface
As for the netterpillar creation in the code, the only difference is setting the IsRemote property properly, according to the current network type. For stand-alone games, no player is remote; for a host game, the first Chapter 1 - .Nettrix: GDI+ and Collision Detection netterpillar is local and the second one is remote; and for a client game, the first netterpillar is remote and the Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites second one is local. We also set the Player1 variable to the locally controlled netterpillar, since the local Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ player controls the netterpillar through this variable. Introduction
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5 - River II: DirectInput Updating the Pla.Net Render Method and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow We'll also toKindergarteN. update the Render procedure to reflect changes Chapter 7 -need Magic II: Animation Techniques andthe Speech API for multiplayer games. This method will
be core8 to -the game synchronization, we'lland depend heavily on the guarantee that TCP delivers all Chapter .Netterpillars II: Multiplayerand Games Directplay messages, and that they will be delivered in the same order they sent. D-iNfEcT: Multithreading, Nonrectangular Windows, and were Access to
Chapter 9
-
Nonmanaged Code
We'll also not include any special treatment to hide the latency. Let's suppose this game will run on a local network, and forget about this problem to make the code simpler.
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Appendix B -allMotivations in Games the code may appear a little confusing to you if you've never written a networkEven with these assumptions, Appendix C How Do I Make enabled application, so we Games? include loads of comments in the code, and we'll see what happens, step by step. Appendix D - Guidelines for Developing Successful Games
Before looking at the code, let's remember the four steps (previously steps 7 to 10) we planned in the game Index project with regards to keeping the game fields synchronized between players: List of Figures 1.Tables The server gets the input from the local player and sends it to the client (NetterDirection message). List of 2. The client receives the information about the remote player movement, and obtains the input from the local player. 3. The client updates the netterpillar positions in the game field, and sends their positions to the server. 4. The host receives the information about the remote player's movements, and updates the netterpillar positions in the game field. We can summarize these steps in a single statement: Both client and server will only move after receiving the input from the local player and the direction of the movement from the remote player. The input from the local player is sent only once to the remote player, to avoid synchronization problems, like moving in a certain direction twice on one machine and once on another. We can control this easily with a pair of variables: a static local variable in the Render method that will be set when we send our position, and a private class variable that will be set when we receive the direction from the remote player. Both variables will be reset when we move the netterpillars. In the next code sample, we present the updates to the Render procedure that implement the multiplayer features in our game. Refer to the comments in the code to see how we are implementing the synchronization control. Sub Render()
Dim i As Integer .NET Game Programming with DirectX Static DirectionSent As Boolean = True9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton ' Update to network game: maintain the game field drawn Apress © 2003 (696 pages)
Redraw() of this text show how easy it cannetwork be to produce ' Update The to authors network game: only move in mode interesting multimedia games using Managed DirectX 9.0 and ' if we send and receive programming with Visualthe Basicnew .NETdirections on Everett, the latest If NetWorkType enNetWorkGame.No Then version of<> Microsoft's Visual Studio. ' Update to network game: send the player movement to the oponent If Not DirectionSent Then Table of Contents DirectionSent = True .NET Game Programming with DirectX 9.0 = Player1.Direction Player1.Direction Foreword If NetWorkType = enNetWorkGame.Host Then Preface GameClient.SendNetterDirection(Player1.Direction) Introduction End If If GDI+ and Collision Detection Chapter 1 -End .Nettrix: If we didn't receive the Chapter 2 -'.Netterpillars: Artificial Intelligence andremote Sprites player movement, exit the function Not DirectionArrived ThenBasics and DirectX vs. GDI+ Chapter 3 -If Managed DirectX First Steps: Direct3D Chapter 4 - RiverReturn Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5 -Else River Pla.Net II: DirectInput and Writing Text to Screen ' Update to NetWork game: The game won't run until the next Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ' direction from the remote player arrives; and we will send our Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API ' new direction to him only once Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay DirectionSent = False D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 DirectionArrived = False Nonmanaged Code If NetWorkType = enNetWorkGame.Host Then Bonus Chapter Porting .Nettrix to Pocket PC ' Move the Netterpillars when we receive the remote player Appendix A - The State of PC Gaming ' direction Appendix B - Motivations in Games MoveNetterpillars() Appendix C - How Do I Make Games? Else 'Client Appendix D - Guidelines GameClient.SendNetterDirection(Player1.Direction) for Developing Successful Games Index ' Move the Netterpillars List of Figures MoveNetterpillars() List of Tables End If End If Else ' Move the Netterpillars MoveNetterpillars() End If ... ' Update to network game: game over when the first player dies If NetWorkType <> enNetWorkGame.No Then For i = 0 To NetterpillarNumber - 1 If objNetterpillars(i).IsDead Then GameOver = True End If Next Else ' On standalone game, GameOver if all Netterpillars die GameOver = True For i = 0 To NetterpillarNumber - 1 If Not objNetterpillars(i).IsDead Then GameOver = False End If Next ' If all mushrooms got eaten - Game Over
If MushroomNumber = 0 Then .NET Game= Programming with DirectX 9.0 GameOver True ISBN:1590590511 by Alexandre Santos Lobão and Ellen End If Hatton End If Apress © 2003 (696 pages) ' Game over will happen if the player dies or closes the game window authors of this text show how easy it can be to produce If gameOverTheThen interesting multimedia games using Managed DirectX 9.0 and If NetWorkType enNetWorkGame.Client Then programming=with Visual Basic .NET on Everett, the latest GameClient.SendEndDeathMatch(1) version of Microsoft's Visual Studio. ElseIf NetWorkType = enNetWorkGame.Host Then GameClient.SendEndDeathMatch(0) Table of Contents End If .NETEnd Game IfProgramming with DirectX 9.0 Foreword ... Preface End Sub Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection Besides2 the synchronization, in theIntelligence previous code listing we are also setting the new criteria for game over (the Chapter - .Netterpillars: Artificial and Sprites
death match ends as soon as one player dies, not when the last netterpillar dies). We send the - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ EndDeathMatch message to the remote player when the game is over, which will occur if the local player dies Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio or closes the game field window. Chapter 3 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 -section, Magic KindergarteN.: Adventure Games, ADO.NET, DirectShow In the next we present the message handlers for ourand game, the last step required before being able to Chapter - Magic KindergarteN. II: Animation Techniques and Speech API play our7 game through the network. Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Fourth- Draft: Writing the Multiplayer Message Handlers Nonmanaged Code
Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC
In this section, we'll put together everything that we have done in the previous sections, so we can see how the
Appendix A work - The across State ofthe PC network. Gaming game will Appendix B - Motivations in Games
Let's look the messages exchanged by both players in sequence, according to the time they occur in a Appendix C at - How Do I Make Games? commonDgame. Referfor to the steps described inGames the game project if you have any doubts about this sequence. Appendix - Guidelines Developing Successful All events that handle these messages are defined in the NetworkNetterpillar class or in its base Index class.The GameClient is the object from the class we defined in the GameEngine class. List of Figures List of Tables
The first message received in a game is the NewPlayer message, received on the host when a new player connects to a session. This message is defined in the NetworkGame class, and reflects directly the message received by the Peer object. When the host receives this message, it will send the array with the mushroom positions (created in the CreateGameField method) to the client, using the SendSyncGameField method of the NetworkNetterpillar class, as we can see in the next code sample: Sub GameClient_NewPlayer(Name As String, ID As Integer) _ Handles GameClient.NewPlayer ' If we are the host, send mushroom positions to the client If GameClient.PlayerID <> ID And NetWorkType = enNetWorkGame.Host Then ' Store the remote player name GameClient.SendSyncGameField(arrMushrooms) End If End Sub
When the host sends the SyncGameField message, the event that processes this message is triggered on the client machine. This machine reads the messages and creates all the mushrooms in the game field, and then sends the OkToStartGamemessage back to the host, as we can see in the next code sample: Sub GameClient_SyncGameField(playerId As Integer, ArrMushrooms(,) As Byte) _
Handles GameClient.SyncGameField Game Programming with DirectX 9.0 Dim i As .NET Integer ISBN:1590590511 Alexandre Santos and Ellen Dim x As by Integer, y As Lobão Integer Hatton Apress © 2003 (696 pages)
If GameClient.PlayerID <> playerId Then The authors this text show how easy it can be to produce ' Create the of mushrooms interesting multimedia games using Managed DirectX 9.0 and objMushrooms NewVisual clsMushroom() programming=with Basic .NET on Everett, the latest For iversion = 0 of ToMicrosoft's 74 Visual Studio. arrGameField(ArrMushrooms(i, 0), ArrMushrooms(i, 1)) = _ enGameObjects.Mushroom Table of Contents Next .NET Game with DirectX 9.0 End Programming If Foreword GameClient.SendOkToStartGame() Preface End Sub Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
The host will then receive the OkToStartGame message and send the current local player direction to the - .Netterpillars: Artificial Intelligence and Sprites remote player. This will start the "loop" of message exchanges between server and client, where each of them Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ will pass its direction to the remote player and receive a direction from him or her. Chapter 2 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Sub GameClient_StartDeathMatch() Handles GameClient.StartDeathMatch Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow If NetWorkType = enNetWorkGame.Host Then Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API GameClient.SendNetterDirection(Player1.Direction) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End If D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 End Sub Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B -will Motivations in Games The client receive the direction from the host, update the correct netterpillar direction, and simply set the Appendix C How Do I Make Games? DirectionArrived variable to True. This variable, as we have just seen in the previous section, will indicate Appendix - Guidelines Successful that the D local machinefor hasDeveloping already received theGames remote player movement, and can go on to update the screen Index in the Render method. List of Figures List of Tables Sub GameClient_NetterDirection(playerId As Integer, Direction As Integer) _
Handles GameClient.NetterDirection If NetWorkType = enNetWorkGame.Client Then ' If we are the client, update the 1st netterpillar ' (the host controlled one) objNetterpillars(0).Direction = Direction Else ' NetWorkType = enNetWorkGame.Host ' If we are the host, update the 2nd netterpillar ' (the client controlled one) objNetterpillars(1).Direction = Direction End If ' The game can go running DirectionArrived = True End Sub
In the Render method, as we saw in the previous section, the local player will send his or her direction to the remote player, continuing in this loop until one of the players dies. When a player dies or closes the game window, the EndDeathMatchmessage is sent by the Render method, which will be handled by the remote player's client simply by setting the remote player character to dead, as we can see in the next bit of code: Sub GameClient_EndDeathMatch(PlayerKilled As Integer) _ Handles GameClient.EndDeathMatch
' Kill the netterpillar that died in the remote game .NET Game Programming with DirectX = 9.0True objNetterpillars(PlayerKilled).IsDead ISBN:1590590511 by Alexandre Santos Lobão and Ellen End Sub Hatton Apress © 2003 (696 pages)
Thecan authors of this text show easy it can be the to produce One final message be received by any of how the players when connection with the remote player is broken. interesting multimedia games using to Managed DirectX 9.0 In this case, all we do is present an error message the local player, asand shown in the next listing: programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Sub GameClient_SessionTerminated(msg As TerminateSessionMessage) _ Handles GameClient.SessionTerminated Table ofIf Contents Not GameOver Then .NET Game Programming with DirectX 9.0 MessageBox.Show("Connection with oponnent was terminated." & _ Foreword ControlChars.CrLf & "We can't continue playing.") Preface GameOver = True Introduction End If Chapter End Sub 1 - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
We are now able to run our program and see the results. If we want to test it on a single machine, this is still - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio possible, but we need to lower the frame rate (thus resulting in slower netterpillars on screen) because we'll Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen need to control both local and remote players. Chapter 4 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter - Magic KindergarteN. II: Animation Techniques and Speech API Figure 78-15 presents our first .Netterpillars II test, showing the netterpillars moving in sequence on the screens Chapter - .Netterpillars Multiplayer Games and Directplay for the 8local and remote II: player. Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 8-15: Running a death match in .Netterpillars II In the next section, we'll finish our program, including a specific screen for the end of the death match game.
Final Version: Coding the Game Over Screen Our goal for the game over screen in a death match is to present the local and remote player's names, showing which one is the winner. We can also use the code from the previous game over screen to include the length of a player's netterpillar on screen. The first thing we must do is to create a new property in the NetworkNetterpillar class to store the remote player name. Public RemotePlayerName As String
We'll need to set this property properly. On the host, we'll receive the remote player's name in the NewPlayer event, coded in the previous section; so all we need to do is store the name in the newly created property, including the next code line in that event handler:
GameClient.RemotePlayerName = Name .NET Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton As for the client, we'll assume thatpages) the remote player's name is the session name on the remote computer so Apress © 2003 (696
we can store the remote player's name at the end of the CreateGameField method, just after connecting to a The authors of this text show how easy it can be to produce remote session, as shown inmultimedia the next line of code: interesting games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
GameClient.RemotePlayerName = GameClient.SessionName Table of Contents
Now that we have the names of the local and remote players, all we need to do is code the Load event of the death match game over screen, as presented in the next code listing:
.NET Game Programming with DirectX 9.0 Foreword Preface
Sub FrmDeathMatchGameOver_Load(sender As Object, e As EventArgs) _ Handles MyBase.Load Chapter 1 - .Nettrix: GDI+ and Collision Detection ' write the name of the winner Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites ' Remember, objNetterpillars(0) is always the host Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ If objGameEngine.objNetterpillars(0) Is Nothing Or _ Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio objGameEngine.objNetterpillars(0).IsDead Then Chapter 5 -If River Pla.Net II: DirectInput and Writing Text to Screen objGameEngine.NetWorkType = clsGameEngine.enNetWorkGame.Host Then Chapter 6 - MagicLblWinnerName.Text KindergarteN.: Adventure = Games, ADO.NET, and DirectShow objGameEngine.GameClient.RemotePlayerName Chapter 7 -Else Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay LblWinnerName.Text = objGameEngine.GameClient.PlayerName D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to End If Chapter 9 Else Nonmanaged Code Bonus Chapter .Nettrix to Pocket PC IfPorting objGameEngine.NetWorkType = clsGameEngine.enNetWorkGame.Host Then Appendix A - The State of PC Gaming LblWinnerName.Text = objGameEngine.GameClient.PlayerName Appendix B -Else Motivations in Games Appendix C - How Do LblWinnerName.Text I Make Games? = objGameEngine.GameClient.SessionName End If Appendix D - Guidelines for Developing Successful Games Index End If Introduction
List of Figures
' Write the players name List of Tables If objGameEngine.NetWorkType = clsGameEngine.enNetWorkGame.Host Then LblPlayer1.Text = objGameEngine.GameClient.PlayerName LblPlayer2.Text = objGameEngine.GameClient.RemotePlayerName Else LblPlayer1.Text = objGameEngine.GameClient.SessionName LblPlayer2.Text = objGameEngine.GameClient.PlayerName End If 'write the players length LblPlayer1Length.Text = objGameEngine.objNetterpillars(0).NetterBodyLength LblPlayer2Length.Text = objGameEngine.objNetterpillars(1).NetterBodyLength End Sub
Running our game again, we can now see the game over screen for a death match, as shown in Figure 8-16.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Figure 8-16: The game over screen for a death match Preface
In the next section, we'll discuss some suggestions on how to improve our game. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
GameTouch Programming with DirectX 9.0 Adding One.NET Final by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton There's a lot of opportunity for improvement in our game. For example, we could create customized screens Apress © 2003 pages) for network configuration. We (696 could also have a specific place to configure the network options, and buttons to start the game,The so authors the player would have to easy give network such as the provider or the remote of this textnot show how it can be details, to produce interesting multimedia games Managed DirectX 9.0 and machine name, every time he or she wants tousing start a new game. programming with Visual Basic .NET on Everett, the latest of Microsoft's Visual the Studio. The main goal forversion this chapter is to present features of DirectPlay in the simplest possible way, so some
usability aspects such as easy network configuration were neglected. Table of Contents
Therefore, as a final touch, all we'll do is create a smoother game start, and leave all the other
.NET Game Programming with DirectX 9.0 improvements as an exercise for you to do on your own time. Enjoy! Foreword Preface
Smoothing the Game Start
Introduction
Chapter GDI+ Collision Detection Playing1our- .Nettrix: own games is and surely the best way to find weaknesses in them. In the case of this chapter's Chapter 2 .Netterpillars: Artificial Intelligence Sprites sample game, one thing that really annoys usand is the way the game starts, with the netterpillars running at full Chapter 3 Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ speed. Sometimes we didn't have time to think before we died! Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio So, we'll this issue includingand a netterpillar acceleration Chapter 5 address - River Pla.Net II: by DirectInput Writing Text to Screen at the beginning of the game: The game
characters start to move slowly, and then increase their speed until they reach full velocity. Chapter 6 - will Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API This can be done in a very simple way. In the Main subroutine, we'll set the DesiredFrameRate variable to - .Netterpillars II: Multiplayer Games and Directplay 2 (2 frames per second), and we'll increment it slowly (let's say 0.2 frames per second) until it reaches our D-iNfEcT: Multithreading, current9frame rate of 10, as shown inNonrectangular the next code Windows, listing: and Access to Chapter Chapter 8
Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC
Sub main() ... Appendix B - Motivations in Games ' Reset the frame rate, to do the initial acceleration Appendix C - How Do I Make Games? DesiredFrameRate = 2 Appendix D - Guidelines for Developing Successful Games Do While Not objGameEngine.GameOver Index If Not objGameEngine.Paused Then List of Figures ' Force a Frame rate of 10 frames to second on maximum List of Tables If Environment.TickCount - LastTick >= 1000 / DesiredFrameRate Then ' Increase the DesiredFrameRate from 2 to 10 when ' starting the game, so the player can see the ' netterpillar speed increasing If DesiredFrameRate < 10 Then DesiredFrameRate += 0.2 MoveComputerCharacters() objGameEngine.Render() LastTick = System.Environment.TickCount End If End If Application.DoEvents() Loop ... End Sub Appendix A - The State of PC Gaming
With this simple trick, our game will have a smooth start. Play it again and you'll see the difference! That's all for this chapter's sample game. In the next section, we'll recap the main points we have discussed.
Summary
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
In this chapter weHatton went back to the sample game created in Chapter 2 and added multiplayer features to it using DirectPlay. Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce
This chapter's sample was amultimedia simple one, but itusing was Managed definitely DirectX hard enough to show the problems and interesting games 9.0 and programming with Visual Basic .NET on Everett, the latest challenges we face when coding multiplayer games. version of Microsoft's Visual Studio.
Among the points discussed were the following: Table of Contents Details about how to create multiplayer games and choices we must make when thinking about .NET Game codingProgramming such gameswith DirectX 9.0 Foreword
The use of managed DirectPlay to connect computers Preface Introduction
The creation of a new game class that handles the connection between remote computers and the
Chapter 1 - .Nettrix: GDI+ and Detection delivering and receiving ofCollision messages. Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites In the next go back to the basics and create very simple game in order to reinforce the Chapter 3 -chapter, Managedwe'll DirectX First Steps: Direct3D Basics anda DirectX vs. GDI+
single most important thing in game enjoying theDirectAudio programming. At the same time, we'll explore Chapter 4 - River Pla.Net: Tiled Game creation: Fields, Scrolling, and new concepts thatPla.Net may help us in building games, such as multithreading, creating windows with Chapter 5 - River II: DirectInput andother Writing Text to Screen different accessing Adventure nonmanaged codeADO.NET, from theand underlying Windows API. Chapter 6 shapes, - Magic and KindergarteN.: Games, DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Chapter .NET 9: D-iNfEcT: Multithreading, Nonrectangular ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Windows, and Access to Nonmanaged Code Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Studio.a very simple game with a few dozen lines of code to In this chapter, we'll go back to basics Visual by creating
Overview
reinforce the ideas you have encountered in this book: Creating games can be simple, and, most of all, it can be fun. Table of Contents .NET Game Programming DirectX We'll create an original with game, called9.0 D-iNfEcT (see Figure 9-1), which uses some simple concepts that Foreword haven't been covered in previous chapters but that may help us add some extra spice to our game Preface projects. We'll see some more details about multithreading, discover how to create nonrectangular Introduction windows, and you'll learn how you can access nonmanaged code—and why you would want to do such a Chapter thing. 1 - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List ofFigure Tables 9-1: D-iNfEcT, this chapter's sample game
.NET Game Programming with DirectX 9.0 Multithreading by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Visual Basic .NETHatton opened up whole new horizons for Visual Basic programmers, and probably one of the Apress 2003 (696 pages) most exciting of its latest©features is its multithread capabilities. The authors of this text show how easy it can be to produce
To understand what a thread is, first you mustusing understand what a process is. Microsoft's MSDN library interesting multimedia games Managed DirectX 9.0 and (http://www.msdn.microsoft.com/) programming with Visual Basic defines .NET aonprocess Everett,as thea latest "single instance of a running ofhas Microsoft's Studio. application. Eachversion process at leastVisual a primary thread, which executes code within the process. You can also create additional threads in a process, limited only by RAM." In other words, a process is an EXE file held in memory, and a thread is what executes the program code. Table of Contents .NET Game Programming with DirectX As for a thread, MSDN library states9.0 that "a thread executes code in a process. Each thread has a stack, Foreword where the linker sets the stack size of all threads created in a process. Each process has a primary thread Preface and can have as many additional threads as permitted by available RAM. Threads within a process share Introduction the address space of the process. A thread also has associated registers such as the instruction pointer. Chapter 1 - .Nettrix: GDI+ and Detection These associated registers areCollision known as the context." In less technical terms, we can say that a thread is Chapter a "unit of 2 execution" - .Netterpillars: insideArtificial a process, Intelligence comprising and Sprites an instruction pointer (which tells which instruction will be
executed and some context data associated with it.and DirectX vs. GDI+ Chapter 3 next) - Managed DirectX First Steps: Direct3D Basics Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
A better way to really understand these concepts is by studying a graphical depiction of the relationship - River Pla.Net II: DirectInput and Writing Text to Screen between processes and threads, as shown in Figure 9-2.
Chapter 5 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 9-2: Processes and threads If a process has only the primary thread, it's called single-threaded. If it has more than one thread, it's calledmultithreaded. NEW IN Visual Basic .NET allows you to create multithreaded applications through the declaration of .NET aThread object, which is associated with a function. When the function ends, the thread is destroyed. We control the execution of the thread with the methods Start,Stop,Suspend, Sleep(time),Resume, and Abort.
Creating Multiple Threads in a Program The following code sample shows a simple program that creates two extra threads besides the primary one, which is automatically created for every program. Imports System.Threading
Private secondThread As Thread .NET GameAs Programming with DirectX 9.0 Private ThirdThread Thread by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Sub Main() secondThread = New Thread(AddressOf ThreadCode) The authors of text show how easy it can be to produce secondThread.Name = this "Second Thread" interesting multimedia games using Managed DirectX 9.0 and secondThread.Start() programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
ThirdThread = New Thread(AddressOf ThreadCode) ThirdThread.Name = "Third Thread" Table ThirdThread.Start() of Contents .NET Game End Sub Programming with DirectX 9.0 Foreword Preface Public Sub ThreadCode() Introduction Do while MessageBox.Show("Do you wish to end this thread?", _ Chapter 1
from inside " & Thread.CurrentThread.Name, _ - .Nettrix: GDI+ and"Calling Collision Detection
Chapter 2
MessageBoxButtons.YesNo, MessageBoxIcon.Question) = vbNo - .Netterpillars: Artificial Intelligence and Sprites
loop Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ End Sub Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
With multithreading, we can make our program run different pieces of code at the same time. We have - Magic KindergarteN. II: Animation Techniques and Speech API already used this feature to pool the input devices in Chapter 5, but we can do a lot more. For example, Chapter 8 - .Netterpillars II: Multiplayer and Directplay since we can create functions that can Games keep running calculations even while we draw the screen, we can D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to create more Chapter 9 - complex AI code to take into account more variables and achieve more interesting results, or Nonmanaged Code we can improve our collision detection algorithms to produce more accurate results. Chapter 7
Bonus Chapter Porting .Nettrix to Pocket PC
Appendix A -we Thecan't Statego ofon PCcreating Gaming new threads forever. Although we can create a few hundred threads in Of course, Appendix the same B program, - Motivations there in is Games a practical limit to the number of threads we can include, just as there is a
practicalCmaximum the number Appendix - How Do to I Make Games?of programs we can run on Windows before it becomes too slow to use. Appendix D - Guidelines for Developing Successful Games
Avoiding Errors in Multithreaded Programs
Index
List of Figures
When our programs gain multiple threads, we must be particularly careful about the so-called critical List of Tables sections of our code: The code from different threads may access program data at the same time, generating unexpected results. Just to give a simple example, consider the following situations regarding the use of a global counter from two threads of the same process. The first sequence refers to normal processing, with no errors: 1. Thread 1 reads the counter. Its value is 10. 2. Thread 1 increments the counter (counter's new value: 11). 3. Thread 1 saves the value (value saved: 11). 4. Thread 2 reads the counter. Its value is 11. 5. Thread 2 increments the counter (counter's new value: 12). 6. Thread 2 saves the value (value saved: 12). The previous situation occurs when the threads execute sequentially; but since we have multiple instruction pointers, there's no guarantee that the processing will happen this way. The next steps represent another valid operation sequence, which leads to an incorrect result: 1. Thread 1 reads the counter. Its value is 10. 2. Thread 1 increments the counter (counter's new value: 11). 3. 4.
1. 2. 3. Thread 2 reads the counter. Its value is 10.
.NET Game Programming with DirectX 9.0
by Alexandre Santos Lobão and11). Ellen 4. Thread 1 saves the value (value saved:
ISBN:1590590511
Hatton 5. Thread 2 increments Apress © 2003the (696 counter pages) (counter's new value: 11). The authors of this text show how easy it can be to produce
6. Thread 2 saves the value (valuegames saved:using 11). Managed DirectX 9.0 and interesting multimedia programming with Visual Basic .NET on Everett, the latest
This kind of errorversion can be of disastrous when weStudio. are accessing non-thread-safe resources from our Microsoft's Visual application, and can lead to instability in the program. To avoid these problems, VB .NET offers a new construct,SyncLock(), that helps with protecting critical sections and data. Table of Contents .NET Game NEW Programming TheSyncLock()/End with DirectX 9.0 SyncLock block in Visual Basic .NET informs the program that any
IN Foreword
data inside the statements must only be accessed one thread at a time. The SyncLock() method receives as a parameter a reference type (usually a class, but this also can be a Introduction module, an array, an interface, or a delegate), and prevents the thread from executing the until it has anCollision exclusive lock on the object referenced by this parameter. For example, Chapter 1 - block .Nettrix: GDI+ and Detection SyncLock(me) blocks the current object. Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites .NET Preface
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
This code sample shows how a global variable can be protected from problems that occur due to - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio concurrent threading:
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Imports System.Threading - Magic KindergarteN. II: Animation Techniques and Speech API Private MyGlobalVar as integer = 0 Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Private secondThread As Thread D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -ThirdThread As Thread Private Nonmanaged Code Chapter 7
Bonus Chapter Porting .Nettrix to Pocket PC
Sub Main() secondThread = New Thread(AddressOf SecondThreadCode) Appendix B - Motivations in Games secondThread.Name = "Second Thread" Appendix C - How Do I Make Games? secondThread.Start() Appendix A - The State of PC Gaming
Appendix D - Guidelines for Developing Successful Games IndexThirdThread = New Thread(AddressOf ThirdThreadCode) List ofThirdThread.Name Figures = "Third Thread" List ofThirdThread.Start() Tables
End Sub Public Sub SecondThreadCode() Synclock(me) MyGlobalVar += _ inputbox ("Enter the value to sum to the global variable", _ Thread.CurrentThread.Name) End Synclock End Sub Public Sub ThirdThreadCode() Synclock(me) MyGlobalVar += _ inputbox ("Enter the value to sum to the global variable", _ Thread.CurrentThread.Name) End Synclock End Sub
In the preceding sample code, we protect the global variable from being over-written by concurrent threads, but what if we wanted to know the final value of the variable, after the two threads had ended? TheJoin method of the threads will help us when waiting for a thread to end, enabling our programs to do any synchronization that's possible.
.NET Game Programming DirectX 9.0 to go to sleep until the destination thread Tip The.Join method forceswith the caller thread ISBN:1590590511 ends. by Alexandre Santos Lobão and Ellen Hatton
Adding the next lines Apress to © the 2003 end (696 ofpages) the Main procedure in the previous code sample forces our main program to wait for both threads to continuing, so be thetomessage The authors of this end text before show how easy it can produce box presents the correct final interesting using Managed 9.0 and (just like separate programs), value of the global variable. multimedia Remembergames that the threads run DirectX asynchronously programming with Visual .NET on Everett, the method, latest so if we simply include the message box, Basic without calling the Join it would be presented as soon version of Microsoft's Visual Studio. as the threads were created, showing a zeroed variable. Table of Contents Secondthread.join() .NET Game Programming with DirectX 9.0 Thirdthread.join() Foreword MessageBox.show("Final value of the global variable: " & _
MyGlobalVar.ToString)
Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
In the next section, we'll discuss how to create nonrectangular windows, which are a nice touch when - .Netterpillars: Artificial Intelligence and Sprites making splash or configuration screens for our games.
Chapter 2 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 Creating Nonrectangular Windows by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton windows can help us to come up with customized window shapes that may improve Creating nonrectangular Apressof© our 2003game. (696 pages) the visual appearance Perhaps the most common example of a program that uses this resource is Windows Media Player, in which skin we choose The authors of this text showeach how easy it can be to implies producein a different window shape. interesting multimedia games using Managed DirectX 9.0 and
To change a window's programming shape, with all weVisual needBasic to do.NET is toon setEverett, the Region the latest to a previously created graphics path. version of Microsoft's Visual Studio. We talked about graphics paths when introducing GDI+ in Chapter 1, and used them to draw gradient-filled squares for our first sample game, but here's a brief recap: Graphics paths represent series of connected lines and curves, and are used by functions that draw, fill, or clip a specific region of the window. We can Table of Contents create graphics paths by adding lines, open or closed curves, Bezier curves, arcs, rectangles, and other .NET Game Programming with DirectX 9.0 geometric shapes. Foreword
Preface To illustrate this concept, let's create a graphics path composed of two rectangles and then set the region Introduction property of the window to this graphics path, creating a cross-shaped window. First, open a new project in Chapter 1 - .Nettrix: GDI+aand Collision Visual Studio and create window withDetection two labels, which will be used as a visual clue in design mode to the Chapter window's 2 final - .Netterpillars: shape. Figure Artificial 9-3 shows Intelligence the design and Sprites mode window. Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 9-3: A window with two labels forming a cross shape
All we need to do now is to include in the Load event of the window the code to set the Region property to the path composed of the two rectangles, as shown in the following code listing: Private Sub FrmCross_Load(sender As System.Object, e As System.EventArgs) _ Handles MyBase.Load 'Shape the window to make it look like a cross Dim GraphicsPath As New Drawing2D.GraphicsPath() GraphicsPath.AddRectangle(New Rectangle(Label1.Location, Label1.Size)) GraphicsPath.AddRectangle(New Rectangle(Label2.Location, Label2.Size)) Me.Region = New Region(GraphicsPath) End Sub
Running our program, the result is a little surprising. Figure 9-4 shows the result.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 - 9-4: RiverAn Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Figure odd cross-shaped window Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
As we can-see in Figure 9-4, there are still some details to learn about graphics paths. Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 7
Chapter 8 lesson - .Netterpillars Multiplayer and Directplay The first is that theII:graphics pathGames will receive window coordinates, with the (0,0) point located the D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to upper-left Chapter 9 -corner of the title bar. The labels, on the other hand, have client coordinates, and in this case the Nonmanaged Code
(0,0) point is in the upper-left corner of the client area. The client area is the region "inside" the window, without the title bar and the window borders, whereas the window area is the complete window area, Appendix - The State of PC Gaming includingA the area of the borders and the title bar. That's why the title bar appears as part of our cross Appendix B Motivations in Games window in Figure 9-4: The coordinates weren't translated from client to window coordinates, so the cross Appendix - How to Dothe I Make Games? appearsCshifted top-left of the window. Bonus Chapter Porting .Nettrix to Pocket PC
Appendix D - Guidelines for Developing Successful Games
To solve this problem, the easiest thing to do is simply remove the form border by setting its Index FormBorderStyle property to None. With this setting, the window is presented without borders and title List of Figures area, so the client area will match the window area. List of Tables The second strange thing we see in Figure 9-4 is that there's a hollow region in the middle of the labels. This happens because the application can fill and clip the internal region of the graphics paths in two modes: alternate (the default) or winding. Thealternate mode uses a simple algorithm to determine if a point in the window is inside or outside a path. It creates a line from the point to another point that is outside the graphics path. If the point crosses an odd number of graphics path segments, the point is inside the window; if it crosses an even number of segments, it's outside the window. This algorithm works well if we have convex paths or we want to create a window with hollow regions, but it doesn't work if we simply want to add shapes to create the window border, as we did in our example. Thewinding mode basically takes a starting point on the path and goes on adding segments to the path, using a simple algorithm at each path intersection to decide if the segment is inside or outside the path. In other words, we can say that this mode looks for the outermost border of the figures added to create a path. Adding the following line to our code will change the fill mode property of the graphics path: GraphicsPath.FillMode = Drawing.Drawing2D.FillMode.Winding
If we run our program again now, we can see the expected result, shown in Figure 9-5.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Figure cross-shaped window Chapter 4 - 9-5: RiverAPla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
In the next section, we'll discuss how to access nonmanaged code from our .NET applications.
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 Accessing .NET Nonmanaged Code by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hattonas it is now, is a hybrid set of classes: Some classes are entirely managed code, The .NET framework, Apress © 2003 (696 pages) the operating system or extended library features that still do the and some are .NET wrappers to access work behind the scenes. Sometime in the nexthow feweasy years, we'll operating systems that will be more The authors of this text show it can behave to produce interesting games Managed DirectXbut 9.0 and stable, reliable, and secure multimedia because they'll beusing fully .NET enabled; for now we need to find a way of programming withtogether. Visual Basic .NET on Everett, the latest making the old and the new work version of Microsoft's Visual Studio.
Sometimes our games may need to access a feature from the operating system that isn't mapped to a wrapper class. For instance, some members of WinMM.DLL, which is responsible for multimedia control Table of Contents in windows, have no wrappers in .NET. .NET Game Programming with DirectX 9.0
Foreword Visual Basic, since its earlier versions, always had a way to call the Windows APIs directly, and Visual Preface Basic .NET is no exception. Although calling such functions will mark your code as unsecure (since it'll be Introduction stepping out of the sandbox that .NET creates around programs so they don't mess up others), sometimes Chapter 1 want - .Nettrix: GDI+atand Collision Detection you may to do this, least until the final managed operating system is released. Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites
To use3external API functions from our program, we must before calling them. In Visual Chapter - Managed DirectX First Steps: Direct3D Basics anddeclare DirectXthem vs. GDI+
Basic .NET- River there Pla.Net: are two Tiled waysGame to doing this. To demonstrate these, let's use the function that plays a Fields, Scrolling, and DirectAudio sound file through the default sound system on a machine, the sndPlaySoundA function, in our samples.
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 - Magic Adventure ADO.NET, andand DirectShow The "classic" way KindergarteN.: is to declare the function Games, and its parameters, return values using the Declare Chapter 7 - as Magic KindergarteN. Animation statement, shown in the next II: code snippet:Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Declare Chapter 9 -Function sndPlaySoundA Lib "winmm.dll" (lpszSoundName As String, _ Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
uFlags As Integer) As Integer
Appendix A - The State of PC Gaming Appendix B - Motivations in Games Visual Basic .NET introduces a new way to perform this declaration, using a declarative attribute that tells Appendix C How Do I Make Games? the application that the function is implemented as an export from a nonmanaged function that resides in a Appendix DLL outside D - Guidelines .NET. This forisDeveloping the preferred Successful way of performing Games a declaration. Its syntax is equivalent to that of a
classical function definition, but it must be left empty, as shown in the following code: Index List of Figures List of Tables Function sndPlaySoundA(lpszSoundName As String, _
uFlags As Integer) As Integer ' If you declare it this way you will need to keep the function empty. ' (But either way will work). End Function
NEW IN .NET
Such use of attributes is very common in Visual Basic .NET, and they are beneficial for many things, like "signing" your program by including attributes with the author name; including any extra info for external and internal use (like ODBC data source names); and even help making your code more secure against viruses, since there are special attributes you can use to specify which facilities from the operating system your program can and can't use.
Note It's beyond the scope of our book to go any further with the topic of declarative attributes, but it's a new and interesting feature that is present in Visual Basic .NET. For further information, refer to the Visual Studio help files. To use the sndPlaySoundA function, we can call it directly, as we would any common function. In this specific case, there are also some constants used by the function we'll declare if we want to make our code clearer. The next code listing shows a complete sample of code to play a WAV file: Function sndPlaySoundA(lpszSoundName As String, _ uFlags As Integer) As Integer
' If you declare it this way you will need to keep the function empty. .NET Game Programming with DirectX 9.0 ' (But either way it will work). ISBN:1590590511 by Alexandre Santos Lobão and Ellen End Function Const Const Const Const Const Const
Hatton Apress © 2003 (696 pages)
SND_SYNC = &H0 The authors SND_ASYNC = &H1of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and SND_NODEFAULT = &H2 programming with Visual Basic .NET on Everett, the latest SND_LOOP = &H8 version of Microsoft's Visual Studio. SND_NOSTOP = &H10 SND_PURGE = &H40
Table of Contents .NET Game Sub Programming Public Main()with DirectX 9.0 Foreword Dim strSoundFile As String = "C:\temp\MySound.Wav" PrefacesndPlaySoundA(strSoundFile, SND_ASYNC Or SND_NODEFAULT) Introduction End Sub Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Next we'll discuss the proposal for the sample game used in this chapter, which will include the features - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ discussed in the previous sections.
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Game Proposal by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hattonthis chapter's sample game is creating a task to clean up the player's computer The basic idea behind Apress © 2003 (696 pages) from a (kind of) virus attack. The authors of this text show how easy it can be to produce
The game will beinteresting composedmultimedia of a main games window, which will have an irregular using Managed DirectX 9.0 and shape to mimic some kind of programming Visual Everett, latestthe time for the game and the bacterium or germ (viruses arewith harder to Basic draw),.NET withon options to the choose version ofand Microsoft's Studio. number of germ children, a buttonVisual to start the game. Once started, the game will generate new threads (one for each germ) that will move across the screen in an erratic way. The player will have to catch all of them before the specified time is up by clicking each .NET Programming with DirectX 9.0time is up, we display a message box telling the player that the oneGame with the mouse pointer. When the Foreword computer is irreversibly sick; if the player catches all the bacteria, we'll display a congratulations message.
Table of Contents
Preface
Although the game concept is very simple, the game can be very addictive, as you'll see. In the next Introduction section,1 we'll discussGDI+ someand extra detailsDetection about the game project. Chapter - .Nettrix: Collision Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Game Project by Alexandre Santos Lobão and Ellen
ISBN:1590590511
This game will beHatton so simple that we won't need to use any of the previously created game classes; we'll © 2003of(696 pages) events. We'll have two windows—the startup window and the child simply add code Apress to a couple window germ window. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming .NET on Everett, the latest Table 9-1 presents the logic forwith theVisual main Basic window events. version of Microsoft's Visual Studio.
Table 9-1: Logic for the Main Window Events Table of Contents EVENT
ACTION
.NET Game Programming with DirectX 9.0
Load Foreword
Change the shape of the window.
Preface Start button Introduction click
Create as many threads as chosen by the user on screen, and activate a timer to count the time left to the end of the game.
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Close2button Close all threads and the main window. Chapter - .Netterpillars: Artificial Intelligence and Sprites click
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter - River Pla.Net: Tiledgame GameisFields, Scrolling, and the DirectAudio Every4second When the running, decrease Time Left label on screen. If time's up, Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen display the game over message. Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Table 9-2 the actions for each germand window event. Chapter 8 -describes .Netterpillars II: Multiplayer Games Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - Logic for the Germ Window Events Table 9-2: Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
EVENT
ACTION
Appendix A - The State of PC Gaming
Load B - Motivations Change the shape of the window. Appendix in Games Appendix C - How Do I Make Games?
Click on the form
Close the form, decrease the number of active germs on the main window, and play a sound using the unmanaged function described earlier in this chapter.
Appendix D - Guidelines for Developing Successful Games Index
0.1 ListEvery of Figures
Choose a direction and move the window.
Listseconds of Tables
The last thing we must do before moving on to the coding phase is to draw the germ form on a piece of paper, so we can use it later to create the germ. Figure 9-6 shows a graphic representation of the germ, with the highlighted control points needed to draw a Bezier curve (which will be used to create our graphic's path).
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Figure 9-6: The germ form that will serve as a model for our window shape
Chapter As we can 6 -see Magic in Figure KindergarteN.: 9-6, to draw Adventure figuresGames, using Bezier ADO.NET, curves and DirectShow may be a little tricky: The whole image is
a composition of smaller curves,II:and each ofTechniques those curves definedAPI by exactly four points: the starting Chapter 7 - Magic KindergarteN. Animation andisSpeech and the8ending points, which the curve Games passesand through, and two "attraction points," which attract the curve Chapter - .Netterpillars II: Multiplayer Directplay but don't force the curve to pass through themselves. The curve on Microsoft's Paint works in the D-iNfEcT: Multithreading, Nonrectangular Windows, andtool Access to same way. So, Nonmanaged if we pushCode the intermediate points in opposite directions, we'll have an S-shaped curve like the one defined by points 13 to to Pocket 16 in Figure 9-6; if we push them in the same direction, we can create Bonus Chapter Porting .Nettrix PC simple curves, theofone created using points 4 to 7. Since we are drawing a closed curve, the last point Appendix A - Thelike State PC Gaming of the last must be the same coordinates as the first point of the sequence (that's why numbers 1 Appendix B -curve Motivations in on Games and 31 are theDo same point of Figure 9-6). Appendix C - at How I Make Games? Chapter 9
Appendix D - Guidelines for Developing Successful Games
Drawing the figure and marking the points on a piece of square paper, we can get the correct coordinate values for each point, which gives us enough information to create the Bezier curves for our program in List Figures theofcoding phase. Index
List of Tables
Our project is as simple as that. Let's get coding!
Game Programming with DirectX 9.0 The Coding.NET Phase by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hattonphase into three steps, one for each of the features we saw earlier in this chapter, as We'll divide the coding © 2003 expressed in the Apress following list:(696 pages) authors of this main text show how easy it can be to produce 1. First draft:The Create the game window.
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest 2. Second draft: Code the threads. version of Microsoft's Visual Studio.
3. Final version: Add final touches and include access to nonmanaged code. Table of Contents
First Draft: Creating the Game Main Window
.NET Game Programming with DirectX 9.0 Foreword
Let's start by creating the function to change the window shape. Since we'll need to change the shape of both Preface the main window and the child windows, we'll create a function that will fill an array with the points we'll use to Introduction
change the- .Nettrix: shape ofGDI+ the window; this function will receive an integer value that will be used to scale the points and Collision Detection accordingly—so the same function can be used to generate the points for the main window and the smaller Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites child windows. Chapter 1 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 - River Pla.Net: Game Scrolling, and be DirectAudio The following code listingTiled shows this Fields, function, which can included in a separate module of our project: Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6 Function - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Public BezierPoints(intSize As Single) As Point() Chapter 7 Magic KindergarteN. II: Animation Techniques and Speech API Dim ArrPoints As Point() = { _ Chapter - .Netterpillars II: * Multiplayer Games and Directplay New8 Point(intSize 54, 4 * intSize), New Point(intSize * 60, 10 * intSize), _ D-iNfEcT: Multithreading, Nonrectangular Windows, Access to New9 Point(intSize * 64, 30 * intSize), New and Point(intSize * 70, 32 * intSize),_ Chapter Nonmanaged Code New Point(intSize * 91, 14 * intSize), New Point(intSize * 105, 11 * intSize),_ Bonus Chapter Porting .Nettrix*to107, Pocket21 PC *intSize), New Point(intSize * 98, 36 * intSize),_ New Point(intSize Appendix A The State of PC Gaming New Point(intSize * 99, 45 * intSize), New Point(intSize * 119, 65 * intSize),_ Appendix - Motivations in Games New BPoint(intSize * 119, 72 *intSize), New Point(intSize * 110, 73 *intSize),_ Appendix C - How Do I Make Games? New Point(intSize * 92, 66 * intSize), New Point(intSize * 84, 74 * intSize),_ Appendix New D Point(intSize - Guidelines for Developing * 90, 97 Successful * intSize), Games New Point(intSize * 80, 105 * intSize),_
New Point(intSize * 61, 90 * intSize), New Point(intSize * 51, 90 * intSize), _ Index New Point(intSize * 30, 97 * intSize), New Point(intSize * 20, 83 * intSize), _ List of Figures New Point(intSize * 29, 70 * intSize), New Point(intSize * 29, 64 * intSize), _ List of Tables New Point(intSize * 0, 46 * intSize), New Point(intSize * 5, 27 * New Point(intSize * 25, 25 * intSize), New Point(intSize * 30, 31 New Point(intSize * 35, 30 * intSize), New Point(intSize * 42, 33 New Point(intSize * 44, 30 * intSize), New Point(intSize * 48, 10 New Point(intSize * 54, 4 * intSize)} BezierPoints = ArrPoints End Function
intSize), _ * intSize), _ * intSize), _ * intSize), _
In order to test this code, we can create a form and set the Region property of the window to the graphics path created from a Bezier curve that has the points described in the previous code listing. We can simply add the next code listing to the Load event of a new form to test our Bezier curve: Dim GraphicsPath As New Drawing2D.GraphicsPath() ' Create a window with the scale of 4 GraphicsPath.AddBeziers(BezierPoints(4)) Window.Region = New Region(GraphicsPath)
We include the preceding lines in a procedure so we can call it from the main and the child windows without needing to replicate code. Such a function will receive the window and the germ scale as parameters. Set the background color of the form to green and run the project. You should see results similar to what
appears in Figure 9-7.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Figure 9-7: A germ-shaped window
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Codewe discussed for graphics in Chapter 1 to create a function that will, besides We can nowNonmanaged use some tricks Bonus Chapter Pocket PC and fill the window with varying shades of green. We'll make this last changing the Porting window.Nettrix shape, to add a border Appendix A - The State of PC Gaming feature optional (controlled by a parameter), so we can turn the fill off if we want. Appendix B - Motivations in Games
The code thisDo function, receives three parameters (the window handle, the scaling factor, and a Appendix C for - How I Make which Games? BooleanDvalue) to turnfor theDeveloping filling on orSuccessful off is shown in the following code listing: Appendix - Guidelines Games Index
Sub PaintGerm(WindowHandle As IntPtr, GermSize As Single, Fill As Boolean) List of Figures Dim GraphicsPath As New Drawing2D.GraphicsPath() List of Tables Dim GameGraphics As Graphics Dim brushSquare As Drawing2D.PathGradientBrush ' Create the path that will be used when drawing GraphicsPath.AddBeziers(BezierPoints(GermSize)) ' Get the Graphics object of the background picture GameGraphics = Graphics.FromHwnd(WindowHandle) If Fill Then ' Create the gradient brush which will draw the germ ' Note: There's one center color and an array of border colors brushSquare = New Drawing2D.PathGradientBrush(GraphicsPath) brushSquare.CenterColor = Color.LightGreen brushSquare.SurroundColors = New Color() {Color.DarkGreen} ' Finally fill the germ GameGraphics.FillPath(brushSquare, GraphicsPath) End If ' Draw the germ border GameGraphics.DrawBeziers(New Pen(Color.Green, 6), BezierPoints(GermSize)) End Sub
We must call this function in the Paint event of the form we have just created so that the window is updated .NET Game Programming with DirectX 9.0 every time the system runs this event. We can see the result of calling this function with the fill parameter set in ISBN:1590590511 by Alexandre Santos Lobão and Ellen Figure 9-8. Hatton Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - 9-8: A gradient-filled, germ-shaped window with borders Figure Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC Appendix A window - The State of PC Gaming Since our is the right shape, we can go to the next step: creating the controls and putting them in the Appendix B Motivations in Games window in the right place (that's the tough part). We'll create two up-down controls to let the player choose the Appendix How Do Make and Games? number Cof-germs toIcatch the duration of the game in seconds, as well as labels to display the remaining Appendix - Guidelines for Developing Successful Games time andDnumber of germs. We'll also add a bitmap bearing the game name in the middle of the window, a Index button to start the game, and a button to close the window. List of Figures
Place all the window controls so they appear in the locations shown in Figure 9-9. It may take you a couple of List of Tables attempts before you manage to position all the window controls properly.
Figure 9-9: The final interface for the main window
.NET Game Programming with DirectX 9.0
by to Alexandre Lobãoshading, and Ellenas we did, ISBN:1590590511 You may also have turn off Santos the gradient because it might not look right with your images Hatton and labels. Apress © 2003 (696 pages)
To synchronize the of of thethis up-down controls withitthe will control the remaining time and Thevalues authors text show how easy canlabels be to that produce games using Managed DirectX 9.0 as anddepicted in the subsequent code germs, we'll add interesting two lines inmultimedia the ValueChanged event of this controls, programming with Visual Basic .NET on Everett, the latest listing: version of Microsoft's Visual Studio.
Sub NumTime_ValueChanged(sender As System.Object, e As System.EventArgs) _ Handles NumTime.ValueChanged .NET Game Programming with DirectX=9.0 lblTimeLeft.Text NumTime.Value Foreword End Sub
Table of Contents
Preface
Sub NumGerms_ValueChanged(sender As System.Object, e As System.EventArgs) _ Introduction Chapter 1
Handles NumGerms.ValueChanged - .Nettrix: GDI+ and Collision Detection
= NumGerms.Value -lblGermsLeft.Text .Netterpillars: Artificial Intelligence and Sprites End Sub Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 2 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen With this last step, we've completed the coding of the main window interface. In the next section, we'll include Chapter 6 controlling - Magic KindergarteN.: Adventure Games, and DirectShow code for the threads and the creation ofADO.NET, the child windows. Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
SecondD-iNfEcT: Draft:Multithreading, Coding the Threads Nonrectangular Windows, and Access to Nonmanaged Code
When coding the threads, we must be careful when creating them and destroying them. In order to have a Bonus Chapter Porting .Nettrix to Pocket PC reference to each new thread created, we'll define an array of Thread objects that can be used to abort all of Appendix A - The State of PC Gaming the threads, if needed. This array must be declared as a form variable so that it can be used when creating and Appendix B - Motivations in Games destroying the threads. Appendix C - How Do I Make Games?
To create threads,for we'll need to define a function Appendix D -the Guidelines Developing Successful Gamesthat will be passed as an argument to the New method of theThread object. For now, our thread will be a function that will simply create and display a second form (the Index child form), so the thread is finished when the form is closed. The code for creating the threads is as follows: List of Figures List of Tables
Private GemThread As Thread() Private Sub cmdGO_Click(sender As System.Object, e As System.EventArgs) _ Handles cmdGO.Click Dim i As Integer ReDim GemThread(NumGerms.Value) ' Create as many germs as defined by the user on the main window For i = 0 To NumGerms.Value - 1 GemThread(i) = New Thread(AddressOf NewGerm) GemThread(i).Name = "Germ " & (i + 1) GemThread(i).Start() Next ' Enable the timer that will count down the time TmrTime.Enabled = True End Sub Public Sub NewGerm() Dim f As New FrmGerm() ' Show the window f.ShowDialog() ' If we get here, the window was closed - so the germ was caught End Sub
If we run our program now, we'll see that we can create as many windows as defined in the germs number .NET Game Programming with DirectX 9.0 control box in the main dialog box, but they still won't look like germs, nor will they close when we close the ISBN:1590590511 by Alexandre Santos Lobão and Ellen main window. Hatton Apress © 2003 (696 pages) First, let's deal with the question of closing, so we can conclude the thread handling in the main window. The The authors of thisthat textaborts show all how easy it can ignoring be to produce next code listing shows a function the threads, any errors that may arise if the thread is interesting multimedia games using Managed DirectX 9.0 and already closed; the call to this function appears in the Closing event of the main window. We also show the programming with Visual Basic .NET on Everett, the latest code for the closeversion button—just a call to the Close of Microsoft's Visual Studio. method of the form.
Sub KillGerms() Dim i As Integer
Table of Contents
.NET Game Programming with DirectX 9.0 Foreword For i = 0 To NumGerms.Value - 1 Preface Try Introduction
GemThread(i).Abort()
Chapter 1
-Catch .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence Spritesdoesn't exists ' Ignore errors if and thread -End Managed Try DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 3
ChapterNext 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
End Sub Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Private As System.Object, Chapter 7 -Sub MagiccmdClose_Click(sender KindergarteN. II: Animation Techniques and Speech API e As System.EventArgs) _
Handles cmdClose.Click - .Netterpillars II: Multiplayer Games and Directplay Me.Close() D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 End Sub Nonmanaged Code Chapter 8
Bonus Chapter Porting .Nettrix to Pocket PC
Private frmStart_Closing(sender As Object, e As CancelEventArgs) _ Appendix A -Sub The State of PC Gaming Handles MyBase.Closing KillGerms() Appendix C - How Do I Make Games? End Sub Appendix B - Motivations in Games
Appendix D - Guidelines for Developing Successful Games Index List of Figures Placing the call to KillGerms in the Closing event will force the application to always close all child threads List of Tables before leaving; regardless of the way the main form is closed—when the user clicks the close button, when he
or she presses ALT+F4, or when he or she uses any other way of closing it. We must now create the code in the child form to change the window shape (by calling the ChangeWindowShape function in the Load event), define a startup position for the window, paint the germ (by simply calling PaintGerm in the Paint event), and finally close the window if the player clicks it. For now, let's not include any code to move the germs on screen, so we can easily click them and test our code. The implementation of these modifications is shown in the next piece of code. Remember that we must set the form border property to None, or else the picture we'll see won't be what we were expecting. Sub Form_Load(sender AsObject, e As EventArgs) Handles MyBase.Load Dim x As Integer Dim y As Integer ' Change the window shape to the bezier germ-like curve ChangeWindowShape(Me, 0.3) ' choose a random position on the screen Randomize() x = Rnd() * Screen.PrimaryScreen.WorkingArea.Width y = Rnd() * Screen.PrimaryScreen.WorkingArea.Height Me.Location = New Point(x, y) End Sub
Sub Form_Click(sender As Object, e As EventArgs) Handles MyBase.Click .NET Game Programming with DirectX 9.0 ' If the form was clicked, the germ was caught ISBN:1590590511 by Alexandre Santos Lobão and Ellen Me.Close() Hatton End Sub Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce
Sub FrmGerm_Paint(sender As Object, e Managed As PaintEventArgs) Handles MyBase.Paint interesting multimedia games using DirectX 9.0 and PaintGerm(Me.Handle, True) programming with 0.3, Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio. End Sub Table Contents If weofrun our program now, we'll be able to click the game start button (in this case, the iNfEcT! button) and see .NET Game Programming DirectX 9.0 the screen. We can kill each of them by clicking them—not very lots of newly generated with germs all over Foreword challenging, since they are stationary. Figure 9-10 displays a screen showing all germs—our first test of the Preface multithreaded program. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 9-10: The main germ window, reproducing ... In the next section, we'll code the final touches for our game—such as making the child germs move and including a call to the nonmanaged API function that plays a sound every time a germ is caught.
Final Version: Final Touches and Access to Nonmanaged Code There are just a few details we must code to finish our simple game, including the movement of the child windows, and checking the game over conditions. To make our child windows move, we can simply create a timer and add a constant value to the x and y coordinates on every timer tick. In the next code sample, we show the code to move the window, checking the screen resolution limits to change direction to avoid the germ going off the edge of the screen. Const randomness As Single = 0.05 Sub Timer1_Elapsed(sender As Object, e As ElapsedEventArgs) Handles Timer.Elapsed Dim x As Integer = Me.Location.X Dim y As Integer = Me.Location.Y Static incX As Integer = 10, incY As Integer = 10
If Rnd(1) < randomness Then incX = -incX Game Programming with DirectX 9.0 If Rnd(1).NET < randomness Then incY = -incY ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton If x + incX > Screen.PrimaryScreen.WorkingArea.Width Then incX = -incX Apress © 2003 (696 pages)
If y + incY > Screen.PrimaryScreen.WorkingArea.Height Then incY = -incY The authors of thisincX text show how easy it can be to produce If x + incX < 0 Then = -incX interesting multimedia games using Managed DirectX 9.0 and If y + incY < 0 Then = -incY programming with incY Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
x += incX y += incY Table of Contents .NET Game Programming=with 9.0 Me.Location NewDirectX Point(x, y) Foreword End Sub Preface Introduction
To help1 us- test various types randomDetection behavior when choosing a new direction, in the previous code sample Chapter .Nettrix: GDI+ andofCollision
we define -a .Netterpillars: constant, randomness, which can be changed to give the germs a more erratic or more constant Artificial Intelligence and Sprites behavior. Since our timer is triggering the elapsed event every 0.1 seconds, using values higher than 0.05 (5 Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ percent) will lead to such erratic movements that the player will hardly be able to catch any germs. Try different Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio values and decide for yourself which is the best randomness factor! Chapter 2
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 our - Magic Adventure Games, ADO.NET, andplay DirectShow Running codeKindergarteN.: now, we can see the germs moving and can at catching them, but the game still doesn't Chapter 7 (except - Magic KindergarteN. II: Animation Techniques and API code the game over conditions. terminate for when we press the close button), so weSpeech must now Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
For this game, we'll have two different ending conditions: The and player catches D-iNfEcT: Multithreading, Nonrectangular Windows, Access to all the germs, so he or she wins Chapter 9 and the game is over; or the time runs out before the player has caught all the germs, and he or she loses the Nonmanaged Code game. Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
To control the time, we'll need to add a timer control on the main form, set its interval to 1 second, and add code to decrement the label that states the time remaining every time the event is run. If the label reaches zero, Appendix C - How Do I Make Games? then we must end the game. The next code listing shows the code for the Tick event of the main window timer: Appendix B - Motivations in Games
Appendix D - Guidelines for Developing Successful Games Index
Sub TmrTime_Tick(sender As Object, e As EventArgs) Handles TmrTime.Tick ' decrement the time counter List of Tables lblTimeLeft.Text -= 1 ' Check to see if time's up If lblTimeLeft.Text = 0 Then ' abort all active threads TmrTime.Enabled = False KillGerms() MsgBox("Your computer cannot be cured anymore!", _ MsgBoxStyle.Critical, "Time's up!") End If End Sub List of Figures
To control the number of active germs, we can add extra code to our NewGerm function, which handles the germ window creation, to decrement the remaining germs label and perform the corresponding action when the last germ is caught. The full code for the function is presented in the next code sample: Public Sub NewGerm() Dim f As New FrmGerm() ' Show the window modally f.ShowDialog() ' If we get here, the window was closed - so the germ was caught SyncLock (Me) ' Decrement the number of live germs
lblGermsLeft.Text -= 1 .NET to Game Programming with DirectX ' check see if we were the last9.0 germ ISBN:1590590511 by Alexandre Santos Lobão and Ellen If lblGermsLeft.Text = 0 Then Hatton MessageBox.Show("You saved your computer!! The virus is gone!", _ Apress © 2003 (696 pages) "Congratulations!", MessageBoxButtons.OK, _ The authors of this text show how easy it can be to produce MessageBoxIcon.Exclamation) interesting multimedia games using Managed DirectX 9.0 and TmrTime.Enabled = False programming with Visual Basic .NET on Everett, the latest End If version of Microsoft's Visual Studio. End SyncLock End Sub Table of Contents .NET Game Programming with DirectX 9.0
Refer to the previous code sample to see the use of the SyncLock/End SyncLock block to prevent any Foreword problems when accessing the main window objects, which are external to the child threads and therefore work Preface like global variables. Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
For an extra touch, in the child window we'll play a sound every time a germ is caught, using the - .Netterpillars: Artificial Intelligence and Sprites sndPlaySoundA function, and call it in the Closing event of the child window.
Chapter 2 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter - River Pla.Net: Tiledfunction, Game Fields, Scrolling, and DirectAudio The full4 code to call the DLL including a wrapper function to perform the calls, is presented in the next Chapter code fragment: 5 - River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 -Function Magic KindergarteN. II: Animation Techniques and Speech API Declare sndPlaySoundA Lib "winmm.dll" (lpszSoundName As String, _ Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay uFlags As Integer) As Integer
'or D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code ' Function sndPlaySoundA(lpszSoundName As String, _ Bonus Chapter Porting .Nettrix to Pocket PC ' uFlags As Integer) As Integer Appendix A - The State of it PC Gaming ' If you declare in this way you will need to keep the function empty. Appendix ' (ButB either - Motivations wayinit Games will work.) 'End Function Appendix C - How Do I Make Games? Chapter 9
Appendix D - Guidelines for Developing Successful Games
Const SND_SYNC = &H0 Index Const SND_ASYNC = &H1 List of Figures Const SND_NODEFAULT = &H2 List of Tables Const SND_LOOP = &H8 Const SND_NOSTOP = &H10 Const SND_PURGE = &H40 Public Sub PlaySound(strSoundFile As String) sndPlaySoundA(strSoundFile, SND_ASYNC Or SND_NODEFAULT) End Sub
That's all for this chapter's sample game, except for some little improvements that we'll discuss in the next section. As we said before, this chapter's sample is an example on how simple, yet fun, a game can be.
Game Programming with DirectX 9.0 Adding the .NET Final Touches by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton As with the .Nettrix sample, there is little room for improvement in a game with such simple concepts; but, Apress 2003 (696 pages)with some small enhancements, as described in the following as always, we can try to ©make it better sections. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Improving the Interface
In our game, as it is now, the main window controls remain enabled while the game is running. What if the Table of clicks Contents player the game start button again and again? This will result in many uncontrolled threads being .NET with DirectX 9.0 run Game on theProgramming computer, possibly consuming the whole CPU because of their excessive numbers. So we'd
better disable all controls, replacing the various settings of the Enabled property of the timer we saw in Foreword the previous code listings with calls to the function presented in the next code piece, EnableInterface: Preface Introduction Chapter 1 - .Nettrix: GDI+ and CollisionAs Detection Sub EnableInterface(Enable Boolean) ChapterTmrTime.Enabled 2 - .Netterpillars: Artificial = NotIntelligence Enable and Sprites
= Enable ChapterNumGerms.Enabled 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ = Enable ChapterNumTime.Enabled 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio = Enable ChaptercmdGO.Enabled 5 - River Pla.Net II: DirectInput and Writing Text to Screen End Sub Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Adding Chapter 9 - Further Improvements Nonmanaged Code
Bonus WhatChapter else canPorting we do.Nettrix to improve to Pocket the game? PC Here are some suggestions to inspire you to play a little with
the game Feel free try your own ideas! Appendix A code. - The State of PCtoGaming Appendix B - Motivations in Games
We can create different shapes for the germs, and cycle between the shapes every half second, or everyTick event of the timer from the child windows. Be careful—some graphics boards can make Appendix D - Guidelines for Developing Successful Games the screen flash if we do this too often, with too many windows. Appendix C - How Do I Make Games? Index
List ofWe Figures can change the color of the germs every clock tick, using different degrees of green (or another List ofcolor), Tables to create the illusion that the germs are glowing.
We can create new ways of playing. For example, we could create a kill-or-get-killed game where there's no time limit, but every germ can generate another germ after 30 seconds; the game ends if we catch them all or if the germs reach epidemic proportions and there are 20 of them on the screen at once. As we can see, even a simple game can benefit from new ideas, and exercising our minds looking for such ideas will only make us better game developers!
Summary
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton In this chapter, we did a back-to-basics game, to remind us that a game doesn't need to be complex to be Apress © 2003 (696 pages) fun. The authors of this text show how easy it can be to produce
We also learned interesting some new multimedia concepts about .NET, including the following: gamesVisual using Basic Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
What threadsversion are, how of Microsoft's to control Visual them, and Studio. how to create multithreaded programs How to improve our game by creating nonrectangular windows Table of Contents
How to access nonmanaged code, .NET Game Programming with DirectX 9.0 which will be useful until all operating systems are constructed using .NET libraries Foreword Preface
With this chapter, we conclude the main part of our book. We hope that it was as much fun and instructive for you to read as it was for us to write.
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter To give2you - .Netterpillars: some ideas about Artificial theIntelligence next steps you and Sprites can take in the game developing world, we present
appendices written byDirectX from some famous namesBasics in the and game developing industry. Find out what these Chapter 3 - Managed First Steps: Direct3D DirectX vs. GDI+ authors4say aboutPla.Net: what you must consider you wantand to get serious about game programming. Chapter - River Tiled Game Fields, ifScrolling, DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Good luck with your games!
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 Bonus Chapter Porting .Nettrix ISBN:1590590511 to Pocket PC by Alexandre Santos Lobão and Ellen Hatton
In this bonus chapter, we'll go back to our first sample game, .Nettrix, and update it to make it run on a Apress © 2003 (696 pages) Pocket PC (see Figure 1). There'll be no new features, except for a few adjustments to the interface to this text show how easy it can be to produce make it playable The on aauthors PocketofPC and an update on the score counting. interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 1: .Nettrix II, running on a Pocket PC Before starting the migration of our game, let's talk a little more about creating programs for mobile devices in the next section.
Programming for Mobile Devices The .NET framework opens whole new horizons to all programmers, and especially to game programmers, with its property of running the same code across different devices running different operating systems. In this first version, .NET is, most of the time, a simple wrapper to the operating system functions, which are still present running everything in the background; but Microsoft and other companies are already working on operating systems based on the .NET Framework, so we can expect the compatibility to grow over the next few years. Note Of course, this compatibility will never be 100 percent, since every device has its own characteristics, with its own strengths and weaknesses; but it's really great to be able to write our program for a PC and make it run on a Pocket PC, with just a few adjustments!
Creating Smart Device Applications in9.0.NET .NET Game Programming with DirectX by Alexandre Santos Lobão and Ellen
ISBN:1590590511
In versions of Visual Studio prior to .NET, if we wanted to create a program to run on a mobile device such Hatton as the Pocket PC, we had to use specific version of the compiler, and there was no compromise from Apress © 2003 (696 a pages) the operating system in providing compatible porting a program was sometimes a The authors of this text show functions. how easy itTherefore, can be to produce matter of erasinginteresting and rewriting everything. multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version Microsoft'strue Visual Studio. This porting problem wasofespecially when dealing with graphical functions. Even simple programs sometimes needed adjustments before running on a different device. Table of Studio Contents Visual .NET 2003 (code-named Everett) already has built-in support for the .NET Compact .NET Game Programming with DirectX 9.0 Framework, with the corresponding assemblies and project templates to support project-targeting mobile Foreword devices. The new project templates are named Smart Device Application and ASP.NET Mobile Preface Application, and they allow us to create applications to be used on either Pocket PC- or Windows CE-
based devices. Figure 2 shows the New Solution dialog box of Visual Studio, highlighting the Smart Device Introduction Application Chapter 1 - item. .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 2: One of the new Visual Studio .NET 2003 application types
Choosing the Platform and Project Type Once we have created a new smart device application, Visual Studio .NET presents a new dialog box that lets us choose the target platform (Windows CE or Pocket PC) and listing the project types available to the platform, as shown in Figure 3.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction
Figure 3: Choosing the platform and the project type
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 target - .Netterpillars: Intelligence and SpritesWizard presents the available devices the For each platform, Artificial the Smart Device Application Chapter 3 Managed DirectX First Steps: Direct3D Basics DirectX vs.the GDI+ application can be deployed to. In Figure 3, we can see and to the right of target platform list window that Chapter 4 two - River Pla.Net: Tileddevices: Game Fields, Scrolling, andPC DirectAudio there are possible target a physical Pocket (we used a Compaq iPaq for the purposes of Chapter 5 River Pla.Net II: DirectInput and Writing Text to this chapter) and a Pocket PC emulator, which is installed Screen along with the Visual Studio .NET 2003. Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API Deploying Your Program to an Emulator
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and options: Access to Once the is created, we can see that we have new menu On the Tools menu, there now Chapter 9 project Nonmanaged Code appears a Connect to Device option, and under the Build menu appears the Deploy option. Bonus Chapter Porting .Nettrix to Pocket PC
After creating a State program, can click the Start button in the Visual Studio toolbar just like we would in any Appendix A - The of PCwe Gaming project targeting regularinPCs. Visual Studio then builds the program with the proper libraries according to Appendix B - Motivations Games the platform we choose, and opens a dialog box that allows us to choose the target device for the Appendix C - How Do I Make Games? application, as presented in Figure 4.Successful Games Appendix D - Guidelines for Developing Index List of Figures List of Tables
Figure 4: Choosing the target device for our application If we choose to deploy the program to the emulator, Visual Studio loads the emulator before starting to deploy. The emulator is an exact copy of the Pocket PC system, including all programs (yes, it comes with Solitaire, too), right down to the emulator skins, which are bitmaps with active buttons. This emulator allows us to test our application in the exact same way we would with a real device without having to own a real device. Figure 5 presents the first screen of the emulator, when it's opened for the first time. We have already seen an emulator with a skin in Figure 1; but for practical reasons we use the emulator without a skin throughout this chapter.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games IndexFigure 5: The Pocket PC emulator List of Figures List of Tables Once the emulator is loaded or the device is connected, Visual Studio .NET deploys not only the
application we created, but also any necessary libraries to make our program run on the desired device. The application is deployed to the \Windows directory on the device, and Visual Studio automatically runs it, and it even allows us to debug the application. Tip One last word about the emulator: When we close the emulator window, it presents us with a dialog box that allows us to save the emulator state (thus preserving the deployed files) or simply shut down the program, losing all changes since the last time we saved the state. For small projects, you'll probably want to simply shut down the emulator, since the deployment of the .NET Compact Framework doesn't takes too long; but if you are working with a large project that has many extra files (like video or image files, or even many different applications), you'll probably want to save the emulator state so you won't need to redeploy all project files every time you start working with the project. Figure 6 presents the closing dialog box of the emulator.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game FigureProgramming 6: Choosingwith the DirectX target device 9.0 to run our application Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET GamePC Programming with and DirectX 9.0 Running Desktop Programs Operating Systems on Mobile ISBN:1590590511 by Alexandre Santos Lobão and Ellen Devices Hatton Apress © 2003 (696 pages)
You'll be able to run any simple desktop PC program with very few adjustments on this type of project, and The authors of this text show how easy it can be to produce some programs actually won't need any updates, just a new compilation and, of course, replacement of interesting multimedia games using Managed DirectX 9.0 and form interface controls with thewith corresponding for Everett, the smart programming Visual Basic ones .NET on thedevice latest project. version of Microsoft's Visual Studio.
As for the graphical functions, of course, GDI+ is not completely present in the mobile device, but many of its functions are there and use the same interfaces, so porting graphical applications is simpler than in Table of Contents previous versions of Visual Studio. .NET Game Programming with DirectX 9.0
And as for DirectX, only DirectPlay for Pocket PC is available, and can be downloaded from Foreword
http://msdn.microsoft.com/directx by following the DirectX Downloads link and selecting DirectPlay for PocketPC.
Preface
Introduction
Chapter 1 - .Nettrix: GDI+ and Collision The Window CE operating system runsDetection on many different devices, from pocket computers to automobiles, Chapter 2 - .Netterpillars: and so the support for variousArtificial DirectX Intelligence technologies is Sprites built in when the device manufacturers create their Chapter 3 system. - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+can be supported, if any. operating Depending on the device, different DirectX technologies Chapter - River Pla.Net: Tiled Game and DirectAudio DirectX4technologies for Windows CEFields, can't Scrolling, be downloaded and then added to an operating system as in Chapter the Windows 5 - River desktop Pla.Net world: II: DirectInput Just as there andisWriting no oneText Windows to Screen CE operating system, there is no one level
of DirectX Chapter 6 -support. Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Windows CE .NET, the newer version of the operating system, has the ability to support DirectDraw, - .Netterpillars II: Multiplayer Games and Directplay DirectSound, and DirectShow, depending on the device. More information about multimedia on Windows D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter CE can9be- found at http://msdn.microsoft.com/library/enNonmanaged Code us/wcemain4/htm/_cmoriMultimediaTechnologies.asp. Chapter 8
Bonus Chapter Porting .Nettrix to Pocket PC
Appendix A - The of PC Gamingof DirectX for Windows CE and Pocket PC, our DirectX programs won't Since there are State different versions Appendix B Motivations in Games be portable across these platforms with a simple recompilation; and there's no .NET interface for DirectX Appendix C -devices, How Do so I Make on mobile we'll Games? need to access DirectX directly, using Visual C++ for mobile devices. Appendix D - Guidelines for Developing Successful Games
Another important point to make regarding DirectX on mobile devices is that since the operating systems Index areofdesigned List Figures for the capabilities and limitations of embedded systems, the DirectX implementations running over them tend to be pared down from the desktop offerings (this is especially true of Direct3D). List of Tables So, don't expect to create a full-speed Doom IV for a Pocket PC or Windows CE.
Now let's move on to discuss the proposal for this chapter's sample game, .Nettrix II.
.NET Game Programming with DirectX 9.0 The Game Proposal by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Our main objective is to do the minimum number of updates while preserving the performance of the new Apress © 2003 (696 pages) device. The authors of this text show how easy it can be to produce
We'll also do an interface update: including navigation buttons on the9.0 interface so that the player can play interesting multimedia games using Managed DirectX and programming with Visual Basic .NET on Everett, the latest it by tapping the screen. version of Microsoft's Visual Studio.
In the next section, we'll discuss some extra details in the game project. Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Game Project by Alexandre Santos Lobão and Ellen
ISBN:1590590511
There's no need Hatton for a full project for this game, because we already did one in Chapter 1. So all we'll do Apress 2003 (696 pages) to creating mobile device programs is to make a new projectas a project and also as©an introduction .Nettrix II-and to define the basic interface to meet the needs of our game proposal. Let's say that this The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and interface is a "visual prototype" of the game.
programming with Visual Basic .NET on Everett, the latest of Microsoft's Studio. Figure 7 presentsversion our visual prototype,Visual including the desired navigation buttons. For the sake of simplicity,
we set the text of each button to <, >, /\, and \/ for right, left, up, and down directions, in that order. Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 7: Our game interface, updated for Pocket PCs Now we can live out the dream of every unorganized programmer: to start coding without a real project! A brief word about this: Sometime ago a guy told one of us that this is called "Zen game programming," referring to the Zen philosophy we've all already heard about in dozens of movies. ("Don't plan to reach the target, BE the target," and other things like that.) But remember, we already did a project in Chapter 1, that's why we don't need one here! Before entering the code phase, let's look at Figure 8, which shows the .Nettrix class diagram we came up with in Chapter 1.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0
Figure 8: .Nettrix class diagram
Foreword Preface
To refresh your memory, let's take a quick look at the details of this diagram. The Square class draws Introduction and erases squareGDI+ on the screen; theDetection Block class draws, erases, and moves four squares to form a Chapter 1 -a .Nettrix: and Collision basic .Nettrix block with different and and the Sprites GameEngine class has some general-use functions, Chapter 2 - .Netterpillars: Artificialshapes; Intelligence such as3 the collision detection support and Basics the basic to GDI+ deal with this array. Besides these Chapter - Managed DirectX First Steps:array Direct3D andfunctions DirectX vs.
classes, we implemented the game logic directly in the main form events: The game variables are - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio initialized in the Load event, the game loop is in the Tick event of a timer, and the input handling routine Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen is in the KeyPress event. Chapter 4 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 - Magic KindergarteN. II:the Animation Techniques and Speech API our code to run on the Pocket In the coding phase, we'll discuss necessary modifications to update Chapter PC. 8 - .Netterpillars II: Multiplayer Games and Directplay Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Game Programming with DirectX 9.0 The Coding.NET Phase by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Although this is our first game targeting a mobile device, porting a game is so simple that we'll do everything in Apress ©no 2003 (696 pages)second draft, and so on). one simple step (hence, first draft, The authors of this text show how easy it can be to produce
First, we'll copy the code from Chaptergames 1, buildusing it, and see which errors interesting multimedia Managed DirectX 9.0occur and and fix them. Then we'll perform programming withtoVisual .NET Everett, latest any updates to the game needed makeBasic it run, if it on doesn't runthe after removing the build errors, and include the of elements. Microsoft's Visual Studio. code for the new version interface
Adapting the Code to Build for a Pocket PC Target
Table of Contents
.NET Game Programming with DirectX 9.0
Copying the code from Chapter 1 into our project and compiling it will present us with some compatibility issues, Foreword but they should be fairly easy for us to fix. Once we have done this, there'll probably be tougher problems to Preface solve for functions and methods that preserve the same interface but do not behave the same.
Introduction
Chapter 1 build - .Nettrix: GDI+ Detection Our first presents us and with Collision only three errors: two when building the program and one when running it. Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites
The first is the MessageBox parameters, which areand different onvs.the Pocket PC version. The last parameter Chapter 3 one - Managed DirectX First Steps: Direct3D Basics DirectX GDI+ (the default button) is mandatory, andFields, we also have to modify the icon name, since the Stop icon corresponds Chapter 4 - River Pla.Net: Tiled Game Scrolling, and DirectAudio to the Hand icon (the older used and on the desktop Chapter 5 - River Pla.Net II: name DirectInput Writing Textplatform) to Screenin the Pocket PC. So we need to change our "game 6over" message box line as follows: Games, ADO.NET, and DirectShow Chapter - Magic KindergarteN.: Adventure Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API MessageBox.Show("GAME OVER", Games ".NetTrix", MessageBoxButtons.OK, _ Chapter 8 - .Netterpillars II: Multiplayer and Directplay Chapter 9
-
MessageBoxIcon.Hand, MessageBoxDefaultButton.Button1) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
This error illustrates perfectly the first kind of error we would expect to find when porting games to mobile devices: Some functions take slightly different parameters, and some of the overrides (or different ways to call Appendix C - How Do I Make Games? the same functions) are missing. These are the easier problems to solve, since all we have to do is to make Appendix D - Guidelines for Developing Successful Games simple adjustments, such as completing the extra parameters or correcting the parameter values. Appendix B - Motivations in Games
Index
List ofNote Figures An interesting detail is that MessageBoxIcon.Hand does work on desktop PCs, so this update is List of Tables only needed because we weren't targeting both platforms at the beginning of the project in Chapter 1.
The second update refers to the Activated event for the form, which doesn't exist on the Pocket PC. The new event name is GotFocus, so all we need to do is replace the Handles clause of the event with the following: Sub FrmNetTrix_Activated(sender As Object, e As EventArgs) _ Handles MyBase.GotFocus
This error is a good example of the second type of problem we face when porting our games to mobile devices: Some functions, methods, and events are missing or correspond to different ones. This kind of error may be somewhat difficult to fix, since we must look for the relevant method, event, or function and, if there's no exact match, sometimes have to rewrite part of the program. We'll come across another error of the same type in the Square class: The Graphics object for the Pocket PC is far simpler than the one for desktop computers, and it doesn't support the DrawPath method used to draw a gradient square. In this case, we'll need to rewrite the whole Draw method of this class to make it simply draw a square with a solid border. The code for this update is presented later in the chapter, in the section "Updating the Square Class." After fixing these three compilation errors, our program will run on the Pocket PC, but it'll abort as soon as we click the Start button, with a "Null Reference" error.
The Visual Studio .Net online documentation indicates that in this version of the .NET Compact Framework we Programming with DirectX 9.0 need to explicitly .NET createGame bitmaps for the picture boxes in code. To fix this problem, we need to add two extra ISBN:1590590511 by Alexandre lines to the form initialization: Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
PicBackground.Image = New Bitmap(PicBackground.Width, PicBackground.Height) The authors of this text show how easy it can be to produce PicNextBlock.Image = New Bitmap(PicNextBlock.Width, PicNextBlock.Height) interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Since we are working with a beta version, this behavior may change in the final release. However, it illustrates very well the third variety of error we can find when moving programs to other platforms, such as mobile Table of Contents devices: The program generates a runtime error because something (a function, method, or event) doesn't .NET Game behave asProgramming expected. with DirectX 9.0 Foreword
This class of errors is a little more difficult than the previous ones to fix, since the error can occur in a different Preface place from where it is generated. In our sample, we get an error inside the Square class the first time we try to Introduction create a objectand to draw on the screen; but the error is raised over the call stack until the Click Chapter 1 Graphics - .Nettrix: GDI+ Collision Detection event on Start button. Artificial So we could get confused when debugging the code, until we set breakpoints and do Chapter 2 the - .Netterpillars: Intelligence and Sprites a step-by-step debugging. Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Once we have fixed this error, our program should run without errors. But when we click the Start button, we'll
Chapter 5 the - River Pla.Net II: DirectInput andexpected. Writing Text to Screen see that blocks are falling slower than Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow This error the last and category we'll encounter when porting our programs: Chapter 7 -exemplifies Magic KindergarteN. II: toughest Animationerror Techniques and Speech API
Everything fine, but as expected. Or, in other words, there are no errors, but Chapter 8 -works .Netterpillars II:something Multiplayerdoesn't Gamesbehave and Directplay our programD-iNfEcT: doesn't work as planned. Multithreading, Nonrectangular Windows, and Access to -
Chapter 9
Nonmanaged Code Experienced Bonus Chapter programmers Porting .Nettrixprobably to Pockethave PC a good idea about what is happening in our program: The program is
working fine, the timer is okay, the collision detection code is facing no problems, and the game over tests are functioning as expected, but the screen drawing on a Pocket PC is simply slower than on a desktop PC.
Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Appendix C -fixing How Do Make Games? So let's try theIproblem. Appendix D - Guidelines for Developing Successful Games
If we run through our program, we see that we are creating the Graphics object inside the Show and Hide Index methods of the Square class. That's no big deal when running in a desktop PC, but when we run on a mobile List of Figures device, we need to improve this code to make it faster. This can be done by creating a Graphics object for List of Tables each pictureBox when initializing the game, and then passing this object to the drawing functions.
In the next sections, we'll look at the required updates to each of the game classes and the main form to improve the game speed.
Updating the GameEngine Class Most of the updates will occur in the GameEngine class; we'll have to add some extra properties and methods and make adjustments to the Block and Square classes: We need to include a Graphics object for each pictureBox on the form. We need a method to initialize these new properties to their proper values. We also need to create a Clear method to erase the pictureBoxes. After we have implemented these modifications, we need to adapt the game's main loop (remember, in this game the "loop" is the code inside the Tick event of the timer) to clear the back buffers and to refresh them, and make the adjustments to the base classes (Block and Square) to deal with the new logic. The updates to the GameEngine class are shown in the following code listing: ' Update to Pocket PC - Create rectangles to store the screen position
Public Shared rectBackground As Rectangle Game Programming with DirectX 9.0 Public Shared.NET rectNextBlock As Rectangle ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton ' Update to Pocket PC - New Global Graphics objects Apress © 2003 (696 pages)
Public Shared GraphBackground As Graphics authors of this text show how easy it can be to produce Public SharedTheGraphNextBlock As Graphics
interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest ' Update to Pocket : New Visual method to clear the game field and the next block version ofPC Microsoft's Studio.
' images, instead of using the Invalidate method of a pictureBox Public Shared Sub Clear() Table of ' Contents Since we are working in a solid background, we can just draw a solid .NET Game ' Programming rectanglewith in DirectX order9.0 to "clear" the game field Foreword GraphBackground.FillRectangle(New SolidBrush(backcolor), rectBackground) Preface' Clear the "next block" image Introduction GraphNextBlock.FillRectangle(New SolidBrush(backcolor), rectNextBlock) End Sub Chapter 1 - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites ' Update to Pocket PCFirst : New that will Chapter 3 - Managed DirectX Steps:method Direct3D Create Basics andgraphics DirectX vs. objects GDI+
' be the Fields, application Chapter 4 used - Riverthroughout Pla.Net: Tiled Game Scrolling, and DirectAudio Public Sub II: Initialize(frmSource Asto Form, Chapter 5 Shared - River Pla.Net DirectInput and Writing Text Screen PicBackground As PictureBox, _ PicNextBlock As PictureBox) - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow ' Set the game field backcolor Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API backcolor = Color.Black Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay ' Update to Pocket PC - Create rectangles to help on drawing to screen D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to ChapterrectBackground 9 = New Rectangle(0, 0, _ Nonmanaged Code PicBackground.Width, PicBackground.Height) Bonus Chapter Porting .Nettrix to Pocket PC rectNextBlock = New Rectangle(0, 0, _ Appendix A - The State of PC Gaming PicNextBlock.Width, PicNextBlock.Height) Chapter 6
Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
' Update to Pocket PC: Create Graphics to draw on the back buffers
Appendix D - Guidelines for Developing Successful Games GraphBackground = Graphics.FromImage(PicBackground.Image) Index GraphNextBlock = Graphics.FromImage(PicNextBlock.Image) List of Figures End Sub List of Tables
In the next section, we'll discuss the modifications needed to update the Square and Block classes.
Updating the Square Class TheSquare class will need two updates: changes to the interface of the Draw and Hide methods so they will receive the Graphics object to use instead of a handle of the pictureBox; and rewrites to the Draw method to draw a solid square instead of a gradient-filled one, since the Pocket PC version of the Graphics object doesn't support this feature. The final version of the code, presented in the next listing, is far simpler than the corresponding one for the desktop version of the game. Refer to Chapter 1 to compare both implementations. Public Class ClsSquare Public location As Point Public size As size Public forecolor As Color Public backcolor As Color ' Update: There's no graphics path on pocket PC ' So we draw a solid rectangle with a border Public Sub Show(Graph As Graphics)
' Draw the square .NET Game Programming Drawing.SolidBrush(backcolor), with DirectX 9.0 Graph.FillRectangle(New _ ISBN:1590590511 by Alexandre Santos Lobão and location.X,Ellen location.Y, _ Hatton size.Width, size.Height) Apress © 2003 (696 pages) ' Draw the square border The authors of this text showPen(forecolor), how easy it can be to _ produce Graph.DrawRectangle(New interesting multimedia games using Managed DirectX 9.0 and location.X, location.Y, programming with Visual Basic .NET on Everett, the _ latest size.Width - 1, size.Height - 1) version of Microsoft's Visual Studio. End Sub Public Sub Hide(Graph As Graphics) Table of Contents Dim rectSquare As Rectangle .NET Game Programming with DirectX 9.0 ' Since we are working in a solid background, we can just draw a solid Foreword ' rectangle in order to "hide" the current square Preface rectSquare = New Rectangle(location.X, location.Y, _ Introduction size.Width, size.Height) SolidBrush(ClsGameField.backcolor), rectSquare) Chapter 1 -Graph.FillRectangle(New .Nettrix: GDI+ and Collision Detection ChapterEnd 2 -Sub .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Sub New(InitialSize size, InitialBackcolor As Color, _ ChapterPublic 4 - River Pla.Net: Tiled Game Fields, As Scrolling, and DirectAudio Chapter 5
Color) - River Pla.Net II:InitialForecolor DirectInput and WritingAs Text to Screen
size = InitialSize backcolor = InitialBackcolor Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API forecolor = InitialForecolor Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay End Sub D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 End Class Nonmanaged Code Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A -section, The State of PC Gaming In the next we'll present the modifications we need to make to the Block class. Appendix B - Motivations in Games Appendix C - How Do I Make Games?
Updating the Block Class
Appendix D - Guidelines for Developing Successful Games Index The block class has more than 300 lines of code, including eight methods, two enumerations, and a bunch of List of FiguresSince everything is well organized, all we need to update is the two methods that draw and hide a properties. List of Tables block, so they will receive a Graphics object as a parameter and use this object when calling the
corresponding methods of the Square class. The following code listing presents the new code for these methods: ' Draw each square of the block on the game field Public Sub Show(Graph As Graphics) ' Update to Pocket PC: Show method now receives a graphics object square1.Show(Graph) square2.Show(Graph) square3.Show(Graph) square4.Show(Graph) End Sub ' Hide each square of the block on the game field Public Sub Hide(Graph As Graphics) ' Update to Pocket PC: Hide method now receives a graphics object square1.Hide(Graph) square2.Hide(Graph) square3.Hide(Graph) square4.Hide(Graph) End Sub
Besides these modifications, we need to change the calls for these methods inside the Rotate,Down,Left, .NETpassing Game Programming DirectX 9.0GameField class, as illustrated in the next code andRight methods, the Graphicswith object from the ISBN:1590590511 by Alexandre Santos Lobão and Ellen line: Hatton Apress © 2003 (696 pages)
Show(ClsGameField.GraphBackground) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest With these simpleversion updates, the portingVisual of ourStudio. Block class is complete. Note that the entire collision detection of Microsoft's
algorithm (implemented in the Down,Left, and Right methods) and the complicated logic in the Rotate method doesn't need to be updated.
Table of Contents
.NET Game DirectX 9.0 In the nextProgramming section we'll with discuss the updates needed to the main game form. Foreword Preface
Updating the Game Form
Introduction
Chapter 1 - .Nettrix: GDI+classes, and Collision Detection After updating the game we'll need to modify the game form to adapt to these updates. Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites
We'll need- to update the form Load event, the Click event of the Start button, and the Tick event of the Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ timer. Besides these changes, we'll have to add code for the extra interface buttons we created for the Pocket Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio PC version. Chapter 3 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6 at - Magic Adventure Games, ADO.NET, and DirectShow Let's look each KindergarteN.: of these updates in detail. Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API
Starting8 with the form's Load event, weGames need to include a call to the Initialize method of the GameEngine Chapter - .Netterpillars II: Multiplayer and Directplay class so theD-iNfEcT: back buffers will be created as well as the Graphics objects Multithreading, Nonrectangular Windows, and Access to for them and for the form, as presented inNonmanaged the next piece Code of code:
Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The of PCPC: Gaming ' Update to State Pocket The initialize function will create the Appendix B - Motivations Games ' buffers and in Graphics objects used to draw on the screen Appendix ClsGameField.Initialize(Me, C - How Do I Make Games? PicBackground, PicNextBlock) Appendix D - Guidelines for Developing Successful Games Index
To update the Start button code, we'll need to replace the call to the Invalidate method of the pictureBoxes on the form (which was used to clean the screen when starting a new game) to a call to the List of Tables Clear method of the GameEngine class, which explicitly cleans the images by drawing a black rectangle on them. List of Figures
We'll also have to update the call to the Show method of the blocks to use the correct parameters, and call the Invalidate method of the pictureBoxes that will commit the drawings to screen. The final code for the Click event of the Start button is presented in the following code listing: Sub CmdStart_Click(sender As Object, e As EventArgs) Handles cmdStart.Click TmrGameClock.Enabled = True cmdStart.Enabled = False LblScoreValue.Text = 0 ' Clean the collisions control array ClsGameField.Reset() ' Clean the game field ' Update to Pocket PC: we must draw the blank screen, instead of simply ' invalidating a picture box image ClsGameField.Clear() ' Create and show the current and next blocks CurrentBlock = New clsBlock(New Point(ClsGameField.SquareSize * 6, 50)) CurrentBlock.Show(ClsGameField.GraphBackground)
NextBlock = New clsBlock(New Point(20, 10)) .NET Game Programming with DirectX 9.0 NextBlock.Show(ClsGameField.GraphNextBlock) ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton ' Refresh everything (updating the screen) Apress © 2003 (696 pages)
PicBackground.Invalidate() The authors of this text show how easy it can be to produce PicNextBlock.Invalidate() interesting multimedia games using Managed DirectX 9.0 and End Sub programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
In the Tick event of the timer, we'll do the same updates as we did in the preceding listing: Replace the call to Table thepictureBox of Contents Invalidate method to a call to the new GameEngine Clear method and update any
callsGame to theProgramming Show and Hide methods of the Block class to pass the correct parameters. .NET with DirectX 9.0 Foreword
The full code of the Tick event is presented in the following code segment. The updates in the code are marked with the comment "Update to Pocket PC":
Preface
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection Sub tmrGameClock_Tick(sender As Object, Chapter 2 - .Netterpillars: Artificial Intelligence and Spritese As EventArgs) Handles TmrGameClock.Tick
Static stillProcessing As Boolean = False - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Dim ErasedLines As Integer
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Try
' Prevent the code from running if the previous tick ' is still being processed Chapter 8 -If .Netterpillars II: MultiplayerThen Games and Directplay stillProcessing Exit Sub D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -stillProcessing = True Nonmanaged Code ' Control the block falling Bonus Chapter Porting .Nettrix to Pocket PC If Not CurrentBlock.Down() Then Appendix A - The State of PCfor Gaming ' Test game over Appendix B - Motivations in Games If CurrentBlock.Top = 0 Then Appendix C - How Do I Make Games? TmrGameClock.Enabled = False Appendix D - Guidelines cmdStart.Enabled for Developing Successful= Games True Index ' Update to Pocket PC - Different parameters List of Figures ' on the MessageBox Show Method MessageBox.Show("GAME OVER", ".NetTrix", _ List of Tables MessageBoxButtons.OK, MessageBoxIcon.Hand, _ MessageBoxDefaultButton.Button1) stillProcessing = False Exit Sub End If ' Increase the score using the number of deleted lines, if any ErasedLines = ClsGameField.CheckLines() LblScoreValue.Text += 100 * ErasedLines ' Clear the game field If ErasedLines > 0 Then ' Update to Pocket PC - Clear method ClsGameField.Clear() ClsGameField.Redraw() End If ' Release the current block from memory CurrentBlock = Nothing ' Create the new current block CurrentBlock = New clsBlock(New Point(ClsGameField.SquareSize * 6, _ 0), NextBlock.BlockType) CurrentBlock.Show(ClsGameField.GraphBackground) ' Release the next block from memory NextBlock.Hide(ClsGameField.GraphNextBlock)
NextBlock = Nothing Game the Programming with DirectX 9.0 '.NET Create new next block ISBN:1590590511 by Alexandre Santos Lobão and Ellen NextBlock = New clsBlock(New Point(20, 10)) Hatton NextBlock.Show(ClsGameField.GraphNextBlock) Apress © 2003 (696 pages) End If The authors of this text can be to produce ' Update to Pocket PCshow - how use easy of itinvalidate to redraw the screen interesting multimedia games using Managed DirectX 9.0 and ' Refresh the with screen programming Visual Basic .NET on Everett, the latest PicBackground.Invalidate() version of Microsoft's Visual Studio. stillProcessing = False Table of Contents Catch ex As Exception .NET Game Programming with DirectX 9.0 MessageBox.Show(ex.Message) Foreword End Try Preface End Sub Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
In Figure 9,- we can see the result of the updates: The game is already ready to play. Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 3 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 9: With just a few updates, here is .Nettrix II. The final update to our code is to include the event handlers for the new buttons we have created, named cmdUp,cmdDown,cmdLeft, and cmdRight. The code for these buttons is very straightforward—just call the corresponding methods of the currentBlock variable as we did with the KeyPress event (coded in Chapter 1, and used without any updates in this version of the game). The next code listing shows the code for the four buttons: Sub cmdUp_Click(sender As Object, e As EventArgs) Handles cmdUp.Click CurrentBlock.Rotate() End Sub
Sub cmdDown_Click(sender As Object, e As EventArgs) Handles cmdDown.Click .NET Game Programming with DirectX 9.0 CurrentBlock.Down() ISBN:1590590511 by Alexandre Santos Lobão and Ellen End Sub Hatton Apress © 2003 (696 pages)
Sub cmdRight_Click(sender As Object, e As EventArgs) Handles cmdRight.Click The authors of this text show how easy it can be to produce CurrentBlock.Right() interesting multimedia games using Managed DirectX 9.0 and End Sub programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Sub cmdLeft_Click(sender As Object, e As EventArgs) Handles cmdLeft.Click CurrentBlock.Left() Table Contents End ofSub .NET Game Programming with DirectX 9.0 Foreword Preface
TheKeyPress event, as we said before, won't need any updates. We can leave it on the form so that players Introduction can eventually play with the navigation keys when using a keyboard attached to the mobile device. Chapter 1 - .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Now we can run our game and play .Nettrix II on the emulator or on a real device, as depicted in Figure 10.
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Figure 10: Our game is working well, and we have reached "Game Over." This is all we need to do to create a mobile version of our game. In the next section we'll look at some finetuning.
Game Programming with DirectX 9.0 Adding the .NET Final Touches by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Given the sampleHatton game's simplicity, there is little room for improvement in this chapter, but we can always Apress ©to 2003 pages)to improve playability. add some extra touches our(696 games The authors of this text show how easy it can be to produce
In this chapter's sample game, after playing few dozen times, we feel interesting multimedia gamesa using Managed DirectX 9.0 that and using the Pocket PC buttons withaVisual Basic .NET the latest interface is not asprogramming simple as using keyboard, sinceon onEverett, a keyboard we can use more than one finger at versionkeys of Microsoft's Studio. once on the navigation to controlVisual the blocks. We can't solve this issue, but we can increase the game rewards so players will feel more comfortable with the scoring, even if they don't manage to clear many lines. To do this, we'll improve the score .NET Gameto Programming DirectX counting add 5 pointswith to the score9.0 for each block dropped. Referring back to Chapter 1, recall that the Foreword game score only increased when a line is filled (up to 100 points per line); including these extra rewards Preface will make the game more addictive.
Table of Contents
Introduction
In the code, all we need toand do is to include one more line of code inside the If block of the Tick event Chapter 1 - .Nettrix: GDI+ Collision Detection that tests collisions, asArtificial presented in the following code snippet: Chapter 2 for - .Netterpillars: Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ If Not Then Scrolling, and DirectAudio Chapter 4 CurrentBlock.Down() - River Pla.Net: Tiled Game Fields,
' Increase 5 points on theand score block drop Chapter 5 - River Pla.Net II: DirectInput Writingfor Text each to Screen lblScoreValue.Text +=Adventure 5 Chapter 6 - Magic KindergarteN.: Games, ADO.NET, and DirectShow . . Chapter 7 .- Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter And that's 9 -all for this chapter's sample game! Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Summary
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton In this bonus chapter, we presented a simple example that shows how to port a GDI+-based game to Apress 2003 (696 pages) PC. another platform—in this© case, a Pocket The authors of this text show how easy it can be to produce
Although this chapter doesn't go through all the possible issues you can face when porting a game, it interesting multimedia games using Managed DirectX 9.0 and withofVisual onclasses Everett,we thediscussed: latest provides at least programming a good example eachBasic of the.NET error version of Microsoft's Visual Studio.
Compilation errors due to modifications in the function or event interfaces Table of Contents errors due to missing functions and events in the target platform Compilation .NET Game Programming with DirectX 9.0
Runtime errors due to differences in the behavior of compatible functions or object initialization Foreword Preface
Program malfunctioning in which there are no visible errors, but the program doesn't work as expected due to slightly different behavior in compatible functions
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter One of 2the- most .Netterpillars: interesting Artificial detailsIntelligence about this and migration Spritesis that once we have migrated the code to Pocket
PC, we3can copy all the codeFirst back to theDirect3D desktopBasics .Nettrix project, will run without any modifications. Chapter - Managed DirectX Steps: and DirectXand vs. itGDI+ After the the code becomes 100 percent compatible between the two platforms—and, since the Chapter 4 updates, - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Pocket5PC- version was optimized, copying back will to a better .Nettrix game for the desktop, too, Chapter River Pla.Net II: DirectInput and itWriting Textlead to Screen with faster drawing routines. Chapter 6 -code Magicand KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Programming with DirectX 9.0 Appendix.NET A:Game The State of PC Gaming ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton
In this appendix we have an article by Paul Sullivan that gives a clear and critical view of the game industry Apress © 2003 (696 pages) and where it is going. This article is a must for anyone interested in creating games. The article was first authors of this text how easy it can be to produce published in 2001The at the FiringSquad siteshow (http://firingsquad.gamers.com), and is reproduced interesting multimedia games using Managed DirectX 9.0 and here with the permission of thewith author. programming Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
The Current State of PC Gaming Table of Contents
Introduction
.NET Game Programming with DirectX 9.0 Foreword
When you walk into your favorite computer or electronics store, what kind of physical setup do you see in Preface the PC gaming section? Most likely, you will see rows of largish boxes with all sorts of eye-catching colors Introduction and titles sitting there, mockingly you to throw your money at them. Chapter 1 just - .Nettrix: GDI+ and Collisionbegging Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites The promotional information on those boxes promise all kinds of ground-breaking fun that certainly
Chapter 3 -the Managed First even Steps:sport Direct3D Basics DirectX vs. GDI+ "redefines genre,"DirectX and some quotes fromand industry heavies praising the devastating Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio awesomeness that the game brings to the table. Potential buyers are bombarded by all of this promotional Chapter 5 only - River Pla.Net II: DirectInput and Writing Textmagazines to Screen and web sites as well. hype not on the boxes, but in the popular gaming Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
As you 7step back to ponder andII: start to pay even closer and attention, you Chapter - Magic KindergarteN. Animation Techniques Speech APIbegin to realize some fundamental truths. Many of the games make it Games onto the shelves are backed by huge publishing companies. Many Chapter 8 - .Netterpillars II:that Multiplayer and Directplay of these companies tons of advertising to promote their new D-iNfEcT:buy Multithreading, Nonrectangular Windows, andreleases Access toin an effort to make the public Chapter 9 them. aware of Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
In fact, the more you think about it, the more you realize that modern day game production and promotion is starting to look like the Hollywood movie industry. Promotion is less about the actual plot and the Appendix B - Motivations in Games gameplay and more about creating buzz around the product by highlighting certain features, like the Appendix C - How Do I Make Games? graphics engine or the big name development talent working on the title. Appendix A - The State of PC Gaming
Appendix D - Guidelines for Developing Successful Games
Index Remember American McGee's Alice? When the industry started hearing about it, it was all about a well-
known story, Alice in Wonderland, being twisted to fit the vision of one of the biggest names in the industry: List of Figures American List of TablesMcGee. He was one of the id luminaries behind the Doom and Quake franchises and was well regarded by fans of those series. Much of the early hype seemed to focus on just how cool Alice could look when it was made using the incredible Quake III Arena engine, which fellow Doomer John Carmack created. Imagine the minds of two Doom alumni brought together on a new engine with a new concept. Only when you started digging deeper did you find elements of the story and the gameplay. Much to his credit, American McGee fought mega publisher Electronic Arts on the idea of putting his name in the title of the game. From the press reports, it looked like he was more interested in focusing on the game itself and not on the personalities involved. He also seemed to make it clear that he wanted to use the Q3A engine not because it was hyped up in the press, but because it was powerful and flexible enough to help him realize his vision for the look of the game itself. His intentions seemed honorable and true to the gamers he hoped to serve.
.NET Game Programming with DirectX 9.0 Compromises in Development by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Ads, Reviews, Super Bowl Spots
The authors of this text show how easy it can be to produce
Unfortunately, when the big marketing engine revs up, it is sometimes very hard to bring it back down to interesting multimedia games using Managed DirectX 9.0 and idle. In the end, the game was with finally released by the programming Visual Basic and .NETviewed on Everett, thepublic. latest When you took a good crack at playing the title, you version could of see Microsoft's so much Visual potential Studio. in the game itself, but somehow it felt like it was not quite finished and lacked some of the magical visionary polish that you had anticipated. The graphics were at times stunning, but somewhat inconsistent. Some of the textures looked incredible, while others looked Table of Contents bland. Some of the levels were truly inspired, while others seemed like nothing more than a fairly complex .NET Game Programming with 9.0 than it should. Some felt that the $50 they spent was a bit much jump puzzle that seemed to DirectX end earlier Foreword for what they got. Preface
To this day, American McGee should be applauded for his drive to get this work in the hands of gamers, Introduction but some always remember it in aDetection "what could have been" type of way. Impressions were that Chapter 1 may - .Nettrix: GDI+ and Collision somewhere along the way, the bigIntelligence guns stepped and started to push the marketing angle more than the Chapter 2 - .Netterpillars: Artificial and in Sprites actual quality of the gameplay experience. Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio EA eventually pressured McGee to put his name on the title, even though he still fought the idea for the
Chapter - River Pla.NetThey II: DirectInput Writing Text toabout Screen reasons5 stated earlier. seemed toand be more worried getting the product out the door as fast as Chapter 6 -with Magic Adventure ADO.NET, DirectShow they could asKindergarteN.: much marketing buzz asGames, possible and lessand interested in releasing the title when the Chapter 7 - Magic KindergarteN. AnimationtoTechniques and Speech game would actually be finishedII: according McGee's original visionAPI and attention to detail. Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List ofFigure FiguresA-1: Alice List of Tables
Figure A-2: Scary? Maybe ... Big? Yeah.
What Does Everyone Want? Unfortunately, for developers all over the world, it seems that in today's computer gaming market you have to make some sacrifices to get your product made. Development is becoming increasing complex, and thus prohibitively expensive, and you need big backers with very deep pockets to get the product completed. In order to keep those backers happy, you may have to give up some of your creative control and scale back your vision, which means in the end, your product may not be all that you wanted it to be.
Thinking about all of this seems to evoke some basic questions: What do gamers want and expect, and .NET Game Programming with DirectX 9.0 what do publishers want and expect? The rest of this article looks at the gaming market from a variety of ISBN:1590590511 Alexandre Lobão and Ellen out there perspectives in anbyeffort to seeSantos what actually happens and perhaps find some answers to those Hatton questions. Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Consumer World by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The Consumer Side: Value and Gameplay The authors of this text show how easy it can be to produce
Gamers can be ainteresting fickle lot, but in spite of that fact, there are some fundamental truths that seem to exist. multimedia games using Managed DirectX 9.0 and Gamers like value and gamerswith like Visual good Basic gameplay. Many of them don't care how flashy a title might programming .NET on Everett, the latest be—if it costs tooversion much and of Microsoft's doesn't deliver Visual the Studio. goods, they will avoid it like the plague. Most consumers want a game that they can get into without too much hassle. They want a game that Table playsofinContents a way that they are familiar with and make sense to them. They want to be able to sit down, open .NET Game Programming withfun DirectX 9.0worrying about DirectX or OpenGL, without worrying about installing the game and start having without Foreword extra video codecs, reconfiguring their hardware or upgrading drivers. Preface
Even so, consumers realize that sometimes you cannot have everything you want. They feel that if these game developers are going to force them to jump through all of these hoops, those developers had better Chapter 1 - .Nettrix: GDI+ and Collision Detection make sure that the product ends up giving gamers one heck of a ride for the money. The problem is, Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites many finished products don't even come close. Introduction
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
When the toDirectInput 3D Goes - RiverMove Pla.Net II: and Wrong Writing Text to Screen
Chapter 5 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Let's look at a few simple examples. Remember Earthworm Jim? This simple and fun 2D scroller was - Magic KindergarteN. II: Animation Techniques and Speech API incredibly popular on the PC and spawned follow-up versions that also did well. But then, somebody on Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay the development side had this brilliant idea that they needed to respond to the exciting new trend of 3D D-iNfEcT: Windows, and Unreal, Access tothey would go crazy to have environments. I mean,Multithreading, if people wereNonrectangular going nuts over Quake and Chapter 9 Nonmanaged Code Earthworm Jim in 3D right? Wrong. Earthworm Jim 3D was an unmitigated disaster. The price was not too Bonus Chapter Porting .Nettrix to Pocket PC high so people went ahead and gave it a try, but word of mouth quickly killed any chance it had to be a Appendix A - The State of PC Gaming real hit. Gameplay was too different and too hard compared to the simple but highly effective 2D world that Appendix - Motivations in Games Jim had Bpreviously inhabited. Chapter 7
Appendix C - How Do I Make Games?
The same happened with LodeSuccessful Runner and Lemmings when they tried to go 3D. People simply Appendix D -thing Guidelines for Developing Games decided that the games were too different and too hard to get used to (at least in comparison to their Index satisfyingly List of Figuressimple predecessors), so even though they were not very expensive, they were shunned. The Lemmings List of Tablesfolks came back with a hybrid product that worked pretty well, one in which you were still in a 2D environment that looked 3D, but by then the damage had been done. What had the developers done wrong? They forgot that it is all about the gameplay. Just because a title is inexpensive does not mean it will be a hit. Well, who did it right then? The folks that made Frogger 3D and Frogger 2: Swampy's Revenge. They took advantage of the nostalgia angle to get their foot in the door and even though the first Frogger 3D was a buggy mess, people fell all over it. Why? Because it played like they expected it to play, even though it was in 3D. It was about hopping back and forth, side to side, dodging the bad guys. You had a view that was only slightly modified from a strict top-down look, and that meant people could control it pretty easily. For Joe Schmoe, Swampy's Revenge added some very cool visual effects and incredible colors and 3D shapes, but preserved the gameplay that made it a video game classic.
.NET Game Programming with DirectX 9.0 High- and Low-End Consumers by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Battle of the Titans
The authors of this text show how easy it can be to produce
Why did Unreal Tournament outduel Quake 3 Arena in sales and customer satisfaction? Many speculate interesting multimedia games using Managed DirectX 9.0 and that the reason was because the focus in Basic Q3A .NET was more on thethe graphics programming with Visual on Everett, latest and the engine than the actual gameplay. Even though version Unreal of Microsoft's Tournament Visual Studio. had an older, arguably less-capable engine, flat textures and odd colored lighting, it gave you more bang for your buck in terms of gameplay. Capture the Flag, Domination, Assault—it was just more fun to play for many people. It had more gameplay modes and Table of Contents weapons that were more balanced and better thought out. .NET Game Programming with DirectX 9.0
Foreword Yes, Quake 3 Arena had incredible model and animation, introduced shaders and texture modifiers, and
insanely high-polygon curved surfaces, but for many, it was just plain old Deathmatch. If it had not been Preface for the massive hype and extreme devotion of the hardcore audience of Quake fans, it would not have sold Introduction nearly as as it did. id software had Detection built a lot of goodwill with their earlier efforts and people expected Chapter 1 well - .Nettrix: GDI+ and Collision that anything they produced wouldIntelligence be among and the Sprites best. Unreal Tournament on the other hand had the Chapter 2 - .Netterpillars: Artificial legacy 3of a- buggy first release butSteps: unanimously forDirectX it with avs.focus Chapter Managed DirectX First Direct3Dmade Basicsup and GDI+on different gameplay, did quite well because of it. Eventually, word of mouth is what made UT outsell Q3A, and that is a lesson that - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio developers should pay attention to.
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index
Figure A-3: Q3A had the graphics ...
List of Figures List of Tables
Figure A-4: UT had the gameplay modes
And Then the Flipside ... Another question developers should ask themselves is, "Why do consumers buy these inexpensive retreads like Deer Hunter and Who Wants To Be A Millionaire?" They don't have fancy cutting edge graphics and killer sound engines, but people are snapping them up like crazy. The answers are pretty simple. First, they are almost always less than $30, which seems to be the magic number for consumers. They feel a whole lot better about dishing out $29 than $39–$49. It seems to be a psychological barrier. Even
though many consumers can afford more than $20 or $30, they are out of their comfort zone past that Game Programming with DirectX 9.0 point. It is harder .NET for them to justify mentally. Why do people drive 50 extra miles to save 10 cents a gallon ISBN:1590590511 by Alexandre Santos Lobão and Ellen on gas?
Hatton Apress © 2003of (696 pages)old fashioned" fun. They are easy to play and easy to enjoy, and that Second, they offer up heaps "good The authors of are this supposed text show how it can be to produce is really what computer games to beeasy about. Entertainment is the focus on these titles, and multimedia games using Managed DirectX 9.0 and that is one of the interesting reasons they sell so well. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Above all, these titles are marketed perfectly to their demographic. Deer Hunter is sold at every Walmart, and while computers may be popping up in more homes than ever, most of them could not be considered stateofofContents the art. A fully 3D, realistic Deer Hunter would not have sold nearly as well due to the system Table requirements alone, andwith as popular as the show is, nobody wants a 3D Regis with full surround sound. .NET Game Programming DirectX 9.0 Foreword
The bottom line is that so many gamers out there like to buy things they can play in a fun, predictable manner. They seldom have the time or energy to invest in a new gaming paradigm. Why do you think that Introduction classics like Space Invaders and Asteroids still sell well? They don't want to shell out $50 for a pretty Chapter 1 -is.Nettrix: andnot Collision game that hard to GDI+ play and muchDetection fun to boot. Preface
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 Planet Industry by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The Industry Side: Originality vs. Practicality The authors of this text show how easy it can be to produce
The industry sideinteresting is a hard one to figure out. Small gaming companies seem to be the closest to the actual multimedia games using Managed DirectX 9.0 and PC gaming community, but have a Visual hard time their products to market. Why? It takes some serious programming with Basicgetting .NET on Everett, the latest dollars to obtain shelf version space of Microsoft's in the computer Visual Studio. super stores. It takes even more money to buy advertising to get your product noticed. It is like the small mom and pop store going up against Walmart. Chances are that unless you have a top-notch product and some seriously good word of mouth, consumers are going Table of Contents to go for the cheaper or better-advertised products every time. Why? See the part about being fickle in the .NET Game Programming with DirectX 9.0 earlier section. Foreword
So what is the industry supposed to do? They are faced with two primary options: Push the envelope and Preface bring out new games based on new technology and ideas or play it safe and take the practical approach Introduction by releasing games based on established franchises and technologies. Either way they go, it seems that Chapter 1 - .Nettrix: GDI+ and Collision Detection they get Chapter 2 criticized. - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
If you take a look at the games on the shelves, you will see a lot of sequels. Quake 3 Arena, Sim City - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio 3000, Caesar III, Chessmaster 8000 and many, many more. Some of these introduce new technology, like Chapter 5 - River Pla.Net II: DirectInput and Writing Text to into Screen Q3A, but most focus on expanding an existing hit concept another iteration. Chessmaster 8000 Chapter Magic KindergarteN.: Adventure ADO.NET,AI and DirectShow focused6 on- smoother graphics, more chessGames, sets, improved (artificial intelligence) and internet gaming. Chapter 7 3000 - Magic KindergarteN. II: Animation Techniques Speech API up the user interface. This Sim City increased resolution, added more featuresand and tightened Chapter 8 approach - .Netterpillars Multiplayer Games and Directplay practical is veryII:sound in terms the business—if it ain't broke, don't fix it. Chapter 4
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Take It Slow and Steady
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
Some games already have an established history and identity, so you can build upon that and save the
Appendix B - Motivations extra money of creatingina Games totally new brand. If you stick close to the same formula, you have a better Appendix C How Make Games? chance that you Do will Inot alienate fans of the earlier releases. You can spend your time and resources
Appendix D - the Guidelines for that Developing addressing concerns playersSuccessful expressedGames with the previous games to bring them more of what they Index already love. You can ride this franchise to help build the bottom line, and at the same time please the List of Figures gamers you worked so hard to cultivate in the first place. You not only release sequels, but expansion List packs of Tables as well, to help wring even more out of the same audience. As long as the gamers are happy and
the stockholders are happy, nobody's getting hurt, right? But sometimes you have the chance to push the envelope and possibly come up with the next big thing. Franchises don't last forever, and new ideas are crucial to keeping the bottom line strong. This is a much riskier strategy, however, because it is hard to tell what gamers are willing to do when it comes to making a purchase. Take a look at a few recent titles for instance. Clive Barker's Undying was by all accounts an incredibly good game. It used the Unreal engine very well, had a great story, impressive sound and visuals. It had a big name smack on the box and a fair amount of promotion. How could it possibly go wrong? Feedback seems to indicate that the game was just too hard to play for some, and for others who were weaned on Quake, it was too slow and involved. You have a company pushing hard to make a quality game, and they are rebuffed by their own customers.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents
Figure A-5: Undying had graphics ...
.NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Figure refreshing gameplay Chapter 6 - A-6: MagicAnd KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 ReTread Lightly by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Take 2, 3, 4 ...
The authors of this text show how easy it can be to produce
Not every game can be a home run, but what happened here is that the developers took their eye off the interesting multimedia games using Managed DirectX 9.0 and ball. Pretty cut-scenes and a creepy atmosphere areonnot enough satisfy this MTV generation. They are programming with Visual Basic .NET Everett, thetolatest used to 3D shooters version withoffast Microsoft's and furious Visual gameplay Studio. and simple objectives. Maybe it is not fair that this game was pigeonholed into the 3D shooter genre, but consumers do not always have the energy to bother discerning between shades of gray. A 3D shooter is supposed to play like a 3D shooter. Who wants to Table of Contents have to reload a pistol every 6 shots and actually think about using the tools at hand to get the results you .NET Game Programming withRPG's DirectX(role 9.0 playing games) are for, right? want? After all, that is what Foreword
Diablo caught the industry by storm. So did Myst. Both sold well and continue to do so. Why bother taking Preface chances when you can just go with the flow. When other games were focused on interactive 3D worlds Introduction and very resolutions, these gamesDetection stuck to the basics and made tons of money while keeping fans Chapter 1 high - .Nettrix: GDI+ and Collision happy. 2Diablo was easy toArtificial play, did not require a ton of complex inventory controls and had simple Chapter - .Netterpillars: Intelligence and Sprites objectives. had DirectX great looking 2D pictures, a Basics very simple interface Chapter 3 - Myst Managed First Steps: Direct3D and DirectX vs. and GDI+fun puzzles. Neither had a
particularly- deep and meaningful story, but that was really not needed. What mattered is that once people River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio got into the game, they had fun playing it.
Chapter 4 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Who Did It Well? - Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 7 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Diablo had a hugely successful add-on pack that convinced the industry to keep doing more of the same. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - for years on Diablo 2 and when it came out it was a HUGE smash. Did it have an incredible They worked Nonmanaged Code new high-resolution engine? No. Did Bonus Chapter Porting3D .Nettrix to Pocket PC it have groundbreaking new levels? No. What did it have? More of the same—and that is all gamers really wanted. Sure, they made adjustments, but on balance, Diablo 2 is Appendix A - The State of PC Gaming a lot like the original. Online play is improved and the world may be a bit more complex, but not that much. Appendix B - Motivations in Games Certainly not enough to alienate players. Blizzard asked gamers what they wanted, and they listened to Appendix C - How Do I Make Games? the answers. It worked out great for everyone. The Myst franchise did the same thing. Riven was a smash, Appendix D - Guidelines for Developing Successful Games and the new Myst III is selling like crazy. Some formulas just work. Index
List of Figures Perhaps the single largest example of this "retread" idea is the Tomb Raider series. Critics decry it as List unoriginal, of Tablesbut gamers keep on forking out the cash for the new releases because they liked what the first
one had to offer. It is so popular it has even become a major motion picture. The old adage "Keep it Simple Stupid" sure seems to apply here. Eidos kept cranking out tweaked versions until the franchise ran out of steam, and made millions in the process. Well, that's great for Eidos, but not quite so for the early adopters who are looking for the "next big thing." Take the case of the famous and talented John Carmack, engine developer at id software. He is one of the best advocates for pushing technology forward that the industry has ever seen. But he has gotten a great deal of criticism for focusing more on the technology than on the gameplay. Most people agree that Quake 3 Arena is a technological marvel, but many critics point out that the game itself is uninspired and unoriginal. His work on Doom 3 will likely be some of the best code ever written for a gaming engine. But already people are starting to decry the system requirements. If they are not able to run at 100 frames per second in their hardcore shooter, they just are not happy at all. From the industry side, it sure looks that you are damned if you do and damned if you don't. So how are you supposed to know what the smart move is? That is where good old facts and data come into play.
.NET GameTrends Programming with DirectX 9.0 Analyzing Market by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The Technical Side: Facts, Data, and Commentary The authors of this text show how easy it can be to produce
This is an opinioninteresting piece, butmultimedia it is also based on good old facts and data. The web was scoured to find as games using Managed DirectX 9.0 and much raw data asprogramming was neededwith to back it up. Data companies charged between $4500 and $7000 for Visual Basic .NET on Everett,have the latest single data reports version in theofpast, Microsoft's and as Visual a result, Studio. custom reports have not been readily available. The selected sampling of data gave a good idea of what PC gamers have purchased in the past. The data Table offrom Contents came the largest gatherer around: NPD Intellect (formerly PC Data). The hard work they have done .NET Game Programming 9.0 has been invaluable to many sites and print publications. to provide gaming sites with with DirectX sales data Foreword
To start things out we looked at the data from 1998. Instead of capturing a one week sales period, the Preface decision was made to use an entire year to create a firm foundation to build upon.
Introduction
Chapter - .Nettrix: PC GDI+ and Collision The 101best-selling games of 1998 Detection (full year) were: Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites
1. Starcraft
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio 2. Deer Hunter Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
3. Deer Hunter 2 Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
4. Myst
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to 5. Big Chapter 9 -Game Hunter Nonmanaged Code Bonus 6. Chapter Titanic:Porting Adventure .Nettrix OuttoofPocket Time PC Appendix A - The State of PC Gaming
7. Lego Island
Appendix B - Motivations in Games Appendix C - How Do I Make Games? 8. Frogger Appendix D - Guidelines for Developing Successful Games Index9. Riven: The Sequel to Myst List of Figures
10. Unreal
List of Tables
Starcraft was an RTS made by the same company as the incredibly popular Warcraft II (and was also berated at the time for not moving to 3D graphics). Deer Hunter and Deer Hunter 2 were both low cost, simple games that were fun to play. Myst was a 2D puzzle game with great graphics that the whole family could play. Big Game Hunter was along the lines of the Deer Hunter franchise and was also in the lowcost arena. Titanic was here due to the hype of the movie more than anything else. Lego Island was a popular low-cost family game, as was the Frogger remake. Riven was the well-received sequel to Myst and Unreal was a more colorful version of the ubiquitous first person shooter that focused more on single player than anything else. Unreal was buggy, but people liked it because it pushed things along in the single player arena when most other 3D games were leaning heavily towards multiplayer deathmatch. With a full year of data as a base, looking at weekly sales data seemed the logical choice. This weekly look focused attention on trends or promotions and also showed which titles had a long lasting life to them. Star Wars Episode 1 was released in movie theaters during this time, for instance. The 10 best-selling PC games for the week of May 16-22, 1999: 1. Star Wars Episode 1 2. Star Wars Episode 1 Racer 3. Baldur's Gate: Tales of Sword Coast 4. Total Annihilation 5. 6.
3. 4. 5. Big Game Hunter 2
.NET Game Programming with DirectX 9.0
by Alexandre Santos Lobão and Ellen 6. Sim City 3000
ISBN:1590590511
Hatton 7. Baldur's Gate Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce
8. Civilization: Call To Power interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
9. Roller Coaster Tycoon version of Microsoft's Visual Studio. 10. Half Life Table of Contents
As the data showed, trends starting .NET Game Programming with were DirectX 9.0 to become readily apparent. As with Titanic, the games with movie tie-ins did well. Baldur's Gate and its expansion pack were hot, as were the sequels Big Game Foreword
Hunter 2 and Sim City 3000. Known quantities sold well, but the last spot showed a new entry, Valve's Half Life, which took some serious chances by adding a story and some atmosphere to the first person shooter Introduction genre. Roller Coaster Tycoon was another sim-style game that was familiar to gamers and did not push Chapter 1 - .Nettrix: GDI+ and Collision Detection beyond their comfort level. Preface
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 The Data Explained by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Has Anything Changed?
The authors of this text show how easy it can be to produce
We moved aheadinteresting to the new millennium to see what changed. Another trend showed itself here, with the multimedia games using Managed DirectX 9.0 and explosive popularity of the Regis Philbin WhoonWants To the Be latest A Millionaire. This ABC show captured programming with Visualvehicle Basic .NET Everett, the minds of viewers, version butofjust Microsoft's how wellVisual will did Studio. it hold up? The 10 best-selling PC games for the week of May 14–20, 2000: Table of Contents
1. Who Wants To Be A Millionaire: 2nd Edition
.NET Game Programming with DirectX 9.0 Foreword 2. The Sims Preface
3. Roller Coaster Tycoon Introduction Chapter 1
.Nettrix: GDI+ and Collision Detection 4. Age- of Empires II: Age of Kings
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 5. Who 3 - Managed Wants ToDirectX Be A Millionaire First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
6. EverQuest: Ruins of Kunark - River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 5
Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow 7. Starcraft Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API 8. Roller Coaster Tycoon: Corkscrew Follies Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 9. SimCity 3000 Unlimited Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
10. Sim Mania Pack
Appendix A - The State of PC Gaming Appendix B -was Motivations in the Games Millionaire a tie-in to very hot TV show and a game concept that people were familiar with. SimCity Appendix C How Do I Make Games? 3000 Unlimited was a spruced up refresh of the SimCity 3000 game, which was in itself a sequel to Appendix SimCity D and - Guidelines SimCity 2000. for Developing Roller Coaster Successful Tycoon Games was back, as was its add-on pack, which was repeated
with the Sims franchise. Familiar names and concepts were clearly obvious. Index List of Figures
Our last weekly grab was from last month. Some titles faded, others remained. It was hard to piece it all together at times, but luckily we had even more data from the same source.
List of Tables
The 10 best-selling PC games for the week of July 15–21, 2001: 1. Diablo II: Lord of Destruction 2. Flight Simulator 2000 3. The Sims 4. The Sims: House Party 5. Diablo II 6. Roller Coaster Tycoon 7. The Sims: Livin' Large 8. Mech Commander 2 9. Age of Empires II: Age of Kings 10. Tribes 2 As you can see, the Sims franchise was going very strong, as was Diablo II and the expansion pack. Sequels were the norm here, that was for sure. Even though Roller Coaster Tycoon was not really a
10.
sequel, it was a sim genre game, and again, one that people were comfortable with. .NET Game Programming with DirectX 9.0
ISBN:1590590511 Alexandre Santos Lobão andaEllen To give you somebyoverall perspective, we took look at the best-selling PC games in history, all of those years included. Hatton
Apress © 2003 (696 pages)
The 10 best-selling games alltext timeshow were: ThePC authors of of this how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and 1. Myst programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
2. Roller Coaster Tycoon 3. The Sims
Table of Contents
.NET4. Game Programming Flight Simulator with DirectX 9.0 Foreword
5. Who Wants To Be A Millionaire Preface Introduction
6. Riven: The Sequel to Myst
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 - of .Netterpillars: Artificial Intelligence and Sprites 7. Age Empires II: Age of Kings Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ 8. Monopoly Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
9. Lego Island
Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API 10. Diablo Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay
Franchises absolutely dominated theNonrectangular charts. Monopoly sold very another game that people were D-iNfEcT: Multithreading, Windows, and well, Access to familiar with.Nonmanaged Lego IslandCode was a similar happening, and both were low-cost family titles. The list was somewhat surprising in that ittomixed genres and old school verses new school ideas, but nobody could Bonus Chapter Porting .Nettrix Pocket PC doubt the titles. Appendix A effectiveness - The State of of PCthese Gaming Chapter 9
Appendix B - Motivations in Games
From the data collected, there were some obvious patterns. Even though a few A+ titles made it into the mix, consistently it was the basics that most consumers were willing to pay for. Value was important, which Appendix D - Guidelines for Developing Successful Games was obvious by the inclusion of lower cost, lower technology titles. But if the data was extrapolated a bit Index more, it could be seen that familiarity was very important to consumers. Groundbreaking games like List of Figures System Shock and Thief were not among the best sellers, while unsophisticated but well-understood titles List of Tables like Monopoly and Lego Island were. Riven was little more than a retread, but it was still the sixth bestselling game of all time. Who Wants To Be A Millionaire was a surprising entry—a trend with legs. Appendix C - How Do I Make Games?
With the exception of the tie-ins to movies and TV, most of the games people purchased were the ones that they knew and were comfortable with. Monopoly was fun to play and a game that consumers grew up with. Diablo was certainly not the most hardcore RPG around, but again, it was fun and easy to play. "God" type games were a big hit as well. People have historically liked to build and tinker with worlds of their own, and as the Reality TV trend has shown, many consumers have been long-term voyeurs at heart. Based upon all of this research, if you had represented a big gaming company and needed to show a profit, what kind of games would you have produced?
Game Programming with DirectX 9.0 Conclusion.NET and Suggestions by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Final Thoughts from an Avid Gamer The authors of this text show how easy it can be to produce
If you're a gamer,interesting you need multimedia to vote withgames your wallet and express your opinions. Buy the good games and using Managed DirectX 9.0 and write letters (yes,programming actual letters)with to developers them exactly Visual Basictelling .NET on Everett, thewhat latestyou liked, and what you want. Let them know that you version wantofmore Microsoft's than just Visual another Studio. number tacked onto the end of the title, or more colors and textures pasted over the same game. In short, take the time to get involved. On the flip side, if you are a developer, you need to listen to your customers. Encourage them to contact you and share their ideas. Table of Contents Ask for their feedback and suggestions. After all, these are the people who are going to be spending their .NET Game Programming 9.0 hard-earned dollars on with your DirectX product. As with any relationship, if you want it to work you have to put some Foreword serious effort into communicating with each other. Preface
Remember back in the day when shareware was such a hot concept? Four or five guys would work on a Introduction game, 1and- during development they would release playable snippets that could be downloaded from Chapter .Nettrix: GDI+ and Collision Detection bulletin2boards and playedArtificial for freeIntelligence by the masses. These unwashed, caffeine-hopped college students Chapter - .Netterpillars: and Sprites would play lowDirectX resolution forDirect3D hours and giveand theDirectX programmers Chapter 3 - these Managed Firsttidbits Steps: Basics vs. GDI+some feedback on what they
liked and what they didn't. The developers would take these comments, make some changes and release - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio more snippets. The cycle would continue until they could release Episode 1 of the mighty adventure as Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen shareware. If you liked what you saw, you ordered and paid for Episodes 2 and 3. It was a total win-win Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow situation for everyone involved. It was a collaborative effort that helped make huge companies out of id Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API and Epic and many others. Chapter 4
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to As it stands Chapter 9 - now, big companies spend years developing a game and only after it is done do they bother Nonmanaged releasing the demo. HowCode are you supposed to get and incorporate useful feedback from your audience if Bonus Chapter Porting .Nettrix Pocket PC you don't include them in thetoprocess? Why wait until after the game is finished and the demo is out? If it Appendix - The State PC all Gaming turns outAthe game is of bad, that money may have been wasted. If you had bothered to communicate Appendix - Motivations in Games you could have made changes and tweaks during development so that with yourB audience beforehand, Appendix the game C ended - How Do up Ibeing Make the Games? type of release that gamers are willing to spend their money on. By waiting until the game is finished, you are stuck with theGames end result, unable to take a step back and rework it. Appendix D - Guidelines for Developing Successful Index
On the other hand, responsibility lies with gamers too. You want good games? Let the developers know what you like and by all means, pay for the games that deserve to be paid for. Don't keep pirating titles List of Tables and hope that these developers will be able to stay in business. It is not fair to anybody. Don't let apathy take over either. If you are passionate about your games, put your money where your mouth is and start kicking out the cash. Lick some stamps and mail some letters to the developers and tell them why you felt that game was worth the money. Conversely, if you are let down, let them know why and give your suggestions on how you would have done things differently. List of Figures
If developers and gamers work together as a team and keep the lines of communication open, we are all sure to end up winners in the long run.
Programming with DirectX 9.0 Appendix.NET B:Game Motivations in Games ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton
This appendix features an article by Sarbasst Hassanpour, UI/game designer at MindArk (developer of the Apress © 2003 (696 pages) upcoming Project-Entropia), discussing one of the most important things to know when developing a The authors of this text show how easy it can be to produce game: how to keep a player interested in your game. The article was first published in 2001, at the interesting multimedia games using Managed DirectX 9.0 and GameDev.Net Web site (http://www.gamedev.net), and isthe reproduced here with the permission of programming with Visual Basic .NET on Everett, latest the author. version of Microsoft's Visual Studio.
Motivations in Games
Table of Contents
.NET Game Programming with DirectX 9.0
Hi everyone. I'll try to bring forward some of the elements that bind people to a game for hours and days. These elements can be used to create a game or application that motivates the user to use/play it. Think Preface of it, an educational game that the kids at school will enjoy and learn from, or of course a game of games! Foreword
Introduction
Now this the almighty recipe for creating the captivating game of the year, but some of these Chapter 1 is- not .Nettrix: GDI+ and Collision Detection elements often overlooked. And that's a shame. Chapter 2 are - .Netterpillars: Artificial Intelligence and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
The elements are:
Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen Reward Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Competition comparison others Techniques and Speech API Chapter 7 - Magicand KindergarteN. II:with Animation Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
Anticipation
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Participant-ship
Bonus Chapter Porting .Nettrix to Pocket PC Appendix Tempo A - The State of PC Gaming Appendix B - Motivations in Games
The Grand Ending
Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
Reward
Index
List of Figures
There are many different levels of rewarding, and they are related to one another. If you achieve the right balance of rewarding, depending on your game goal and type, you will succeed in capturing the player. Now that, my friend, is a bold statement.
List of Tables
Let's look at this as some rules within a specific time span, say between two character levels, or between the first upgrade and the second. First the different aspects, and then some more comments on each. The player needs to be rewarded often and in small portions. The player needs to be rewarded with a greater reward that is expected and the time of the reward is known. The player needs to be rewarded with a greater reward that is expected but the time of the reward is unknown.
Smaller and Often If the smaller rewards are useful in some way they will not become routine and needless. If you give the player a healing, it is useful to the powerful and novice. But if you reward with a great flashy effect, it will lose its strength along the way. You are quite safe if you make the small rewards lead to a greater reward, e.g., money, experience for leveling, points for extra life, and so on.
Greater and Known Occurrence
This is something the player will anticipate and strive to achieve. She can see the goal as she progresses .NET Game Programming with DirectX 9.0 towards it. There could be many known goals. There is nothing wrong with giving away a lot of goals to ISBN:1590590511 by Alexandre Santos Lobão and Ellen give the player the thrill of imagining what to do and how to get to them, as well as dreaming of different Hatton combinations andApress so on.© But remember, once you give away a greater reward the smaller rewards will 2003 (696 pages) mean a little less. The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
Example: The leveling of a character or skill tree and descriptions of skills and their cost. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Example: The different items the player could buy if he had the cash.
Greater and Unknown Table of Contents
Occurrence
.NET Game Programming with DirectX 9.0
When the player has a chance of getting a greater reward and it could come anytime, the anticipation is always there, and in the times of gloom there is always a hope of getting some reward. This hope can Preface save the day many a time. Remember though, the player needs to know about the rewards and expect Introduction them, but their trigger could be anytime within the rules. Foreword
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 Every - .Netterpillars: ArtificialaIntelligence and could Spritesget an "ancient artifact." Example: time you defeat spaceship you Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Example: could a "crystal sword," but chances are very low. Chapter 4 Every - Rivertrader Pla.Net: Tiledhave Game Fields, Scrolling, andthe DirectAudio Chapter 5
Pla.Net II: DirectInput and Writing Text to Screen Example: If- River you kill an orc, you might find a "steel claw" if you are lucky.
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API The Relations Between the Rewards Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Ah, the mostD-iNfEcT: interesting part! One should first focusWindows, on the goal typeto of the game. Is it to be replayed Multithreading, Nonrectangular andand Access Chapter 9 a lot of timesNonmanaged or more likeCode "play it, have an experience, and then put it on the shelf"? Should the same Bonus gameChapter (not replaying Porting it) .Nettrix be able to Pocket to be played PC a long time? Appendix A - The State of PC Gaming
If the player becomes too powerful due to the rewards, the game will have a climax, and then the game cannot beat what it has previously given the player. Thus the game will have reached its designed content Appendix C - How Do I Make Games? limit. Designed content limit is not the same as the game limit. The player could play a lot of quests and Appendix D - Guidelines for Developing Successful Games content in general, but it's more like a walk in the park, and the next "level" of rewarding is not as Index important, or even unreasonably far away. Appendix B - Motivations in Games
List of Figures
List of Tables A very potent and time-cheap design method is to give the player a difficulty option or adapt the game by
changing some colors and increasing the difficulty. Never ever "steal" a greater reward given to the player, not even to make the game more exciting and/or harder. The frustration is exceptionally high, and the relationship (trust) between the player and the game will be crippled. If you decide to "steal" a greater reward, be sure to explain why the game did it. Example: Never take a level from a character as a punishment or special event. If you do, tell the player why. Always reward smart playing and creativity by the player. Sometimes the reward is automatic since it was probably the right way to play the game. As you all know, the right way to play a game doesn't necessarily mean the way the designer intended the game to be played. The majority of players are like water: They always find the natural way of flowing down the mountain. But what I'm talking about here is some designed content. Example: If the player clicks on the well in the middle of the village, he doesn't have to purchase new water skins.
Competition and Comparison If the player can be acknowledged by others, he will be motivated to continue and strive to perfection. This acknowledgement could be in the game or outside. Of course this is not applicable to everyone but to surprisingly many of us.
Remember the example of rewarding with a flashy effect? .NET Game Programming with DirectX 9.0 Well, if the other players see the effect, and the player knows others can see it, it will have its strength every time the player is rewarded by it (that ISBN:1590590511 by Alexandre Santos Lobão and Ellen is, if others see it at that given time). Hatton Apress © 2003 (696 pages)
If the player feels (is reminded) that she is getting better at the game, the motivation factor is The authors of this text show how easy it can be to produce increased also. interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Anticipation
Small, frequent hints about what is to come build anticipation and provide a very good way of building motivation. The important thing about anticipation is the trust between the player and the game. The player .NET Game Programming with DirectX 9.0 needs to be rewarded a few times to come to trust the game. Then a positive spiral is created and the Foreword player and the game will steadily climb to a memorable experience. Alas, beware, once the player is Preface betrayed by the game, the relation has to be created all over again.
Table of Contents
Introduction
Chapter 1 - .Nettrix: GDI+ andpreviously Collision Detection An example: The player has helped a village and the reward was a unique item and a nice story Chapter revelation. 2 -Before .Netterpillars: that he Artificial helped aIntelligence little kid find and hisSprites lost dog, and the reward was a very funny story and
some very candy. Now First the player the Basics game.and DirectX vs. GDI+ Chapter 3 -tasty Managed DirectX Steps:trusts Direct3D Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
If you give him a hint of some event, or a quest or whatever, the player will anticipate the ending and strive - River Pla.Net II: DirectInput and Writing Text to Screen to achieve it. Also some hints here and there of the grand content of the game will lead to an ever present, Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow underlying anticipation. Chapter 5 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8 - .Netterpillars II: Multiplayer Games Directplay The hardest part is to reuse the material used and for the anticipation. Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Never, ever Nonmanaged send a playerCode on a quest/task without designing the harvest of her labors.
Bonus Chapter Porting .Nettrix to Pocket PC
Participant-ship
Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix If the player C - How feelsDo that I Make he isGames? a part of the world and that he is affecting the course of events, the motivation
to continue greatly increased. HereSuccessful we give the imagination of the player a chance to be one with the Appendix D - is Guidelines for Developing Games game world. The UI (user interface) is one of the important parts of this. If the UI is out of line, it will Index interfere with the "becoming one with the game" part. List of Figures List of Tables
A good example is when you are watching a movie and you are enthralled by it, and a friend asks you something. Now it will take you some time to get into the movie again. Think of a UI that shatters the flow of the game on every turn. In addition, the player should not be hindered from using his abilities. For instance, if the player is very good at a fast 3D shooter with a really high speed, he will find himself limited when playing another 3D shooter which is slow. The problem in this example is hard to get around. Often the target group is chosen and the issue is solved. Still there are some given standards, and one should think twice before aiming lower than these standards, especially with a sequel.
Tempo The music, the environmental feel, and the action or tranquility of the game is the tempo. The important part is to change between fast/exciting and slow/relaxing. Otherwise each will lose its strength. The contrast is actually vital to uphold each extreme's meaning. Even by itself the tempo can be very powerful in capturing the player for hours. There is a lot to be learned from the movies industry. Did you know the best way to describe silence is to have a distant and small sound that reminds one of the silence? This could be something like a crow, a creaking door, and so on. If you put the player in a very intense environment where she has to put her senses and skill to the test, you will need to give her some time in a calm and tranquil environment afterward so that she can rest.
Also, the contrast will make her feel the intense environment fully (once it starts again). .NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
The Grand Hatton Ending
ISBN:1590590511
Apress © 2003 (696 pages)
If the ending is very good the player will have a solid anticipation when she is playing your next game. Not The authors of this text show how easy it can be to produce only that, the ending is one of the thingsgames people tendManaged to remember interesting multimedia using DirectXlong 9.0 after and they have played the game. This is the final reward programming and thewith meaning Visual of Basic the .NET game. onThis Everett, is where the latest the meaning of the hours played will version of Microsoft's Visual Studio. be revealed. The ending is a very important part and actually often overlooked. One good method is to design the
Table of Contents ending early in the development. .NET Game Programming with DirectX 9.0 Foreword
Complex UI
Preface
Introduction If the players are motivated enough, you could have the most complex UI ever created. Now, I'm not Chapter GDI+ and Collision Detection saying 1that- a.Nettrix: complex UI design is the best way to go, but often a more simple design is used when a more Chapter 2 one - .Netterpillars: Artificial Intelligence and Sprites complex would be better. Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ A UI that by the player hinder and his abilities to interact with the game. This means Chapter 4 is- mastered River Pla.Net: Tiled Gameshould Fields,not Scrolling, DirectAudio
some slow to achieve something will have to adapt to the skill of the player, providing a faster Chapter 5 - method River Pla.Net II: DirectInput and Writing Text to Screen method6 later on. InKindergarteN.: the end the UI is almostGames, "invisible." Chapter - Magic Adventure ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API An example: To choose a weapon the novice player will probably use a menu and see the actual weapons
Chapter - .Netterpillars II: Multiplayer andto Directplay and so 8forth. But the expert will use theGames keyboard do the same action. The keyboard is the final level of D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to UI to achieve Chapter 9 - this purchasing of weapons. Nonmanaged Code
Bonus Chapter .Nettrix to navigation Pocket PC system might require five frustrating hours to master, but in the Another one: Porting A very advanced Appendix - The State PC Gaming end the A gameplay willofbenefit from the rich environmental feeling, especially if navigation is a major part of Appendix the game B (such - Motivations as in space in Games games). Appendix C - How Do I Make Games?
The optimal approach is to provide the player a set of interfaces for different levels of mastery. The hard part is to make these sets work together and resemble each other, since the player might master one Index aspect of the interface (e.g., navigation) and not the rest. This sounds harder than it really is. All you have List of Figures to do is to provide an alternative, faster way, even if it demands more from the player. Appendix D - Guidelines for Developing Successful Games
List of Tables
That's my silver coin. Good Luck Champions! -Sarbasst Hassanpour
Programming with DirectX 9.0 Appendix.NET C:Game How Do I Make Games? ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton
In this appendix we have an article written by Geoff Howland that goes through the logical steps to Apress © 2003 (696 pages) becoming a better game programmer and other issues. The article was first published on 2001, on the The(http://www.lupinegames.com), authors of this text show how easy it can produce Lupine Games site andbeistoreproduced here with the permission of interesting multimedia games using Managed DirectX 9.0 and the author. programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
How Do I Make Games?—A Path to Game Development Table of Contents
When I talk to people looking to get into game development some of the first things I often hear fall along the lines of, "How do I make games?" or "I want to make a game like Quake/Everquest/Starcraft and ..." Foreword The first is just way out of the realm of answerability, as there are too many aspects to possibly go into, Preface and each of those components can be infinitely complex. .NET Game Programming with DirectX 9.0
Introduction
The second, however, fallsand intoCollision just being unrealistic in expectations. Starcraft, Everquest and Quake were Chapter 1 - .Nettrix: GDI+ Detection all made teams of professionals who had budgets usually million dollar plus. More importantly though, Chapter 2 by - .Netterpillars: Artificial Intelligence and Sprites all of these were made bySteps: peopleDirect3D with a lot of experience atvs. making Chapter 3 - games Managed DirectX First Basics and DirectX GDI+games. They did not just decide 4to make and turned out mega-hit games, started out small and worked their way up. Chapter - Rivergames Pla.Net: Tiled Game Fields, Scrolling, and they DirectAudio This is 5the-point anyone who is interested in getting into game development needs to understand and Chapter Riverthat Pla.Net II: DirectInput and Writing Text to Screen repeat, repeat, repeat until it becomes such a part of your mindset that you couldn't possibly understand - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow life without this self evident, universal truth.
Chapter 6 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures
Figure C-1: A screen shot from Quake 3— Arena
List of Tables
Until you understand that all skills in game development are learned by experience, (meaning to start very small and working your way up) you will be absolutely doomed to never finish your projects. Even the infinitesimal number of teams that do manage to finish a non-trivial project before they have made any smaller ones have to learn incrementally, it just takes them many times longer than if they had started out with smaller projects.
So Where Do I Start? Tetris. Tetris is the perfect game to begin your journey on the path to becoming an able bodied game developer. Why? Because Tetris contains the all the elements found in every game, and can be done with just about the least amount of work. Also, you don't have to be an artist to make a good looking Tetris game. Anyone who can draw a block, which is everyone with a paint program, can make a commercial quality version of Tetris.
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Figure- C-2: A tetris clone—Amazing Blocks .Netterpillars: Artificial Intelligence and Sprites
Chapter 2 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ This is another one of the big benefits of starting with Tetris. Not only can you make a fully functioning
Chapter 4 -isRiver Pla.Net: Tiled Game Fields,basically Scrolling,just andas DirectAudio game that fun and addictive, but it looks good as any commercial version done of it. Chapter 5 River Pla.Net II: DirectInput and Writing Text to Screen Blocks are blocks no matter who draws them, and tetraminos (the shapes used in Tetris) are all just a Chapter 6 of - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow collection four blocks. Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API
Tetris has the individual that ALL share in common. It has a game loop (the Chapter 8 -all .Netterpillars II:components Multiplayer Games andgames Directplay process of repeating and over until the game isWindows, quit). Theand game loop D-iNfEcT: over Multithreading, Nonrectangular Access toreads in input, processes the input, updates the elements of the game (the falling tetraminos), and checks for victory/loss conditions. Nonmanaged Code
Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC
Every single game you will ever make does all of these things, so learning the process and actually implementing it is extremely important. After you have completed this the first time, it will give you an Appendix B - Motivations in Games insight into how hard it will be and how long it may take on future games. Without having done this all the Appendix C - How Do I Make Games? way, at least once, you will never fully have a proper grasp of each of the elements. When you have larger Appendix D - Guidelines for Developing Successful Games projects, there will be more unknowns that you can't judge for in complexity and time. If you don't even Index fully understand the entire process because you have failed to DO it, you will likely be helpless to create List of Figures schedules or estimate times properly and will most likely not succeed at the endeavor. Appendix A - The State of PC Gaming
List of Tables
Something I need to mention is that when you make your Tetris game, you can't call it "Tetris." Tetris is a trademark of the Tetris Company, which is owned by Alexey Pajitnov, the creator of Tetris. It is his exclusive right to use the name Tetris, and I believe they may have won a lawsuit saying that you cannot make a falling blocks game with the syllable "tris," as it is obviously playing off the popularity of the of the name Tetris. However, this means nothing to you if you call your game "The Sky is Falling," or anything without a "tris" in it, as they do NOT own the gameplay, interface, or idea of falling blocks. If you hear anything differently from anyone, tell them you can't own ideas, and if you require further proof you can look up information on this subject at the USPTO (http://www.uspto.gov/).
What's Next? After you have totally, completely, absolutely finished your version Tetris, you are ready for your next challenge: Breakout. Breakout is also a similar game, but it adds in much more advanced collision detection than was necessary in Tetris. You will also need to add some simple deflection physics of the ball rebounding off different portions of the paddle and the blocks. Level layout also becomes an issue in Breakout, and in order to have more than one level you will need to come up with a way to save the maps. This deals with another component found in all larger games, which is saving and loading resources and switching levels.
After you finish your Breakout masterpiece you should move .NET Game Programming with DirectX 9.0on to making Pac-Man. Pac-Man is an evolutionary stepby because it adds in the element of enemy artificial intelligence (AI). You may not have ISBN:1590590511 Alexandre Santos Lobão and Ellen been aware of this, but in the original Pac-Man the four different ghosts had different goals to try to defeat Hatton you as a team. The aggressor would try to follow the shortest path to you, making you directly avoid him. Apress © 2003 (696 pages) The interceptor would try to go to a junction was closest you would have to move to avoid the The authors of this text showthat how easy it can to bewhere to produce aggressor. A second interesting interceptor multimedia wouldgames try to stay using more Managed towards DirectX the middle 9.0 andand try to cut you off from programming with Visual Basic .NET on Everett, latestaimlessly about, which often kept using the tunnel through the sides. The last ghost would sort of the wander version of Microsoft's Visual Studio. him staying in a section you needed to finish the map. This kind of detailed AI was quite advanced for games of that time, and should give you a good challenge for your first game with enemy AI.
Table of Contents
.NET Game Programming with DirectX 9.0
Foreword Pac-Man also increases the complexity of maps, and adds a good deal more flexibility for using sounds, as Preface sound was certainly a crucial element to the success of Pac-Man. (After all, what would Pac-Man be Introduction without some sort of "wakka-wakka" sound?) Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Figure C-3: Pac-Man screen shot
Appendix C - How Do I Make Games?
Appendix - Guidelines for you Developing Successful The lastDgame I suggest should create is a Games side scroller, such as Super Mario Brothers, where you can Index jump on multiple platforms, shoot, duck and interact with enemies. As there is added art involved in this List of Figures game, I would suggest looking into using SpriteLib for some free and easy to use artwork, which is List of Tables available at http://www.arifeldman.com/free/spritelib.html.
Side scrollers introduce the possibility of added enemy AI complexity through the use of enemy bosses which have patterns you must learn to beat, as well an added screen complexity. Now you must make a screen that is capable of scrolling in at least two directions, if not four, and deal with screen clipping, which can have a bit of a learning curve. You must also work on the physics of any jumping, bouncing of the character or shooting projectiles. There will additionally need to be a lot more enemies than before, and you will need to keep track of their current game state (alive/dead, active/inactive), by whether they are on the screen or have already been dealt with. The level complexity and map/character storage complexity will have also increased and you will most certainly need to make a level editor at this point. The level editor should be capable of placing tiles, scrolling through tiles, scrolling over the map, choosing tiles as brushes, cycling through the brushes, cutting and pasting, an undo, and placing enemies. If you decide to skip writing any of these, you will most likely feel sorry about it, and if you have an artist or level designer, they will probably not be very happy with you either (how would YOU feel if you had to go through someone's text files containing a bunch of numbers and commas to edit a level?). I would also suggest making back ups of previously saved maps, as it is often easier to just back things up by versions, than redrawing them. Finally, the side scroller has a real victory condition! When you get to the end of the side scroller, you have actually GONE somewhere, so you can add on a story to progress through the game as well (and don't forget some sort of fireworks on the screen for the end of a level, so that the player has a sense of
accomplishment and a REAL show of fireworks for beating the game ... merely putting the words "You .NET Game Programming with DirectX 9.0 Have Won! " on the screen when a player has spent endless hours trying to beat your game is antiISBN:1590590511 by Alexandre Santos Lobão and Ellen climatic). Hatton Apress © 2003 (696 pages)
Get Out theThe Polish ...this text show how easy it can be to produce authors of interesting multimedia games using Managed DirectX 9.0 and
Finishing a gameprogramming does not merely with mean Visual you Basicget .NET it toona Everett, point where the latest it is playable, and then move on—this versionAof Microsoft's Visual Studio. is not a finished game. finished game will have an opening screen, a closing screen, menu options (if applicable, at least instructions on how to play and start), introduction screens to playing, reward screens and a score board (where applicable).
Table of Contents
.NET Game Programming with DirectX 9.0 arcade game and not be able to tell it doesn't belong just by the If you couldn't put your game in an 80's Foreword modes it goes through (minus the attract mode or demo mode), then your game is not finished. Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Figure C-4: Galaga—everything explained at a glance
Appendix C - How Do I Make Games?
Appendix Guidelines for between Developing Successful There isDa -big difference a game that isGames "bare bones", and a game you have put all the finishing Index touches on. This difference will be a matter of a couple of days to two weeks (depending on the size of the
game). It will get increasingly (sometimes exponentially) more involved as you move from Tetris to List of Figures Breakout and so on. List of Tables The result, though, will be very important, both in terms of your understanding game development, and your own pride in your work and satisfaction/fulfillment. (Accomplishment does wonders for self-esteem! ) It's not easy to show people your game and have to constantly tell them to overlook different things and feel the same as if they picked it up and had no problems moving through it and everything was well presented and complete feeling. Other game developers are a bit more forgiving, since they know the process. Most importantly though, you will learn all the details that go into really finishing a game. If you stop at just working gameplay, you will still miss out on the details of wrapping things up, which will leave a blank spot in your mind when trying to plan larger projects in the future.
But, These Games Are Stupid! Actually, these games clearly show the basis for ALL games' gameplay. Throw a fancy 3D interface over a shooter and it's still a shooter. You could create the same game in a 2D overhead view and the gameplay would be coded exactly the same. Is it stupid to be able to make a game with EXACTLY the same controls, responses and enemies as Quake? If you remove the 3D interface, and look at what is really happening from a directly overhead view, does it still seem as out of reach?
Even so, this is not a beginning project. There are too many elements that need to be developed and .NET Game Programming with DirectX 9.0 refined for a first project, so I strongly urge you to follow the order of games I suggest to gradually build up by Alexandre Santos Lobão (When and Ellen your understanding of game development. you learnedISBN:1590590511 how to swim, did you IMMEDIATELY start Hatton out with a high dive into the deep water? NO! You start in the shallow end, you learn to dog paddle, and Apress © 2003 (696 pages) progress from there.) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Figure C-5: Gauntlet
Chapter 4 -that River Game Fields, Scrolling, and DirectAudio One thing youPla.Net: need toTiled clarify to yourself before starting anything, is what you want out of it. Do you Chapter 5 River Pla.Net II: DirectInput and Writing Text Screen If all you are interested in is the want to make games, or just duplicate the technology intoQuake? Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow technology, then skip all the games stuff and get started on graphics technology. Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API If you are interested making games, you need to separate your desire to create the next Chapter 8 really - .Netterpillars II:inMultiplayer Gamesthen and Directplay
cutting edge, hard core game, and focus on buildingWindows, your ability do so.toThe best way to do that is D-iNfEcT: Multithreading, Nonrectangular andtoAccess through actually making and (more importantly) finishing games, which is what following this path (or a Nonmanaged Code similar one) will give you experience in. Bonus Chapter Porting .Nettrix to Pocket PC Chapter 9
Appendix A - The State of PC Gaming
Be Proud of Your Games!
Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
You don't peoplefor in college embarrassed Appendix D hear - Guidelines Developing Successful about Gamesbeing in college because they don't have a job yet. You are learning, and making even a simple game is hard, especially if you want it done WELL. This is Index shown clearly by all the people who have NOT made even simple games but talk about it constantly. List of Figures Once you have finished a game, consider yourself to have more of a track record than anyone who has List of Tables
not finished a game even if their idea sounds phenomenal and like it's up there with the latest cutting edge games. If you can't play it, it's not a game. When you have a finished product you can show, you need to accept that for what it is, not what it isn't or compare it to people with 5+ years of experience and million dollar budgets who work on games full time.
I Made My Game, Now Where's My Ferrari? Sorry, one game, two games, five games probably won't cut it. Last year there were 3,500 games released on the PC, and only a few handfuls made back a large portion of cash. Most of those that did weren't made by small groups who were self-funded, they were funded by large publishers and probably had multi-million dollar budgets, and definitely near or well over million dollar advertising campaigns. This isn't a world you can't join though; it just takes a good deal of time and experience and track record of making quality games, that hopefully sell well, to give publishers confidence in your team, so that they will entrust you with this kind of financial responsibility.
Figure C-6: Where's my Ferrari?
Programming DirectX 9.0multi-million dollar budgets and I strongly However, there is.NET moreGame to making a living of with games than the ISBN:1590590511 Alexandre Lobão as andwell. EllenThere is nothing suggest you takeby a look at theSantos other things bad or embarrassing about making Hatton budget games; they can be just as or more fun than the high budget commercial games, and it is a lot Apressto© trust 2003 (696 easier to get publisher youpages) with smaller budgets. On top of that, you don't have to spend years The authors thisif text show go howover easywell, it can bedon't to produce working on the same project,ofand it doesn't you have to feel as much loss with it. interesting multimedia games using Managed DirectX 9.0 and
programming Basic want .NET out on Everett, the games latest and then concentrate on making Just have an understanding ofwith whatVisual you really of making version of Microsoft's Visual Studio. that come true. Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Programming with DirectX 9.0 Appendix.NET D:Game Guidelines for Developing Successful ISBN:1590590511 by Alexandre Santos Lobão and Ellen Games Hatton Apress © 2003 (696 pages) The authors this text showby how easyShelley it can be The text in this appendix was of first presented Bruce astoa produce speech at the United States' Game interesting multimedia games using Managed DirectX 9.0 and Developers Conference in 2001, and shows the vision of one of the most successful team of game programming with Visual Basic .NET on Everett, the latest developers, Ensemble Studios (responsible for the blockbuster Age of the Empires), about some points version of Microsoft's Visual Studio. you must keep in mind when thinking about developing commercial games. Table of Contents
Guidelines for Developing Successful Games
.NET Game Programming with DirectX 9.0 Foreword
Introduction
Preface
Introduction
The title for this presentation includes two words that need defining at the start. I use the word "guidelines" - .Nettrix: GDI+ and Collision Detection in the sense of suggestions or check boxes, but not as a recipe. I use "successful" here to mean the Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites commercial success of a game: sales and profits. Chapter 1 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4 of - River Pla.Net: TiledisGame Fields,policies, Scrolling, and DirectAudio The goal this presentation to suggest methods, and features that can lead to commercial Chapter 5 River Pla.Net II: DirectInput and Writing Text Screen success. The more of these guidelines that you follow ortoincorporate into your development, the greater Chapter the probability 6 - Magic of success KindergarteN.: from the Adventure resultingGames, game. ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
The sources of these guidelines are many, but mostly they come from practical experience. That includes - .Netterpillars II: Multiplayer Games and Directplay my personal 20 years making and playing games of one sort or another, lengthy discussions with D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - at Ensemble Studios, discussions with friends in the industry, and discussions with other colleagues Nonmanaged Code colleagues in Porting the past, most to notably Bonus Chapter .Nettrix PocketSid PCMeier. Many of the thoughts presented here I first heard spelled out in one form or another from him. Appendix A - The State of PC Gaming Chapter 8
Appendix B - Motivations in two Games Before beginning, I have caveats. First, the guidelines I present today are applicable mainly to empty Appendix C How Do I Make Games?The emphasis would be different for story-based, linear games. Second, map games and strategy games. Appendix D - Guidelines for Developing Successful Games this presentation was made with PC games in mind, although many of the guidelines would be appropriate Index for console games as well. List of Figures List of Tables
Reach for a Broad Audience When you set out to develop a PC game, the potential market is everyone on Earth who owns a PC. Once you begin making decisions about your game (gory, sci-fi, RTS, shooter) you begin losing potential customers who are not interested in your topic, genre, or style. Commercially successful games hold on to significant share of that market because they choose a topic, genre, and style that connect with a broad audience. The acceptance of the PC into more world communities, different age groups, and by women means that games do not need to be targeted, and perhaps should not be targeted, solely to the traditional gaming audience of young males. Games that have been strong traditionally with the hard-core (young male) audience, must remain attractive to that group, but expanding the appeal can bring in the much larger casual audience. In these cases we need the hard core to approve the game and spread word of their approval to the market. This increases awareness within the casual market where the bulk of sales probably reside. Achieving broad appeal requires that some aspects or game options appeal to the hard core while others, possibly the same or possibly different, appeal to the casual gamer. Know how the game will appeal to the different market segments and why each will like it. This differentiation often requires both single and multiplayer game options. Strive to be the best game in your genre and about your topic. The best games make the bulk of the profits, while the mediocre games suffer. The rest of this presentation deals with what to do or include in a game in order to entertain a large
audience. That usually means creating something that is commercial art, not fine art. The best games .NET Game Programming with DirectX 9.0 entertain by engaging the player's mind, not by providing titillation (which wears off quickly). by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Differentiate and Innovate, Don't Imitate The authors of this text show how easy it can be to produce
The majority of the gameplay ideas in any game come from other games. interesting multimedia games using Managed DirectX 9.0 andIt is natural to be inspired by successful games programming and practical with to borrow Visual Basic from.NET themonwhen Everett, creating the latest games of your own. To be successful, version of Microsoft's Studio. from the competition and innovative as well. Games however, new games must be clearly Visual differentiated that imitate without differentiation and innovation are considered clones. Clones are usually commercial failures.
Table of Contents
.NET Programming DirectX 9.0 AnyGame new game will havewith competition in the form of games very like it in topic, style, or genre. To succeed Foreword the new game must match or exceed the competition in those areas where their game excels. The new Preface games must also exceed the competition where it is weak. Identify important features and components Introduction that the competition is executing poorly or not at all. These are your opportunities. They are the principal Chapter ways that 1 your - .Nettrix: gameGDI+ can be anddifferentiated Collision Detection and distinguished in the market place. Examples of elements in
Age of 2Empires I that were opportunities because few if any of the competing were executing them (or Chapter - .Netterpillars: Artificial Intelligence and Sprites doing them well) include historical theme, organicBasics units,and random maps, non-cheating AI, levels of difficulty, Chapter 3 - Managed DirectX First Steps: Direct3D DirectX vs. GDI+ multiple4 victory conditions, historical stunning Chapter - River Pla.Net: Tiled Game notes, Fields, and Scrolling, and animations. DirectAudio Including all of these elements differentiated the Pla.Net Age of II: Empires games. these elements well helped establish the reputation of Chapter 5 - River DirectInput andExecuting Writing Text to Screen Ensemble as masters ofAdventure the real-time strategy genre.and Analyzing the strengths and weaknesses of Chapter 6 -Studios Magic KindergarteN.: Games, ADO.NET, DirectShow potential competitors in other genres will reveal where the competition is strong, where it is weak, and - Magic KindergarteN. II: Animation Techniques and Speech API where are your opportunities.
Chapter 7 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Nonmanaged Prototype Early Code
Bonus Chapter Porting .Nettrix to Pocket PC
Prototype important and technologies as a proof of concept as early as possible. Prototyping is Appendix A -allThe State ofsystems PC Gaming very useful a technology standpoint, but it is critical for testing gameplay. Designers are largely Appendix B - from Motivations in Games guessingC until their can be played. There are always surprises when a game is first played, and not Appendix - How Do games I Make Games? all are good ones. Prototyping for gameplay testing is especially useful for strategy and other empty map games that do not depend on pre-planned or linear story lines.
Appendix D - Guidelines for Developing Successful Games Index
List of Figures
Design by Playing
List of Tables
Once a playable prototype has been created, play every day, make adjustments based on testing, create new versions quickly, and evolve the game through this process. Rely on your instincts as gamers for guidance for what is working and not working. Larger test groups create more valuable testing feedback and create games of wider appeal. Test for both hard-core and casual gameplay. Everyone at Ensemble Studios is asked to test our current projects at least once per week and provide feedback. The downside of this process is that it is difficult to predict and often costly. It does, however, lead ultimately to creating a fun game.
Interesting Decisions = Fun Presenting the player with interesting and well-paced decisions is the rocket science of game design. Players have fun when they are interested in the decisions they are making, when they are kept absorbed by the pacing of the required decisions, and when they feel a sense of reward and accomplishment as good decisions are made. When the required decisions are too often trivial or random, fun sags. You risk boring the player and driving him/her out of the game. The Age of Empires games demonstrated that our customers consider automating trivial activities (queues, waypoints) a positive improvement. Good pacing can heighten interest in decision making. Real time games have an inherent advantage versus turn-based games because the continual ticking of the game clock adds a sense of desperation. If the player has many reasonable decisions to deal with but time to make only a few, everything being considered becomes much more interesting.
When considering a new feature for a game,with apply the interesting decisions test. Is this new element or .NET Game Programming DirectX 9.0 twist going to addby anAlexandre interesting decision to what the player is doing? If the answer is not a strong "yes," ISBN:1590590511 Santos Lobão and Ellen leave it out. Hatton Apress © 2003 (696 pages) The authors of this show how easy it can be to produce Provide a Great First 15text Minutes of Easily Accessible Play interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
A player must beversion activelyofengaged by a new game within 15 minutes of starting play or we risk losing that Microsoft's Visual Studio. player forever. There are three keys to getting a new player into a game: (1) an interesting starting situation; (2) minimal barriers to entry (interface, back-story); and (3) giving the player only a few decisions Table to make of Contents immediately but growing that number exponentially (this is the inverted pyramid of decision making). the playerwith into DirectX the game .NET GameGet Programming 9.0quickly and easily so that he or she is absorbed and having fun without frustration. When done properly, the player gets into the game successfully and significant time Foreword may pass before he or she is aware of it. Preface Introduction
Games that necessarily require a lot of pre-play work from the player because of special controls, - .Nettrix: GDI+ and Collision Detection character introductions, or story background must create tutorials or other clever ways to educate the Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites player while providing entertainment. In-game tutorials are the best. Games that require uninteresting preChapter 3 or - Managed DirectX Steps: Direct3D and DirectX play work retard entry withFirst frustrating interfacesBasics are likely to fail. vs. GDI+ Chapter 1
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
The Player Should Have the Fun, Not the Designer, Programmer, or Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Computer Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Although this principle seems obvious, many games fail because the wrong entity has most of the fun. D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 be - the designer who allowed feature creep to overrun the product or a designer who did a That can Nonmanaged Code brilliant analysis and .Nettrix installedtoan amazing Bonus Chapter Porting Pocket PC single path to victory that no one else could find. The producer can direct great graphics and cinematics to suck up the budget, making all the artists happy, but leaving Appendix A - The State of PC Gaming little time for inserting actual game play. If a player finds himself waiting too often while the computer Appendix B - Motivations in Games grinds through some brilliant calculations, maybe the computer is having more fun than the player is. Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Games Game development should focus on Successful creating entertainment for players by engaging their minds. Index Everything the team does in development and the machine does in operation is directed toward that goal. List Figures All of code, game features, art pieces, sound effects, music scores, and computer operations should List of Tables enhance entertainment. An exception to this rule may be elements included for marketing considerations,
such as opening cinematics. Two additional points to keep in mind: 1. The player should be the hero or heroine. 2. In single play, the player should sweat but win in the end.
Create Epic Games That Can Launch/Extend a Franchise The greater the newness of a game (genre, topic, artistic style, technology, developer, publisher) the more difficult it is to get shelf space, media coverage, a web following, and customer awareness, all of which relate directly to commercial success. Creating a great franchise makes those tasks much easier and makes it possible to increase the customer base for each succeeding product. Choose genres and topics that can capture the imagination of the market and the media, and thereby establish a new epic series of forthcoming related games. Publishers want franchises and are more willing to invest in them.
Set Production Values High While great gameplay is the key to creating great games, graphics, sound effects, and music have very important supporting roles. Graphics and sound effects are key elements in the game interface. Graphics must be attractive, enticing, and inspire inquisitiveness. Graphics and sound effects should convey information quickly with minimum player effort. Acting together, these three elements set the mood of the
game and help the player forget that he or she is playing a game. Graphics and sound have important .NET Game Programming with DirectX 9.0 ancillary roles in helping to market the game. by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton for graphics, sound effects, and music enhance the player's experience and High production values Apress ©overall 2003 (696 pages) of quality. Low quality elements among others of high quality stand contribute to the game's cachet The authors this text show how easy it canofbe to product. produce A high standard of quality in out like off-key notes, greatly of diminishing the overall impact the games Managed DirectX 9.0 and and the publisher. production valuesinteresting enhancesmultimedia the reputation of using the game, the developer, programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Interface Goals: Intuitive, Easy to Use, and Minimize Frustration Table Contents The of interface often gets treated as an afterthought because it rarely has the ability to create a sensation .NET Game Programming withfeatures, DirectX 9.0 for the player as gameplay graphics, sound effects, and music can do. No one gets excited about Foreword how a game drops down menus or presents buttons. While the interface has little chance to dramatically Preface enhance a game, there is a great risk, however, that poor interface design can do real harm. Keep in mind Introduction that capturing the player's imagination with great gameplay, visuals, and sound is only part of the battle. Chapter Giving the 1 -player .Nettrix: access GDI+toand all Collision of these Detection cool things easily without frustration is the other half. A confusing,
difficult,2 and frustrating interface ruin a game. Players encountering these problems in their first play Chapter - .Netterpillars: Artificialcan Intelligence and Sprites session3may easily lose interest giveDirect3D up. Chapter - Managed DirectX Firstand Steps: Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Minimize the layers of an interface (menus within menus) and control options (being able to play the Age - River Pla.Net II: DirectInput and Writing Text to Screen of Empires games using only a mouse is a good thing). Provide an interesting and absorbing tutorial when Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow learning controls and operations can be daunting, or if the player must learn quite a bit before beginning Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API play. Chapter 5
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Provide- Nonmanaged MultipleCode Gaming Experiences Within the Box
Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC
To help reach a broad audience, include a variety of game types and adjustable game parameters that combine in different ways to create a range of quite different gaming experiences, all within the same Appendix B - Motivations in Games game. Examples of different gaming experiences with the Age of Empires games are multiplayer death Appendix C - How Do I Make Games? matches, single player campaigns, random map games, cooperative play games, king of the hill games, Appendix D - Guidelines for Developing Successful Games and wonder races. Victory conditions, map types, and level of difficulty settings are examples of Index parameters that can be adjusted to create different gaming experiences. Multiple options in each List of Figures dimension (variable parameter) create a volume of different game types. Appendix A - The State of PC Gaming
List of Tables
We want the smartest kid in junior high school (a hard-core gamer) telling his or her friends that our game is his or her favorite right now. When those friends buy our game, they probably won't be able to complete with the star, but by adjusting those parameters they can still find a type of game that suits them and have fun. The average kids and the smart kids can both enjoy our game, although they play quite different parts of it. When we provide a variety of gaming experiences within the single box, we increase the number of people who can buy our game and be happy with it. Each of these successful customers becomes in turn a potential evangelist.
Player Investments Some of the most successful games ever require the player to invest in the experience of play by building empires, character statistics, or city infrastructures. Players enjoy creating things within a game, taking possession of their creations, molding them to their personal taste, and using them to further their game goals. Examples of games requiring player investment include Sim City (city infrastructure), Diablo (character statistics), and Age of Kings (empire and technology). Building, defending, and using in-game investments create a strong bond between the player and the game.
Facilitate Consumer Content Player's enjoy creating additional content for their favorite games, whether it is new planes for Flight
Simulator, skins for their favorite shooter, or scenarios for Age of Kings. They get a chance to be a game .NET Game Programming with DirectX 9.0 designer, make the game/add-on they want but that does not exist, and see their own work running onISBN:1590590511 by Alexandre Santos Lobãodesigners. and Ellen Consumer screen. Players get a chance to be game content lengthens the working life of a Hatton game and helps increase awareness of it in the marketplace. Apress © 2003 (696 pages)
The authors of this text show how easy it can be to produce
Replayability interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio. It is better to create a game that can be played over and over, rather than one that is usually played only once. Providing replayability increases consumer satisfaction and the perceived value of the game. The AOE games provide replayability through randomly generated worlds, variety of maps, variety of game Table of Contents types, and multiple civilizations to be played. .NET Game Programming with DirectX 9.0 Foreword
Story
Preface
Introduction
The story of a game (or narrative or plot) is the experience of playing it through the series of events that - .Nettrix: GDI+ and Collision Detection extend from start to completion (victory condition). A great game story keeps the player engaged, intrigued Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites and playing, increasing satisfaction. The story a game tells depends on the topic and victory condition, plus Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ the hurdles the player must overcome to reach victory (completion). A great story uses plot twists, reversal Chapter 4 -and River Pla.Net: Gamethe Fields, Scrolling, and Adventure DirectAudiogames require the designer write the of fortune, other ploysTiled to keep player interested. Chapter 5 River Pla.Net II: DirectInput and Writing Text to story and the player act it out. RTS games usually provide Screen no story, but instead an empty map, like an Chapter 6 - Magic KindergarteN.: Adventure ADO.NET, and DirectShow empty page, on which the players write the Games, story themselves as they play. Chapter 1
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
II: Multiplayer Games and Directplay Quality- .Netterpillars vs. Budget and Schedule D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Chapter 9
-
Nonmanaged Code
An extraordinary game that ships late makes its money in the long run, and has positive effects on Bonus Chapter Porting .Nettrix to Pocket PC customer satisfaction, the franchise, and developer/publisher reputations. A mediocre game that ships on Appendix - The State of PC Gaming time is aAdisaster (financial, brand, reputation). Appendix B - Motivations in Games
Game development moreGames? an art than a science, and therefore difficult to predict. Developers must Appendix C - How Do IisMake demonstrate that a project is makingSuccessful good progress toward a goal. Publishers must assess that progress. Appendix D - Guidelines for Developing Games There is no reasonable justification for major compromises in the quality of a product. Make a great game Index or kill it early. One of the values of early prototyping is that it can reveal that a game is not going to work List of Figures early in the process. List of Tables
Gameplay vs. Realism or History We are in the entertainment business, not simulation or education. Our priority is to create fun, engaging gameplay. Realism and historical information are resources or props we use to add interest, story, and character to the problems we are posing for the player. That is not to say that realism and historic fact have no importance. They are just not the highest priority. Any education that follows from playing our games is a very positive, though secondary, benefit. This is a great marketing point and adds to the reputation of the developer and publisher.
Polish the Game Budget time at the end of a project to polish the game, bring all elements to a high production value standard, and add the little touches. Test rigorously to insure balance (where appropriate), to insure there is no single optimal winning strategy (or unit, or spell, etc.), and to eliminate any potentially fatal gameplay flaws. When the game reaches the customer, we want them to feel that every aspect of the game was well planned and executed. Polish tells our customers that we took the time and made the effort to craft an extraordinary product. Polishing a game increases customer satisfaction, enhances the reputation of the developer and publisher, and builds fan loyalty. Lack of polish has a negative effect in all of these areas, working against the goals of everyone involved in development. There is no acceptable excuse for not polishing a game. If
you cannot afford to polish, you are in the wrong business or your team was inadequate (too small or DirectX 9.0 unskilled). Nearly.NET doneGame is notProgramming an acceptable with standard for going gold. by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Special Characters
The authors of this text show how easy it can be to produce ^ (power operator), 56
interesting multimedia games using Managed DirectX 9.0 and
programming with Visual Basic .NET on Everett, the latest 2-D graphics. See GDI+ version of Microsoft's Visual Studio.
3-D graphics. SeeDirect3D;graphics, 3-D 3/4-to-1/4 tiles, 215 Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index A
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
authors of this text show how easy it can be to produce acceleration.SeeThe DirectX
interesting multimedia games using Managed DirectX 9.0 and
with Visual Basic .NET on Everett, the latest Access database,programming 381–82,387–94 version of Microsoft's Visual Studio.
action, tempo and, 615 actions
Tablemouse of Contents pointers and, 402–9 .NETproposals Game Programming and, 24 with DirectX 9.0 Foreword
Activate event, 66,584
Preface
active objects Magic KindergarteN, 371–74,378–79,387–93 Chapter 1 - .Nettrix: GDI+ and Collision Detection Magic KindergarteN II, 450–51,457–59 Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites River Pla.Net II, 321–24 Introduction
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
adaptable tables, Chapter 4 -percentage River Pla.Net: Tiled 75–76 Game Fields, Scrolling, and DirectAudio adapters, 146,147, 168,170–71 Chapter 5 DirectX, - River Pla.Net II: 150, DirectInput and Writing Text to Screen Chapter 6 objects, - Magic 492, KindergarteN.: Address 498,502 Adventure Games, ADO.NET, and DirectShow Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API
ADO.NET data access - .Netterpillars II: Multiplayer Games and Directplay Magic KindergarteN, 381–82,387–94 D-iNfEcT: Multithreading, Magic II, 457–59 Nonrectangular Windows, and Access to Chapter 9 KindergarteN Nonmanaged Code objects,355–58 Chapter 8
Bonus Chapter Porting .Nettrix to Pocket PC
Adventure 348of PC Gaming Appendix A -game, The State adventure 347–55. See alsoMagic KindergarteN game Appendix B -games, Motivations in Games graphical, 350Do I Make Games? Appendix C - How point-and-click, 351–52 Appendix D - Guidelines for Developing Successful Games Indexrole-playing games (RPGs) and, 347
technical List of Figures tips for coding, 353–55 text-based, 348–49
List of Tables
advertisements,595–97,601,624 AdvPlayer class, 379–80 A8R8G8B8format,150 Age of Empires games, 87,607,627,608,629,630 Age of Kings game, 633 AI.Seeartificial intelligence AINetterpillar class, 93–94,132–36 algorithms collision detection (seecollision detection) line of sight, 76–78 Alice game, 595–97 alpha blending, 2,188–89 alternate fill mode, 555 Amazing Blocks game, 618 analysis, market, 604–9.See alsoPC gaming market analysis, object-oriented (OOA), 70.See alsoobject-oriented programming (OOP) animation,423–30 of anticipation, 428–29
compiling guides, 434–35 .NET Game Programming with DirectX 9.0 cycling movements, 424–26 ISBN:1590590511 by smoothing, Alexandre Santos frame rates and 205–7Lobão and Ellen Hatton full,475–76 Apress © 2003 (696 pages) hiding latency with, 487–88 The authors of this text show how easy it can be to produce of mouths, 432–34 interesting multimedia games using Managed DirectX 9.0 and of parts of images, 430–32 with Visual Basic .NET on Everett, the latest programming of posture to reveal 429–30 versionemotions, of Microsoft's Visual Studio. River Pla.Net player, 285–88 squashing and stretching motions, 426–28 Tabletechnical of Contents tips, 430–34 .NET Game Programming with DirectX 9.0
ANSI strings, 487
Foreword
answer blocks, dialog, 451–52,457–59 Preface Introduction antialiasing,4 Chapter 1 - .Nettrix: GDI+ and Collision Detection anticipation Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites animating, 428–29 Chapter 3 - Managed DirectX as player motivation, 614First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio ApplicationDescription objects, 492–93,502
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Application objects, 60
application interfaces (APIs), 435, 557–58 and Speech API Chapter 7 - programming Magic KindergarteN. II: Animation Techniques Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay applications, game. See.NET game programming
arrays 9 Chapter
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
of bits, zoning with, 20–21,54–56 game field, 95 Appendix A - The State of PC Gaming initial values of, 34 Appendix - Motivations in Games tiled B game field, 17–18 Appendix C How Do I Make Games? zoning and, 18–21
Bonus Chapter Porting .Nettrix to Pocket PC
Appendix D - Guidelines for Developing Successful Games
artificial intelligence, 72–79 adaptable percentage tables, 75–76 List of Figures categories,73 List of Tables techniques, 74–79 common defined, 69 game engines and, 88–89 game physics vs., 72 general considerations, 73–74 hearing player sounds, 78 in multiplayer games, 488 Pac-Man, 620 proposals and, 24 learning about, 79 libraries of reusable graphics and objects, 79 line of sight algorithms, 76–78 .Netterpillars game and, 69,93–94, 132–36 (see also.Netterpillars game) path finding, 78–79 side scroller games, 622 Index
ASP.NET Mobile Application, 576 attributes, declarative, 557.See alsoproperties audiences, broad, 628 audio.SeeDirectAudio;DirectMusic;DirectShow;DirectSound Audio objects, 359 audio paths, 242
AudioVideoPlayback interface, 359
.NET Game Programming with DirectX 9.0
AutoDepthStencilFormat structure, 148 by Alexandre Santos Lobão and Ellen Hatton automatic scrolling, 213
ISBN:1590590511
Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index B
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce back buffer structures, DirectX, 148–49
interesting multimedia games using Managed DirectX 9.0 and
with303 Visual Basic .NET on Everett, the latest background inputprogramming device access, version of Microsoft's Visual Studio.
background music, 239–49,283–85.See also DirectMusic balanced games, 490 Table of Contents
Baldur's Gate games, 606
.NET Game Programming with DirectX 9.0
bandwidth,480,486,488 Foreword Preface Barker, Clive, 602 Introduction base class methods, 102,222 Chapter 1 - .Nettrix: GDI+ and Collision Detection
Begin method, 293
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
BeginScene method,DirectX 151 First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 3 - Managed behavior device, 147–48 Chapter 4 flags, - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5 - River Pla.Net 604–9 II: DirectInput and Writing Text to Screen best-selling PC games, Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
beta testing groups, 490
Bezier curves, 560–61 - .Netterpillars II: Multiplayer Games and Directplay Big Game Hunter games, 605,606 Nonrectangular Windows, and Access to D-iNfEcT: Multithreading, Chapter 9 Nonmanaged Code bitmap images, 6,81–82,144,145.See alsoimages Chapter 8
Bonus Chapter Porting .Nettrix to Pocket PC
bits zoning with, 18–20 Appendix B - Motivations in Games zoning with arrays of, 20–21
Appendix A - The State of PC Gaming Appendix C - How Do I Make Games?
blending, 2 Appendix D alpha, - Guidelines for Developing Successful Games blitting, bitmap, 82,144,145 Index List of Figures Block class, 37–53 List of Tables class diagram, 25–27,29
class interface, 37–39 Down, Right, and Left methods, 41–44 New method, 39–41 Pocket PC version, 588–89 Rotate method, 45–50 Show and Hide methods, 50–51 testing,51–53 body language, animation, 429–30 border tiles, 215–16,253–54 bounding boxes algorithms, 9–13 calculating collisions with boxes, 11–12 collision detection, 9–10 creating custom rectangle objects, 12–13 extending, for 3-D, 21 mouse pointer collision detection, 402 boxes, path, 79 Branch class, 92–93,103–6 Breakout game, 619–20 broad audiences, 628 broadcasting,482,491
brushes, gradient, 7–9
.NET Game Programming with DirectX 9.0
budget games, 625 by Alexandre Santos Lobão and Ellen Hatton budgets, commercial games and, 634
ISBN:1590590511
Apress © 2003 (696 pages)
buffers The authors of this text show how easy it can be to produce DirectSound, 234, 239 multimedia games using Managed DirectX 9.0 and interesting Direct3D vertex, 160, 163–66 (see alsoBasic vertex collections) programming with Visual .NET on Everett, the latest version of Microsoft's Visual Studio. DirectX,148–49 bullet sprites 330 Tablearray, of Contents collision detection, 335–36 .NET Game Programming with DirectX 9.0 moving, 333–35 Foreword bumpers around characters, 78 Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index C
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
Caesar III game, The 601authors of this text show how easy it can be to produce
interesting multimedia games using Managed DirectX 9.0 and
with Visual Basic .NET on Everett, the latest camera position, programming Direct3D, 154–55, 158–59 version of Microsoft's Visual Studio.
cardinal splines, 3
Carmack, John, 596,604 Table of Contents
cartoons,206
.NET Game Programming with DirectX 9.0
Castle Elsinore game, 348 Foreword Preface Castle Wolfenstein game, 72 Introduction Catch keyword, 58,245 Chapter 1 - .Nettrix: GDI+ and Collision Detection
Cesar, Waldivar, 363,417,440,448
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites character Seeanimation Chapter 3 -animation. Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
characters. nonplayer characters (NPCs); player characters Chapter 4 - See River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Chapter 5 preventing, - River Pla.Net II: DirectInput cheating, 484–85, 488–89 and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
cheats, adventure game, 354
CheckDeviceType method, 170 - .Netterpillars II: Multiplayer Games and Directplay CheckLinesD-iNfEcT: method, 56–58 Multithreading, Nonrectangular Windows, and Access to Chapter 9 Nonmanaged Code cheese puzzle, Magic KindergarteN II, 460–62 Chapter 8
Bonus Chapter Porting .Nettrix to Pocket PC
Chessmaster 8000 game, 601
Appendix A - The State of PC Gaming
child classes, base class Appendix B - Motivations in methods Games and, 102, 222 Appendix C - How Do I Make Games? circle objects Appendixcollision D - Guidelines detection for for, Developing 14–15 Successful Games Indexextending proximity algorithms for 3-D, 22 List of Figuresgame, 217, 355, 606 Civilization List of Tables
class diagrams Magic KindergarteN, 376–80 Magic KindergarteN, 454–55 .Netterpillars,88–91 .Nettrix, 25–27,29–30,582–83 River Pla.Net, 257–60 River Pla.Net II, 317–18 classes, interface, 97 class interfaces Block,37–39 GameEngine,96,218–25 GameFont,292–93 GameMusic,239–40 NetworkGame,493–97 PlayerVoice,440–43 Sprite,80–81,225–33 Square,31 client area, 555 clients, DirectPlay, 492 client-server connections, 479–80 clones, 628
CloseDown method, 248
.NET Game Programming with DirectX 9.0
Closing event, 109, 171 ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton coding.See also.NET game programming;Visual Basic .NET Apress © 2003 (696 pages) accessing nonmanaged code, 556–58,569–72 multiplayer games The authors from ground of this text up, 486 show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and projects and coding phase, 24–25 (see also projects) programming with Visual Basic .NET on Everett, the latest proposals (seeproposals) version of Microsoft's Visual Studio.
Collect method, 140,233 collision detection, 9–22 bounding boxes algorithms, 9–13 .NET Game Programming with DirectX 9.0 Breakout,619 Foreword extending algorithms for 3-D collisions, 21–22 Preface line of sight and, 77 Introduction Magic KindergarteN, 395,402–9 Chapter 1 - .Nettrix: GDI+ and Collision Detection .Netterpillars, 119–24 Chapter 2 -42, .Netterpillars: Intelligence .Nettrix, 54–56 (seeArtificial also.Nettrix game) and Sprites Chapter 3 - Managed First Steps: Direct3D Basics and DirectX vs. GDI+ optimizing numberDirectX of calculations, 17–21 Chapter 4 - River Pla.Net:14–16 Tiled Game Fields, Scrolling, and DirectAudio proximity algorithms, Chapter River 5 Pla.Net, - River Pla.Net 280–83II: DirectInput and Writing Text to Screen River Pla.Net II, 324,327–29,335–36, 345 Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Table of Contents
Chapter 7 - Magic Color objects, 8 KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
colors D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter alpha 9 blending, 2,188–89 Nonmanaged Code Direct3D,163–66,188–97 Bonus Chapter Porting .Nettrix to Pocket PC DirectX display modes, 150 Appendix A - The State of PC Gaming gradients,2,7–9,564 Appendix B - Motivations in Games .Nettrix Block objects, 38–39 Appendix C - How2,Do I Make Games? transparent, 8,82, 96,105 Appendix D - Guidelines for Developing Successful Games
Command objects, 356–57
Index
commercial List of Figures games, 627–33. See alsoPC gaming market broad audiences and, 628 List of Tables
creating franchise, 631 definitions and qualifications, 627 designing, by playing, 629 differentiation and innovation vs. imitation, 628–29 facilitating consumer content, 633 first fifteen minutes of easily accessible play, 630 game development and, 617–18, 624–25 (see alsogame development) gameplay vs. realism or historical information, 634 high production values, 631 player fun, 630–31 player fun as interesting decisions, 629–30 player investments, 633 polishing,634 prototyping,629 providing multiple gaming experiences within, 632 quality vs. budget and schedule, 634 replayability,633 storylines,633 user interface goals, 632
communities, game, 488,490,609–10.See alsoplayers COM objects, 233,239–40 comparison, player, 614
comparison operators, 55
.NET Game Programming with DirectX 9.0
compatibility, devices and, 575Santos Lobão and Ellen ISBN:1590590511 by Alexandre Hatton competition Apress © 2003 (696 pages) market,628–29 player,614 The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
compilation errors, porting games 583–86 programming withand, Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio. complex user interfaces, player motivation and, 616 compromises, game development, 596–98 Table of Contents
computer-controlled players, 73,95,488.Seealsononplayer characters (NPCs)
.NET Game Programming with DirectX 9.0
configurations game, 87 (see alsoconfiguration screens) Preface server,504 Introduction service provider, 500–501 Foreword
Chapter 1
- .Nettrix: GDI+ and Collision Detection
configuration screens - .Netterpillars: Artificial Intelligence and Sprites .Netterpillars,87,95,99,124–29 Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ .Netterpillars II, 503–4 Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio .Nettrix, 66 Chapter 2
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Connection objects, 356–57 Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow connections Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API ADO.NET, 356–57 II: Multiplayer Games and Directplay Chapter 8 - .Netterpillars client-server, 479–80 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 peer-to-peer, Nonmanaged 478–79 Code to Chapter remote Porting sessions, 512–13 Bonus .Nettrix to Pocket PC ring, Anetwork groups, and broadcasting, 481–82 Appendix - The State of PC Gaming types, Appendix B478–82 - Motivations in Games Appendix - How Do I Make Games? ConnectCmethod, 512 Appendix D -52 Guidelines for Developing Successful Games constants, Index
constant world games, 484–85
List of Figures
consumer List of Tablescontent, facilitating, 633 consumer expectations, 597–601.See alsoplayers broad audiences and, 628 high-end,599–600 low-end, 600–601 and unsuccessful movement of games to 3D environments, 598–99 value and gameplay, 598 context-based games, 484–85 contrast,615 conversion data type, 267 text to speech, 437–39 (see alsoSpeech API) cooperation levels DirectInput,303 DirectSound, 237–38 CooperativeLevelFlags enumeration, 303 coordinate systems, 3-D, 152–59 camera position and, 158–59 projections,152–55 matrix transformations, 156–58 costs
game development, 597 .NET Game Programming with DirectX 9.0 low-end games, 600–601 by Alexandre Santos Lobão and Ellen
CreateFlags enumeration, 147–48 Hatton
ISBN:1590590511
© 2003 (696 pages) CreateGameFieldApress method, 533–35
The authors of this text238 show how easy it can be to produce CreateSoundBufferFromFile function,
interesting multimedia games using Managed DirectX 9.0 and
critical sections, 550 programming with Visual Basic .NET on Everett, the latest culling,163,199
version of Microsoft's Visual Studio.
curves TableBezier, of Contents 561 .NETspline, Game 3 Programming with DirectX 9.0 Foreword
cut-scenes,354
Preface
cyclic approach, object-oriented, 25
Introduction
cycling,1mouse pointer, 399 Chapter - .Nettrix: GDI+ and Collision Detection Chapter - .Netterpillars: Artificial Intelligence cycling2movements, animation and, 424–26 and Sprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index D
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce data interesting multimedia games using Managed DirectX 9.0 and access (seeADO.NET datawith access) programming Visual Basic .NET on Everett, the latest internal, and artificial intelligence, version of Microsoft's 73 Visual Studio. models, 381–82,456 PC gaming market sales, 604–9 Tabletypes of Contents (seedata types) .NET Game Programming with DirectX 9.0
DataAdapter objects, 356–57
Foreword
DataReader objects, 356–57 Preface Introduction DataSet objects, 356–57 Chapter 1 - .Nettrix: GDI+ and Collision Detection data types Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites multiplayer games and, 486–87 Chapter 3 Basic - Managed First Visual .NET,DirectX 34,244, 267Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
dead zone, joystick, 305
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
death match game, 520
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow debugging, games and, II: 585Animation Techniques and Speech API Chapter 7 - porting Magic KindergarteN. Chapter 8 -commercial .Netterpillarsgames II: Multiplayer Games and Directplay decisions, and, 629–30 D-iNfEcT:557 Multithreading, Nonrectangular Windows, and Access to Declare9 statement, Chapter Nonmanaged Code
Deer Chapter Hunter game, Bonus Porting600–601, .Nettrix to605 Pocket PC Appendix demo games, A - The610 State of PC Gaming Appendix B -programs Motivations in Games 577–80 deploying to emulator, Appendix C - How Do I Make Games?
depth buffers, DirectX, 148
Appendix D - Guidelines for Developing Successful Games
designed content limit, 613 Index designing games by playing, 629 List of Figures List of Tables desktop PC programs and operating systems on mobile devices, 580–81
destroying sessions, 502–5 development, game. Seegame development device contexts, creating Graphics objects from specified handles to, 6–7 devices APIs and, 435 capabilities,168 compatibility and, 575 DirectX,146–51,158,168,171–72,234 input (seeinput devices) mobile (seemobile devices) writing text to, 291–95,337–39 Diablo games, 603–4,608,609,633 dialog boxes, 129 dialogs, Magic KindergarteN II answer blocks and, dialog paths, 451–53 adding support for, to active objects, 457–59 coding,462–73 finishing, 471–73 letting player choose character's speech, 465–69 mouse events and, 462–63
mouse pointer, 459–60 planning,354,.NET 362 Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen presenting dialog choices on screen, 463–65 Hatton reviewing, 469–71 Apress © 2003 (696 pages) user interface and, 454
ISBN:1590590511
The authors of this text show how easy it can be to produce
diamond-shapedinteresting objects multimedia games using Managed DirectX 9.0 and programming calculating collisions for, 16with Visual Basic .NET on Everett, the latest version of Microsoft's Visual22Studio. extending proximity algorithms for 3-D, differentiation, commercial games and, 628–29 Table of Contents difficulty levels. Seelevels .NET Game Programming with DirectX 9.0
Dim statement, 34
Foreword
D-iNfEcT game, 547–74 Preface
accessing nonmanaged code, 556–58,571–72 child window movement, 569–70 Chapter 1 - .Nettrix: GDI+ and Collision Detection coding phase, 561 Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites game over conditions, 570–71 Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ improving interface, 573 Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio main window, 561–66 Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen multithreading, 548–52 Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow nonrectangular windows, 553–56 Chapter 7 -559–61 Magic KindergarteN. II: Animation Techniques and Speech API project, Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay proposal, 559 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to sounds, 569–72 Chapter 9 Nonmanaged Code suggestions for improvements, 573 Bonus Chapter Porting .Nettrix to Pocket PC threads, 566–69 Introduction
Appendix A - The State of PC Gaming
DirectAudio DirectMusic, DirectSound, and, 233–36 Appendix C - and, How 145 Do I (see Makealso Games? DirectX DirectX) Appendix - Guidelines for Developing Successful Games RiverDPla.Net classes, 236–49,283–85 Appendix B - Motivations in Games
Index
DirectDraw object, 144,145
List of Figures
DirectInput List of Tables
basic routines, 297 classes for River Pla.Net II, 297–301 (see also River Pla.Net II game) DirectX and, 145 (see alsoDirectX) force-feed joysticks, 341–46 including support for joysticks and keyboards, 319–21 input devices, 295 mouse pointer and, 400–402 threading,296
direction force-feed joystick, 342 scrolling,212 DirectMusic DirectAudio, DirectSound, and, 233–36 DirectX and, 145 (see alsoDirectX) River Pla.Net class, 239–49,283–85,339 DirectMusic Producer, 233 DirectPlay,491–93.See alsomultiplayer games;.Netterpillars II game broadcasting,482 DirectX and, 145 (see alsoDirectX) hosts and clients, 491–92,493 for Pocket PC, 580
service providers, 492 .NET Game Programming with DirectX 9.0 sessions,492–93 Alexandre TCP protocol,by 489, 490–91Santos Lobão and Ellen
ISBN:1590590511
Hatton DirectSetup,145.See also DirectX Apress © 2003 (696 pages)
DirectShow The authors of this text show how easy it can be to produce interesting multimedia DirectX and, 145 (see also DirectX) games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Magic KindergarteN, 407–9 (see alsoMagic KindergarteN game) version of Microsoft's Visual Studio. streaming media and, 347,358–61 DirectSound TableDirectAudio, of ContentsDirectMusic, and, 233–36 .NETDirectX Game Programming with DirectX 9.0 and, 145 (see also DirectX) Foreword River Pla.Net class, 236–39,283–85 Preface
Direct3D
Introduction application pattern, 218 Chapter 1 - .Nettrix: GDI+ and Collision Detection application project, 167–69 Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites application proposal, 167 Chapter 3 -phase, Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ coding 168–69 Chapter 4 - lights, River Pla.Net: colored 193–97Tiled Game Fields, Scrolling, and DirectAudio Chapter coordinate 5 - River systems Pla.Netand II: DirectInput projections,and 152–59 Writing Text to Screen
DirectX (see alsoDirectX) Chapter 6 - and, Magic143 KindergarteN.: Adventure Games, ADO.NET, and DirectShow drawing and texture, Chapter 7 - primitives Magic KindergarteN. II: 159–66 Animation Techniques and Speech API full-screen sample, 186–87 Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay game engine classMultithreading, for River Pla.Net game, 218–25 D-iNfEcT: Nonrectangular Windows, and Access to GDI+ vs., 207–8 Nonmanaged Code initializing, 268 Bonus Chapter Porting .Nettrix to Pocket PC main window, 170–77 Appendix A - The State of PC Gaming simple 151–52 Appendix B -program, Motivations in Games smoothing animations frame rates, 205–7 Appendix C - How Do I Makewith Games? sprite class for River Pla.Net game, 225–33 Appendix D - Guidelines for Developing Successful Games testing matrix transformations, 197–205 Index transparent textures, 188–92 List of Figures windowed sample, 177–85 Chapter 9
List of Tables
Direct3DX,145 DirectX,143–50 adapters,146 devices,146–50 Direct3D and, 143 (see alsoDirect3D) display modes, 150 Font object, 292–95,337–39 GDI+ vs., 207–8 SDK,143,170,234,243,344 top-level objects, 144–45 Windows CE and, 580–81 disconnected data, 356 display modes, DirectX, 150,172–74,181 Dispose method, 86,109,171,184–85,233.Seealsogarbage collection distance hearing,78 proximity between objects, 14–16,22 seeing,76–77 DllImport,557,572 DMUS_APATH enumeration, 242
DoEvents method, 60
.NET Game Programming with DirectX 9.0
Doom game, 596, 604 by Alexandre Santos Lobão and Ellen Hatton Down method, Block class, 41–44
ISBN:1590590511
Apress © 2003 (696 pages)
drafts, object-oriented analysis and multiple, 95
The authors of this text show how easy it can be to produce
drawing interesting multimedia games using Managed DirectX 9.0 and Branch class programming method, 105–6 with Visual Basic .NET on Everett, the latest version159–63 of Microsoft's Visual Studio. Direct3D primitives, DirectX sprites, 232 Font object method, 293 Table of Contents GameFont class method, 294–95 .NET Game Programming with DirectX 9.0 MagicKindergarteN characters, 369–71,410–17 Foreword Player class method, 275–77 Preface RiverEngine class method, 269–71 Introduction sprites,81,82,85–86 Chapter - .Nettrix: GDI+ and Collision Detection tiles,1289–90 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
drivers,31,35,435
D3DX utility library, 158 Tiled Game Fields, Scrolling, and DirectAudio Chapter 4 - River Pla.Net: Dungeons Dragons game, 348 Chapter 5 -and River Pla.Net II: DirectInput and Writing Text to Screen Chapter 6 force-feed - Magic KindergarteN.: duration, joystick, 342Adventure Games, ADO.NET, and DirectShow Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index E
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce Earthworm Jim game, 598
interesting multimedia games using Managed DirectX 9.0 and
easter eggs, 354programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
education, gameplay vs., 634 effects, flashy, 612,614 Table of Contents
effects, sound. Seesounds
.NET Game Programming with DirectX 9.0
Effect structure, 343–44 Foreword Preface Electronic Arts, 596 Introduction emotions, animating posture to reveal, 429–30 Chapter 1 - .Nettrix: GDI+ and Collision Detection
empty map games, 627.See alsocommercial games
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites emulator, to,Steps: 577–80 Chapter 3 deploying - Managed programs DirectX First Direct3D Basics and DirectX vs. GDI+
EnableAutoDepthStencil Chapter 4 - River Pla.Net: structure, Tiled Game148 Fields, Scrolling, and DirectAudio Chapter 5 -488 River Pla.Net II: DirectInput and Writing Text to Screen encryption, Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
ending games - Magic KindergarteN. II: Animation Techniques and Speech API animated sequences for, 476 Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay D-iNfEcT criteria, 570–71 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to game screens (seegame over screens) Chapter 9 over Nonmanaged Code player motivation and, 616 Bonus Chapter Porting .Nettrix to Pocket PC proposals and criteria for, 24 Appendix A - The State of PC side scroller games, 622Gaming Chapter 7
Appendix B - Motivations in Games
End method, 293
Appendix C - How Do I Make Games?
EndScene 151 Appendix D -method, Guidelines for Developing Successful Games Index EndsWith method, 244 List of Figures engines, game. Seegame engines List of Tables
Ensemble Studios, 627,629 enumerations,52 environmental AI, 73 environmental variables, 74 environments, 3D, 598–99
e parameter, creating Graphics objects with, 5 epic games as franchise games, 631 erasing sprites, 85–86 errors avoiding, in multithreaded programs, 550–52 Direct3D programs and, 152 multiplayer games and, 489 porting games and, 583–86 structured handling of, 58,245 Esc key, 65–66,109,138,185 event handlers, 5,196 events D-iNfEcT,559–60 DirectPlay,495
game engines and, 27 Game Programming with DirectX 9.0 input devices .NET and, 297, 319–21 by Alexandre Santos Lobão and Ellen Paint, 5 Hatton Viseme,446–47
ISBN:1590590511
Apress © 2003 (696 pages)
Everquest game,The 607, 617 of this text show how easy it can be to produce authors interesting multimedia games using Managed DirectX 9.0 and exclusive input device access, 303 programming with Visual Basic .NET on Everett, the latest
expansion packs,version 602 of Microsoft's Visual Studio. expectations.Seecommercial games;consumer expectations;industry expectations Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index F
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
authors of this text show how easy it can be to produce failure of artificialThe intelligence, 73–74
interesting multimedia games using Managed DirectX 9.0 and
programming with Visual Basic .NET on Everett, the latest familiarity, consumer, 609 version of Microsoft's Visual Studio.
fast sprite drawing, 81–82.See alsoperformance features, project. Seeproposals Table of Contents
feedback, player, 610
.NET Game Programming with DirectX 9.0
females, 628 Foreword Preface fields, game. Seegame fields Introduction files, music and sound, 234 Chapter 1 - .Nettrix: GDI+ and Collision Detection
fill modes, 555–56
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
FillRectangle method, 5 Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Finalize4 method, GameMusic Chapter - River Pla.Net: Tiled class, Game 248–49 Fields, Scrolling, and DirectAudio Chapter - River 58 Pla.Net II: DirectInput and Writing Text to Screen Finally 5keyword, Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
FindHosts method, 506–8
finishing games, 622–26,634 - .Netterpillars II: Multiplayer Games and Directplay FireTeam game, 484 Multithreading, Nonrectangular Windows, and Access to D-iNfEcT: Chapter 9 Nonmanaged Code FiringSquad site, 595 Chapter 8
Bonus Chapter Porting .Nettrix to Pocket PC
fixed paths, 79
Appendix A - The State of PC Gaming
flashy effects, 612,614 in Games Appendix B - Motivations Appendix C - How Do I Make Games? flexible parts, animation and, 427 Appendix D - Guidelines Developing Successful Games 197–98, 219, 396–97. See alsovertex collections flexible vertex formats for (FVF), 163–66, 181–83,193–94, Index
Flight Simulator game, 608
List of Figures
Font List of object, Tables 293, 337 Force Editor, 341 force-feed joysticks, 317,341–46 foreground access to input devices, 303 forms.See alsoscreens;windows game engines in, 60–63 Visual Basic .NET and, 109,129 FPU_Preserve flag, 148 frame rates Direct3D animation and, 179,205–7 multiplayer game start, 544–45 River Pla.Net, 272,275 frames, animation, 424–25 franchise games building upon, 602–3 creating commercial, 631 (see alsocommercial games) industry expectations and, 601–4 realistic game development goals and, 617 sales data, 608–9 successful,603–4 Frankenstein syndrome, 53
Frogger game, 599,605
.NET Game Programming with DirectX 9.0
FromARGB method, 166,194–95 by Alexandre Santos Lobão and Ellen Hatton FromHDC method, 6–7
ISBN:1590590511
Apress © 2003 (696 pages)
FromHwnd method, 6
The authors of this text show how easy it can be to produce
FromImage method, 6 interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
full-screen mode,version 167,168, 186–87 of Microsoft's Visual Studio. full scrollers, 212 fun, player commercial games and, 630–31 .NET Game Programming with DirectX 9.0 interesting decisions as, 629–30 Foreword low-end games and, 601
Table of Contents
Preface
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index G
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce Galaga game, 622
interesting multimedia games using Managed DirectX 9.0 and
programming with Visual Basic .NET on Everett, the latest game development, 617-26.See also .NET game programming version of Microsoft's Visual Studio. budgets and schedules vs. quality, 634 building understanding of, 623 compromises, 596-98 Table of Contents costs,597 .NET Game Programming with DirectX 9.0 financial expectations, 624-25 Foreword first level Tetris-like games, 618-19 Preface guidelines for commercial, 627-34 (see alsocommercial games) Introduction polishing games, 622-23 Chapter 1 in- finished .Nettrix:games, GDI+ and pride 625Collision Detection Chapter 2 .Netterpillars: Artificial second level games, 619-22 Intelligence and Sprites Chapter 3 - small, Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ starting 617-18 Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
GameDev.Net site, 611
game engines Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow in forms, 61 Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Magic KindergarteN, 376-78,402-3 Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Magic KindergarteN II, 462-69 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 program main and, 97 Nonmanaged Code .Netterpillars,88-91,94-97,106-10,115-24 Bonus Chapter Porting .Nettrix to Pocket PC .Netterpillars II, 532-38 Appendix A - The State of PC Gaming .Nettrix, 27-29,60-63 Appendix B - Motivations in Games .Nettrix II, 586-87 Appendix C - How Do I Make Games? River Pla.Net, 218-25,260,262-63,277 Appendix - Guidelines for339-41 Developing Successful Games RiverDPla.Net II, 316, Indexscrolling and, 213 List of Figures
game fields. See alsoscreens collision detection and, 17-21 Magic KindergarteN, 376 .Netterpillars,86,87,100,131 .Netterpillars II, 533-38 .Nettrix, 29-30,53-60,66 .Nettrix II, 589-93 neverending, 289 River Pla.Net, 251-56,262-71,289
List of Tables
GameFont class, River Pla.Net II, 292-95,337-39 game limit, 613 GameMusic class, River Pla.Net, 239-49,283-85,339 game over screens. See alsoending games .Netterpillars,131-32,138-40 .Netterpillars II, 542-43 game physics artificial intelligence vs., 72 game engines and, 95 (see alsogame engines) gameplay.See alsoplaying accessible, in first fifteen minutes, 630 Alice game, 596 basic,623
consumer expectations, 598 .NET Game Programming with DirectX 9.0 design and, 629 ISBN:1590590511 by Alexandre Santos Lobão and Ellen fun (seefun, player) Hatton high-end games, 599-600 Apress © 2003 (696 pages) innovative,628-29 The authors of this text show how easy it can be to produce realism or historical information vs., 634 interesting multimedia games using Managed DirectX 9.0 and technology vs., 602-4 programming with Visual Basic .NET on Everett, the latest testing,629 version of Microsoft's Visual Studio. 3D environments vs., 598-99 game programming. See.NET game programming
Table of Contents
gamers. See players .NET Game Programming with DirectX 9.0 Foreword GameSound class, River Pla.Net, 236-39,283-85 Preface
gaming market. SeePC gaming market
Introduction
garbage collection - .Nettrix: GDI+ and Collision Detection Direct3D application, 171,184-85 Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites Dispose method, 86,109,171,184-85,233 Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ .Netterpillars,86,140 Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio sprite,233 Chapter 1
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Gauntlet game, 623
GDI+ 7 Chapter
- Magic KindergarteN. II: Animation Techniques and Speech API alpha 2,188-89 Chapter 8 blending, - .Netterpillars II: Multiplayer Games and Directplay
antialiasing, 4 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - splines, 3 cardinal Nonmanaged Code DirectX vs., 207-8.Nettrix to Pocket PC Bonus Chapter Porting gradients, 2,7-9, 564 Appendix A - The State of PC Gaming Graphics objects, 4-7 Appendix B - Motivations in Games
mobile devices and, 580 .Netterpillars game and, 70 (see also.Netterpillars game) Appendix D - Guidelines for Developing Successful Games .Nettrix game and, 1 (see also.Nettrix game) Index matrix transformations, 3 List of Figures sprites (seesprites) Appendix C - How Do I Make Games?
List of Tables
genre, game, 24,628 GetDeviceCaps method, 170,175-77 Get/End Get blocks, 126 GetHdc method, 6-7 GetMaster methods, 243 GetMotifCount method, 245 GetMotifName method, 248 GetStyle method, 245 ghost objects, 19 golden paths, 74,490 GotFocus event, 584 gradients,2,7-9,564 grammar, speech recognition, 437 grand endings, 616.See alsoending games graphical adventure games, 350.See alsoadventure games graphics antialiasing,4 commercial games and, 631
libraries,79 .NET Game Programming with DirectX 9.0 objects (seeGraphics objects) by Alexandre 3-D (seeDirect3D; graphics,Santos 3-D) Lobão and Ellen Hatton 2-D (seeGDI+) Apress © 2003 (696 pages) Visual Basic .NET routines, 60
ISBN:1590590511
The authors of this text show how easy it can be to produce
graphics, 3-D. See alsoDirect3D interesting multimedia games using Managed DirectX 9.0 and programming with21-22 Visual Basic .NET on Everett, the latest collision detection algorithms, version of Microsoft's Visual Studio. coordinate systems, 152-59 gameplay vs., 599-600,603 unsuccessful movement of games to 3D environments, 598-99 Table of Contents Graphics 4-7 with DirectX 9.0 .NET Game objects, Programming creating, from images, 6 Foreword creating, from specified handles to device contexts, 6-7 Preface creating, with e parameter, 5 Introduction
creating, with window handles, 6 - .Nettrix: GDI+ and Collision Detection drawing sprites, 81-82 (see alsosprites) Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites for Pocket PC, 584 Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ releasing memory, 86 Chapter 1
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
GraphicsPath objects, 8,II: 553-56 Chapter 5 - River Pla.Net DirectInput and Writing Text to Screen greater6rewards known and Adventure unknown occurrence, 612-13 Chapter - Magicwith KindergarteN.: Games, ADO.NET, and DirectShow Chapter - Magic 481-82 KindergarteN. II: Animation Techniques and Speech API groups,7network, Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
guides, compiling animation, 434-35
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index H
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
authors of this text show how easy it can be to produce hackers, 483–85,The 488–89
interesting multimedia games using Managed DirectX 9.0 and
programming with Visual Basic .NET on Everett, the latest Half Life game, 606 version of Microsoft's Visual Studio.
half-to-half tiles, 216 handles
Tablecreating of Contents Graphics objects from specified, for device contexts, 6–7 .NETcreating Game Programming with DirectX 9.0 Graphics objects from window, 6 Foreword DirectX window, 150 Preface
Handles keyword, 5,196
Introduction
hardware abstraction layer (HAL), 147
Chapter 1
- .Nettrix: GDI+ and Collision Detection hardware See DirectX Chapter 2 acceleration. - .Netterpillars: Artificial Intelligence and Sprites Chapter 3 - Managed DirectX flag, First 147 Steps: Direct3D Basics and DirectX vs. GDI+ HardwareVertexProcessing Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Hassanpour, Sarbasst, 611 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
head positions, mouth animation and, 433
hearing7distance player sounds, 78 Chapter - Magic and KindergarteN. II: Animation Techniques and Speech API Chapter help resources 8 - .Netterpillars II: Multiplayer Games and Directplay
ADO.NET, 357 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code animation guides, 434–35 Bonus Chapter Porting .Nettrix artificial intelligence, 79 to Pocket PC Appendix declarative A - Theattributes, State of PC 558 Gaming DirectX 143,170, 234,243,344 Appendix B - SDK, Motivations in Games forms, Appendix C 109 - How Do I Make Games? Internet, 9 (see also Web sites) Successful Games Appendix D - Guidelines for Developing matrix transformations, 158 Index .NET Framework SDK, 4,9 List of Figures object-oriented analysis, 30 List of Tables Chapter 9
Hide method Block class, 50–51 Square class, 32–35 hiding latency from players, 487–88 high-end consumer expectations, 599–600 hints, 614 historical information, commercial games and, 634 horizontal scrollers, 212,620–21 hosts, DirectPlay, 491,493 Howland, Geoff, 617 hype, promotional, 595–96.See alsoadvertisements
Index I
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce icons,352,394–401
interesting multimedia games using Managed DirectX 9.0 and
programming with Visual Basic .NET on Everett, the latest id software, 596,599, 610 version of Microsoft's Visual Studio.
IIF commands, 139
images.See alsoGDI+ Tableanimating of Contents parts of, 430–32 (see alsoanimation) .NETblitting, Game Programming 82,144,145 with DirectX 9.0 Foreword creating Graphics objects from, 6 Preface loading, for scrolling, 214 Introduction point-and-click adventure games, 352
sprites sprites) Chapter 1 -(see .Nettrix: GDI+ and Collision Detection Chapter 2 commercial - .Netterpillars: Artificial imitation, games and,Intelligence 628–29 and Sprites Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Imports clause, 222
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
industry expectations, 597,601–3 - River Pla.Net II: DirectInput and Writing Text to Screen Inherits6keyword, 230 Chapter - Magic 102, KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 5
Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API initialization. See also New method Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay Direct3D and game map, 268
Direct3D D-iNfEcT: application, Multithreading, 179–80,198–99 Nonrectangular Windows, and Access to Nonmanaged Code joystick,304–5 Bonus Chapter Porting .Nettrix to Pocket PC Magic KindergarteN, 383–85 Appendix A class, - The State of PC Gaming music 240–43 Appendix mouse B -and Motivations keyboard, in Games 301–4 player Appendix C objects, - How Do277 I Make Games? Chapter 9
Appendix D - commercial Guidelines for Developing Successful Games innovation, games and, 628–29 Index
input classes, DirectInput, 297–301.See also River Pla.Net II game
List of Figures
input devices. See alsojoystick;keyboard;mouse class interfaces, 299–301 DirectInput and, 145,291,295 handling data from, 330–32 polling, 306–8 processing input from, 308–15
List of Tables
instruments, DirectMusic, 245 interesting decisions, commercial games and, 629–30 interface classes, 97 interfaces.Seeclass interfaces;user interfaces international audience, 355 Internet.See alsoWeb sites collision detection algorithms, 9 never trusting, 490–91 introduction screens finishing games with, 621 Magic KindergarteN, 386 main program and, 97 .Netterpillars,98–99,129–31 .Netterpillars II, 524–27 River Pla.Net, 261,270
Invalidate method, 60
.NET Game Programming with DirectX 9.0
inventory by Alexandre Santos Lobão and Ellen Magic KindergarteN, Hatton 361, 410–17 point-and-clickApress adventure 351 © 2003game, (696 pages)
ISBN:1590590511
investments, player, The 633 authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
IsEmpty method,programming 42,51,54–56with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
J
ISBN:1590590511
Join method, 552The authors of this text show how easy it can be to produce
interesting multimedia games using Managed DirectX 9.0 and
programming with Visual Basic .NET on Everett, the latest joystick version of Microsoft's Studio. adding support for force-feed, 317,Visual 341–46 class interface, 301 controlling plane with, 316 Table of Contents DirectInput and, 295,297,319–21 .NET Game Programming with DirectX 9.0 initialization code, 304–5 Foreword polling, 306–8 Preface processing input, 313–15 Introduction
jumping animations, 426–29 - .Nettrix: GDI+ and Collision Detection
Chapter 1 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
K
ISBN:1590590511
The authors of this text show how easy it can be to produce keyboard adventure games and, 348–50 interesting multimedia games using Managed DirectX 9.0 and class interface, 300 programming with Visual Basic .NET on Everett, the latest DirectInput and, 295,297, 319–21 Visual Studio. version of Microsoft's Esc key, 65–66,109,138,185 events,297 Tableinitialization of Contents code, 301–4 .NETKeyDown Game Programming with DirectX 9.0 event, 63,65–66, 109,278 Foreword KeyPress event, 27,319 Preface Keys enumeration, 52,308 Introduction logo key, 303 .Netterpillars, 117–18,138 Chapter .Nettrix, 1 -27, .Nettrix: 52,63,GDI+ 65–66and Collision Detection .Nettrix 592–93 Chapter 2 -II,.Netterpillars: Artificial Intelligence and Sprites polling, Chapter 3 -306–8 Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ processing input, 308–11 Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio River 278–79II: DirectInput and Writing Text to Screen Chapter 5 Pla.Net, - River Pla.Net Chapter key frames, 6 - Magic animation, KindergarteN.: 424 Adventure Games, ADO.NET, and DirectShow Chapter - Magic KindergarteN. II: Animation known 7occurrence, greater rewards with, 612Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index L
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce latency interesting multimedia games using Managed DirectX 9.0 and hiding, from players, 487-88with Visual Basic .NET on Everett, the latest programming turn-based game, 483of Microsoft's Visual Studio. version
left-handed coordinate systems, 153 Left of method, Block class, 41-44 Table Contents .NET Game Programming Lego Island game, 605,with 609 DirectX 9.0 Foreword
Leisure Suit Larry games, 350
Preface
Lemmings game, 598
Introduction
letters to 609-10 Chapter 1 developers, - .Nettrix: GDI+ and Collision Detection Chapter levels 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3 - intelligence Managed DirectX artificial and, First 73 Steps: Direct3D Basics and DirectX vs. GDI+ Chapter balanced 4 - River games Pla.Net: and, Tiled 490 Game Fields, Scrolling, and DirectAudio
Breakout, 620 Pla.Net II: DirectInput and Writing Text to Screen Chapter 5 - River multiple gaming experiences Adventure and, 632 Games, ADO.NET, and DirectShow Chapter 6 - Magic KindergarteN.: .Nettrix 65-66 Chapter 7 -feature, Magic KindergarteN. II: Animation Techniques and Speech API rewards and, 613,616II: Multiplayer Games and Directplay Chapter 8 - .Netterpillars River Pla.Net game map and, 289 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter side9scroller games, Nonmanaged621 Code Bonus Chapter Porting .Nettrix to Pocket PC libraries Appendix A - The State of PC Gaming animation guides, 434-35 Appendix artificial B - intelligence, Motivations in79 Games
D3DX, Appendix C 158 - How Do I Make Games? Appendix D - Guidelines for167-69, Developing Successful Games lights, Direct3D colored, 193-97 Index
linear games, 627
List of Figures
linear gradients, 7-8
List of Tables
LineList type, Direct3D, 161 line of sight algorithms, 76-78,79 LineStrip type, Direct3D, 161 list box items, 500 listing existing sessions on remote computers, 505-12 ListVoiceNames method, 444-45 Loader objects, 235 loading active objects, 321-24 forms,63 game map, 264-68 list of adapters, 171 mouth images, 443-44 sound files, 235,238,243-45 transparent textures, 231-32 Lobby object, 493 local area networks (LANs), 479 Lode Runner game, 598 loops, game, 619
low-end consumer expectations, 600-601
.NET Game Programming with DirectX 9.0
Lupine Games, 617 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Hatton Apress © 2003 (696 pages) The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index M
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce McGee, American, 595-96
interesting multimedia games using Managed DirectX 9.0 and
programming with Visual Basic .NET KindergarteN on Everett, theII latest Magic KindergarteN game, 347-421. Seealso Magic game version of Microsoft's Visual Studio. active objects, 371-74,378-79 ADO.NET and data access, 355-58,383-94 adventure games and, 347-55 Table of Contents class diagram, 376-80 .NET Game Programming with DirectX 9.0 coding phase, 382-83 Foreword data model, 381-82 Preface DirectShow and, 358-61,407-9 Introduction drawing characters, 369-71 Chapter 1 - .Nettrix: GDI+ and Collision Detection extended storyline suggestion, 417-20 Chapter 2 .Netterpillars: Artificial Intelligence and Sprites game engine, 376-78 Chapter 3 Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ mouse pointer, 394-401 Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio mouse pointer actions, 402-9 Chapter 5 River Pla.Net II: DirectInput and Writing Text to Screen planning main program flow, 382 Chapter player, 6 379-80, - Magic 410 KindergarteN.: Adventure Games, ADO.NET, and DirectShow player inventory, 410-17II: Animation Techniques and Speech API Chapter 7 and - Magic KindergarteN. project, Chapter 8 -362-82 .Netterpillars II: Multiplayer Games and Directplay proposal,D-iNfEcT: 361-62 Multithreading, Nonrectangular Windows, and Access to Chapter 9 screens,Nonmanaged 363-69 Code user interface elements, Bonus Chapter Porting .Nettrix 374-75 to Pocket PC Appendix A - The StateIIof PC Gaming Magic KindergarteN game, 423-76.See also Magic KindergarteN game Appendix B Motivations in active objects, 450-51,Games 457-59 Appendix C - How Do I Make Games? character animation, 423-35 Appendix characters, D - Guidelines 449-50 for Developing Successful Games Indexcheese puzzle, 460-62
class diagram, 454-55 List of Figures coding List of Tablesphase, 457 compiling animation guides, 434-35 data model, 456 dialogs,451-53,457-59,462-73 letting player choose character's speech, 465-69 mouse pointer for talk action, 459-60 mouth animation, 473-75 presenting dialog choices on screen, 463-65 project, 449-56 proposal,448 reviewing code, 469-71 screens, 449 Speech API, 435-39 speech generation, 439-48,473-75 suggested improvements, 475-76 technical tips, 430-34 user interface elements, 454 magnitude, force-feed joystick, 342 main programs artificial intelligence and, 136 Magic KindergarteN, 382 .Netterpillars,97-98,106-10,115-19,136-37 .Netterpillars II, 522-27
River Pla.Net, 261,270-71
.NET Game Programming with DirectX 9.0
main windows by Alexandre Santos Lobão and Ellen ISBN:1590590511 Direct3D application, Hatton 168, 170-78 D-iNfEcT,559-66, 573© 2003 (696 pages) Apress point-and-clickThe adventure game, 351show how easy it can be to produce authors of this text interesting multimedia games using Managed DirectX 9.0 and MakeTransparent, 82
males,628
programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
managed DirectX. SeeDirectX Manager object, 146,170 Table of Contents .NET Game Programming with DirectX maps, game. See alsogame fields 9.0 Foreword empty map games, 627 (see alsocommercial games) Preface neverending, 289
text file and, 256,262-71 Introduction Chapter - PC .Nettrix: GDI+ and Collision Detection market.1See gaming market Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Math object, 60
matrix transformations - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Direct3D,155-58,169 Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen mouse pointer icons, 398-99 Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow scrolling and, 256-57,271-73,277-78 Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API testing,197-205 Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay types of, 3 Chapter 4
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Mech Commander game, 608 Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC media, streaming. See alsoDirectShow Appendix A - 627 The State of PC Gaming Meier, Sid, Appendix B - Motivations in Games
memory garbage collection (seegarbage collection) Appendix D - Guidelines for Developing Successful Games multithreading (seemultithreading) Index scrolling and, 214 List of Figures tiles and, 215 Appendix C - How Do I Make Games?
List of Tables
menus,621,632.See alsouser interfaces messages checking delivery, 489 defining types and sizes, 486-87 formats, 527-29 handling,514-16,538-41 methods that receive, 530-32 methods that send, 529-30 .Netterpillar II, 520-21,527-32 methods.See alsoclass interfaces base class, 102,222 conversion,267 overloading,85,102 scope modifiers, 222-23 Shadows keyword and, 103 shared,35 speech generation, 445-46 sprite,80 Visual Basic .NET, 60 Microsoft Access database, 381-82,387-94 Microsoft Visual Basic .NET. SeeVisual Basic .NET
Microsoft Visual Studio .NET. SeeVisual Studio .NET
.NET Game Programming with DirectX 9.0
Microsoft Windows. SeeWindows by Alexandre Santos Lobão and Ellen Hatton MIDI files, 234
ISBN:1590590511
Apress © 2003 (696 pages)
migration, program. Seemobile devices;.Nettrix II game milestones,78 MindArk,611
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
MixedVertexProcessing, 147 mobile devices, 575-80 choosing platform and project type, 577 .NET Game Programming with DirectX 9.0 creating Smart Device Applications, 576 Foreword deploying programs to emulator, 577-80 Preface .Net Framework and, 575 Introduction porting .Nettrix to (see.Nettrix II game) Chapter 1 - desktop .Nettrix: PC GDI+ and Collision Detection systems on, 580-81 running programs and operating
Table of Contents
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
modal and modeless forms, 129
modem providers, 492 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio monitor5 refresh 173 Chapter - Riverrates, Pla.Net II: DirectInput and Writing Text to Screen Chapter 4
Chapter 6 -game, Magic 609 KindergarteN.: Adventure Games, ADO.NET, and DirectShow Monopoly Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API motifs, music, 245-48
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
motivations, player, 611-16 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 anticipation, 614 Nonmanaged Code competition and comparison, 614 PC Bonus Chapter Porting .Nettrix to Pocket complex user interfaces and, 616 Appendix A - The State of PC Gaming elements, 611 Appendix B - Motivations in Games grand endings, 616 Appendix C - How Do I Make Games? participant-ship,615 Appendix D - Guidelines for Developing Successful Games rewards,612-13 Index tempo,615 List of Figures
mouse class interface, 300 DirectInput and, 295,297 initialization code, 301-4 MouseMove event, 192 point-and-click adventures, 351-52 pointer (seemouse pointer) polling, 306-8 processing input, 311-13
List of Tables
mouse pointer. See alsomouse actions,361,402-9 coding,394-401 icons,375 for talk action, 459-60 mouth animation mouth positions and sounds, 432-34 speech generation and, 438-48,473-75 movie tie-in games, 605,606 moving objects bullets, 333-35 collision detection, 327-29 (see alsocollision detection) child windows, 569-70
enemies,321-29 .NET Game Programming with DirectX 9.0 player characters, 277-80 by Alexandre Santos Lobão and Ellen ships and planes, 316-17,324-26
ISBN:1590590511
Hatton MPEG video files,Apress 347 © 2003 (696 pages)
MP3 sound files, The 347authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
multimedia.SeeDirectShow programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio. multiplayer games, 477-82 artificial intelligence and, 488 balanced, 490 Table of Contents client-server connections, 479-80 .NET Game Programming with DirectX 9.0 coding, from ground up, 486 Foreword communities for, 488 Preface connection types, 478-82 Introduction constant world vs. context-based, 484-85 Chapter 1 - .Nettrix: GDI+ and Collision Detection DirectPlay and, 145, 482, 491-93 Chapter 2 latency - .Netterpillars: Artificial Intelligence and Sprites hiding from players, 487-88 Chapter 3 - Managed DirectX Steps: Direct3D Basics and DirectX vs. GDI+ message types and sizes,First 486-87 Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio multithreading and, 489-90 Chapter .Netterpillars 5 - RiverIIPla.Net features, II: DirectInput 532-41 (seeand alsoWriting .Netterpillars Text toIIScreen game) never trusting the Internet, 490-91 Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow peer-to-peer 478-79 Chapter 7 - Magicconnections, KindergarteN. II: Animation Techniques and Speech API planning, 482-85, 485-91 Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay preventing cheating, 488-89 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 ring topology, network groups, broadcasting, 481-82 Nonmanaged Code screen freeze problem, Bonus Chapter Porting .Nettrix477-78 to Pocket PC testing, 489 Appendix A - The State of PC Gaming turn-based vs. real-time, 483-84 Appendix B - Motivations in Games Appendix multiple Cgaming - How Do experiences I Make Games? within games, 632 Appendix D - Guidelines for Developing Successful Games MultiThreaded flag, 148 Index
multithreading,548-52 avoiding errors, 550-52 List of Tables creating multiple threads, 549-50 D-iNfEcT, 566-69 (see alsoD-iNfEcT game) DirectInput and, 296 DirectSound and, 237-38 DirectX and, 148 multiplayer games, 489-90 polling input devices, 306-8 processes, threads, and, 548-49 List of Figures
Mushroom class, 92,102 music, commercial games and, 631.SeealsoDirectMusic;DirectShow MyBase keyword, 102 Myst game, 603-4,605,608
Index N
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce namespaces,5,222
interesting multimedia games using Managed DirectX 9.0 and
programming naming conventions, 105,111 with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
narrative.Seestoryline navigation
TableMagic of Contents KindergarteN, 404-6 .NET.Nettrix Game Programming II, 592-93 with DirectX 9.0 Foreword
.NET Compact Framework, 576,579
Preface
.NET Framework. See also.NET game programming;Visual Basic .NET;Visual Studio .NET COM objects and, 233 Chapter 1 - .Nettrix: GDI+ and Collision Detection constants and enumerations, 52 Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites garbage collection, 140 Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ mobile devices and, 575 Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio new features, 5 Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen nonmanaged code and, 556 Chapter 6 4,-9 Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow SDK, Introduction
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
.NET game programming - .Netterpillars II: Multiplayer Games and Directplay ADO.NET data access, 355-58 (see also ADO.NET data access) D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter adventure 9 games, 347-55 Nonmanaged Code animation, 423-35 (see alsoanimation) Bonus Chapter Porting .Nettrix to Pocket PC artificial intelligence, 69,72-79 Appendix A - The State of PC Gaming collision detection, 9-22 Appendix B - Motivations in Games D-iNfEcT game (seeD-iNfEcT game) Appendix C - How 233-36 Do I Make Games? DirectAudio, (see also DirectAudio;DirectMusic;DirectSound) Appendix D - Guidelines for(see Developing Successful Games DirectInput, 295-315 also DirectInput) IndexDirectPlay,491-93 List of Figures DirectShow, 358-61 List of Tables and DirectX (seeDirect3D; DirectX) Direct3D game development, 617-26 GDI+,1-9,70 guidelines for commercial games, 627-34 (see alsocommercial games) Magic KindergarteN game (seeMagic KindergarteN game;Magic KindergarteN II game) for mobile devices, 575-81 multiplayer games, 477-91 multithreading,547-52 .Netterpillars game (see.Netterpillars game; ..Netterpillars II game) .Nettrix game (see.Nettrix game;.Nettrix II game) nonmanaged code access, 556-58 nonrectangular windows, 553-56 object-oriented programming, 70-72 PC gaming market, 595-610 (see alsoPC gaming market) player motivations, 611-16 River Pla.Net game (seeRiver Pla.Net game;River Pla.Net II game) scrolling games, 211-14 sprites, 80-86 (see alsosprites) Speech API, 435-48 (see alsoSpeech API) tile-based games, 214-17 writing text to screen, 291-95 Chapter 8
Netterpillar class, 91-92,110-15 .Netterpillars game, 69-141.See also.Netterpillars II game
AINetterpillar class, 93-94,132-36 .NET Game Programming with DirectX 9.0 artificial intelligence, 72-79,132-37 ISBN:1590590511 Alexandre Branch class,by 92-93, 103-6Santos Lobão and Ellen Hatton classes,88-97 Apress © 2003 (696 pages) coding phase, 101 The authors of this text show how easy it can be to produce collision detection, 119-24 interesting multimedia games using Managed DirectX 9.0 and components,69-70 programming with Visual Basic .NET on Everett, the latest configuration screen, 99, 124-29 Visual Studio. version of Microsoft's game engine, 94-97,115-24 game field, 99-100 Tablegame of Contents over screen, 131-32,138-40 .NETgarbage Game Programming with DirectX 9.0 collection, 140 Foreword introduction screen, 98-99,129-31 Preface main program, 106-10,115-19 Introduction main program structure, 97-98,136-37 Chapter Mushroom 1 - .Nettrix: class,GDI+ 92,102 and Collision Detection Netterpillar class, 91-92, 110-15 Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites new3spider characters, 141 Chapter - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ object-oriented programming and,Fields, 70-72Scrolling, and DirectAudio Chapter 4 - River Pla.Net: Tiled Game pause 138 II: DirectInput and Writing Text to Screen Chapter 5 feature, - River Pla.Net player 91-92,110-19 Chapter 6 character, - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow project, 88-101 Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API proposal,87 Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay screens, 98-100 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -80-86, 91, 101 sprites, Nonmanaged Code static objects, 101-10 Bonus Chapter Porting .Nettrix to Pocket PC .Netterpillars II game, 477-545. See also.Netterpillars game Appendix A - The State of PC Gaming coding 524 in Games Appendix B -phase, Motivations connecting toDo remote sessions, Appendix C - How I Make Games? 512-13 creating and destroying sessions, Successful 502-5 Appendix D - Guidelines for Developing Games
DirectPlay and, 491-93 game engine and multiplayer features, 532-41 List of Figures game over screen, 542-43 List of Tables handling messages, 514-16 introduction screen, 524-25 listing existing sessions on remote computers, 505-12 main program, 525-27 managing players, 513-14 multiplayer games and, 477-91 NetworkGame class interface, 493-97 NetworkNetterpillars class, 527-32 project, 520-24 proposal,519-20 service provider methods, 498-502 session methods, 502-13 smoothing game start, 544-45 testing,516-19 Index
.Nettrix game, 1-68 Block class, 37-53 (see alsoBlock class) class diagram, 25-27,29-30 coding phase, 31 collision detection and, 9-22 configuration screen, 67 game engine, 27-29,60-63 game field class, 53-60
GDI+ and, 1-9 levels feature,.NET 66 Game Programming with DirectX 9.0 ISBN:1590590511 by Alexandre next block feature, 63-65 Santos Lobão and Ellen Hatton pause feature, 65-66 Apress © 2003 (696 pages) porting, to Pocket PC. (see.Nettrix II game) project, 24-30 The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and proposal,23-24 programming with Visual Basic .NET on Everett, the latest Square class,version 31-37 of Microsoft's Visual Studio. window redraw feature, 66 .Nettrix II game, 575-94 adapting code to build for Pocket PC target, 583-86 .NET Game Programming with DirectX 9.0 coding phase, 583 Foreword increasing game rewards, 593-94 Preface mobile devices and, 575-81 Introduction project, 581-83 Chapter 1 - .Nettrix: GDI+ and Collision Detection proposal, 581 Chapter 2 .Netterpillars: Artificial Intelligence and Sprites updating Block class, 588-89 Chapter 3 Managed DirectX First 586-87 Steps: Direct3D Basics and DirectX vs. GDI+ updating game engine class, Chapter 4 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio updating game form, 589-93 Chapter 5 River Pla.Net II: DirectInput and Writing Text to Screen updating Square class, 587-88
Table of Contents
Chapter 6 Address - Magic Translation KindergarteN.: Adventure Network (NAT), 491 Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
network connections. Seeconnections
networked or network-enabled games. Seemultiplayer gamesand Access to D-iNfEcT: Multithreading, Nonrectangular Windows, Chapter 9 Nonmanaged Code NetworkGame class, 493-519 Bonus Chapter Porting .Nettrix to Pocket PC class interface, 493-97 Appendix A - The State of PC Gaming handling messages, 514-16 Appendix B - Motivations in Games managing players, 513-14 Appendix service C -provider How Do methods, I Make Games? 498-502 session methods, 502-13 Appendix D - Guidelines for Developing Successful Games Indextesting, 516-19 List of Figures network groups, 481-82 List of Tables
NetworkNetterpillars class, 527-32 message formats, 527-29 methods that receive messages, 530-32 methods that send messages, 529-30 neural networks, 75-76 neverending game maps, 289 New method. See alsoinitialization Block class, 39-41 Branch class, 104-5 GameFont class, 293-94 GameSound class, 237-38 Player class, 274-75 PlayerVoice class, 443-44 Sprite class, 83-85,230-31 Square class, 32-35,36 Visual Basic .NET, 37 next block feature, .Nettrix, 63-65 nonexclusive input device access, 303 nonmanaged code, 556-58,571-72 nonplayer characters (NPCs). See alsoplayer characters adventure game, 353
computer-controlled,73,95,488 .NET Game Programming with DirectX 9.0 line of sight algorithms and, 76-78 ISBN:1590590511 by Alexandre Santos Lobão and Ellen Magic KindergarteN, 369-71, 417-20 Hatton Magic KindergarteN II, 449-50 Apress © 2003 (696 pages) .Netterpillars,141 The authors of this text show how easy it can be to produce side scroller games, 621 interesting multimedia games using Managed DirectX 9.0 and
programming with Visual Basic .NET on Everett, the latest nonrectangular objects version of Microsoft's Visual Studio. collision detection, 12-13 sprites,81-82 windows,553-56,561-66 Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index O
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce objectives.Seeproposals
interesting multimedia games using Managed DirectX 9.0 and
programming with object-oriented analysis (OOA), 70 Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
object-oriented programming (OOP) drafts and, 95 projects and, 25 Tablegame of Contents overload, 85with DirectX 9.0 .NETmethod Game Programming Rational Unified Process (RUP), 81 Foreword terminology, 70-72 Preface Visual Basic .NET and, 102 Introduction objects1 Chapter
- .Nettrix: GDI+ and Collision Detection active active objects) Chapter 2 (see - .Netterpillars: Artificial Intelligence and Sprites
behavior of, 72 (see alsoartificial intelligence) Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ DirectX, Chapter 4 - 144-45 River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio moving moving Chapter 5 - (see River Pla.Netobjects) II: DirectInput and Writing Text to Screen
nonrectangular (seenonrectangular objects) - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow OOP and, 70 Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API sprites (seesprites) Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay static,101-10 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Basic Visual .NET, 60 Nonmanaged Code Chapter 6
objectChapter variables, 6 .Nettrix to Pocket PC Bonus Porting Appendix A - The State612-13 of PC Gaming occurrence, reward, Appendix B - Motivations in Games
opening sequences, animation, 476.See alsostarting games
Appendix C - How Do I Make Games?
operating systems, mobile devices and, 580-81.See alsoWindows
Appendix D - Guidelines for Developing Successful Games
operators, comparison, 55 Index List of Figures opposing player AI, 73 List of Tables originality vs. practicality, 601
optimizing collision calculations, 17-21 tiled game field approach, 17-18 zoning with arrays of bits approach, 20-21 zoning with bits approach, 18-20 orthogonal projection, 154,199,271 overload keyword, 85 overloads, method, 102 Overrideable keyword, 222 Overrides keyword, 222
Index P
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Pac-Man game, 620-21 version of Microsoft's Visual Studio.
pacing,630
PaintEventArgs class, 5 Paint events, 4-5 Table of Contents
Pajitnov, Alexey, 619
.NET Game Programming with DirectX 9.0
parallax scrolling, 212-13 Foreword Preface parameters
creating Graphics objects with e, 5 Introduction DirectX 180,186, 199 Chapter 1 - presentation, .Nettrix: GDI+148-50, and Collision Detection porting and, 584 Chapter 2 -games .Netterpillars: Artificial Intelligence and Sprites Chapter 3 - Managed DirectX participant-ship, player, 615 First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter - River animating, Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio parts of4images, 430-32 Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
path boxes, 79
path finding, 78-79KindergarteN. II: Animation Techniques and Speech API Chapter 7 - Magic Chapter PathGradientBrush 8 - .Netterpillars objects, II: Multiplayer 8-9 Games and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to path gradients, 2,7-9,32-36 Chapter 9 Nonmanaged Code
pathsChapter Porting .Nettrix to Pocket PC Bonus
audio,242 dialog, 452-53 Appendix B - Motivations in Games game development (seegame development) Appendix C - How Do I Make Games? graphics,8,553-56 Appendix A - The State of PC Gaming
Appendix D - Guidelines for Developing Successful Games
pause game features Index
.Netterpillars,138 .Nettrix, 65-66 List of Tables River Pla.Net II, 339-41 List of Figures
Pause method, 360 PC gaming market, 595-610 advertisements,595-97 analyzing market trends, 604-9 broad audiences, 628 compromises in development, 596-98 conclusions,609-10 consumer expectations, 597-601 franchise games, 602-4 guidelines for commercial games, 627-34 (see alsocommercial games) high-end games, 599-600 industry expectations, 597,601-3 low-end games, 599-601 originality vs. practicality, 601 sequels, 600-604,608 unsuccessful movement of games into 3D environments, 598-99 value and gameplay, 598 Peer objects, 493,499-500,502,506,512 peer-to-peer connections, 478-79 performance
alpha blending, 189 .NET Game Programming with DirectX 9.0 DirectInput,295 ISBN:1590590511 Alexandre Santos Lobão and Ellen drawing tiles, by 289-90 Hatton fast drawing of sprites, 81-82 Apress © 2003 (696 pages) garbage collection and, 140 The authors of this text show how easy it can be to produce optimizing collision calculations, 17-21 interesting multimedia games using Managed DirectX 9.0 and Pocket PC, 585 programming with Visual Basic .NET on Everett, the latest version of246-47 Microsoft's Visual Studio. Performance object, 235,
periodic effect, 342 Table of Contents perspective projection, 154-55 .NET Game Programming with DirectX 9.0
Phantom's Revenge game, 348
Foreword
physics.Seegame physics Preface pinball games, 72 Introduction Chapter 1 - .Nettrix: GDI+ and Collision Detection piracy,610 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
plane sprites Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ joystick- control of, 316 Chapter 4 River Pla.Net: moving,316-17, 324-26Tiled Game Fields, Scrolling, and DirectAudio Chapter 5 River Pla.Net DirectInput and Writing Text to Screen shooting feature, 317,II: 332-33 Chapter 3
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
planning - Magic KindergarteN. II: Animation Techniques and Speech API adventure games, 353-55,385 Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay multiplayer games, 482-91 Chapter 7
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 player characters. See also nonplayer characters (NPCs);players Nonmanaged Code
adventure game, .Nettrix 353 Bonus Chapter Porting to Pocket PC bumpers around, Appendix A - The State 78 of PC Gaming
including voices for all, 476 Magic KindergarteN, 369-71,379-80,405,410 Appendix C - How Do I Make Games? .Netterpillars,88-92,110-19 Appendix D - Guidelines for Developing Successful Games path finding, 78-79 Index River Pla.Net, 259,273-80,285-88 List of Figures River Pla.Net II, 316,317,332-33 Appendix B - Motivations in Games
List of Tables
Player class, 273-80 players. See alsouser interfaces broad audience of, 628 characters (seeplayer characters) choice of character's speech by, 465-69 expectations (seeconsumer expectations) facilitating creation of consumer content by, 633 fun for, 629-31 game communities of, 488,490,609-10 investments in games, 633 market advice to, 609-10 motivations,611-16 multiplayer game, 493,513-14 opposing player AI, 73 rewarding (seerewards) scrolling controlled by, 213 traditional,628 PlayerVoice class, 439-48 playing motifs,247-48 designing games by, 629 DirectMusic music files, 246-47
DirectShow streaming media, 358-60 .NET Game Programming with DirectX 9.0 DirectSound sound files, 239 by Alexandre Santos Lobão and Ellen game (seegameplay)
ISBN:1590590511
Hatton plot.Seestoryline Apress © 2003 (696 pages)
Pocket PC The authors of this text show how easy it can be to produce interesting creating applications for,multimedia 576-77 games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest DirectX,580-81 version of Microsoft's Visual Studio. emulator, 577-80 GDI+ and, 208,580 games to (see.Nettrix II game) Tableporting of Contents .NET Game Programming with DirectX 9.0 point-and-click adventure games, 351-52 Foreword
pointer, mouse. See alsomouse pointer
Preface
PointList type, Direct3D, 160
Introduction
polishing 621-25, Chapter 1 games, - .Nettrix: GDI+634 and Collision Detection Chapter - .Netterpillars: Artificial Intelligence and Sprites polling,2input device, 306-8 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ porting games to mobile devices. See mobile devices;.Nettrix II game
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
posture, revealing emotions by animating, 429-30
power operator (^), 56 Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7 - vs. Magic KindergarteN. practicality originality, 601 II: Animation Techniques and Speech API Chapter 8 -player .Netterpillars predicting moves, II: 74 Multiplayer Games and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 work, pre-play 630 Nonmanaged Code Bonus presentation Chapter parameters, Porting .Nettrix DirectX, to Pocket 148-50, PC 180, 186, 199 Appendix - The State Present Amethod, 151 of PC Gaming Appendix B - Motivations in Games
pride, game development and, 622-25
Appendix C - How Do I Make Games?
primitives, drawing, 159-63 Successful Games Appendix D -Direct3D Guidelines for Developing PrimitiveType enumeration, 160-62 Index List of Figures Private keyword, 222 List of Tables
procedures, property, 99,125-26.See alsomethods processes, threads and, 548-49 production values, 631,634 programming.See.NET game programming;Visual Basic .NET Project-Entropia game, 611 projections, Direct3D, 152-55.See alsocoordinate systems, 3-D projects adventure game, 353 Direct3D application, 167-69 Magic KindergarteN, 362-82 multiplayer game, 485 .Netterpillars,88-101 .Netterpillars II, 482-85,520-24 .Nettrix, 24-30 .Nettrix II, 581-83 purpose of, 250 River Pla.Net, 250-57 River Pla.Net II, 316-18 promotional hype, 595-96 properties.See alsoclass interfaces property procedures, 99,125-26
read-only and write-only, 126 .NET Game Programming with DirectX 9.0 shared,35 by Alexandre Santos Lobão and Ellen sprite,80,82-83
ISBN:1590590511
Hatton Property statement, 126© 2003 (696 pages) Apress
proposals The authors of this text show how easy it can be to produce interesting Direct3D application, 167multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Magic KindergarteN, 361-62 version of Microsoft's Visual Studio. .Netterpillars,87 .Netterpillars II, 519-20 23-24 Table.Nettrix, of Contents II, 581 .NET.Nettrix Game Programming with DirectX 9.0 purpose of, 23,250 Foreword River Pla.Net, 249-50 Preface River Pla.Net II, 315-16 Introduction Protected Chapter 1 -keyword, .Nettrix: 222 GDI+ and Collision Detection Chapter 2 - games, .Netterpillars: Artificial Intelligence and Sprites prototyping 629,634 Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
proximity algorithms, 14-16 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio calculating collisions for diamond-shaped objects, 16 Chapter 5 - River Pla.Net for II: DirectInput and Writing Text to Screen calculating collisions square or circle objects, 14-15 Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow extending, for 3-D, 22 Chapter 4
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
pseudo-code, 60-61,151-52
Public keyword, 222 Multithreading, Nonrectangular Windows, and Access to D-iNfEcT: Chapter 9 Nonmanaged Public Shared statement,Code 35 Bonus Chapter Porting .Nettrix to Pocket PC
publishers,595,597,601-3,617,624-25,631
Appendix A - The State of PC Gaming
PureDevice flag, 148
Appendix B - Motivations in Games
puzzles C - How Do I Make Games? Appendix adventure game, 353-54 Appendix D - Guidelines for Developing Successful Games Indexcheese,460-62 List of Figures List of Tables
Index
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
Q
ISBN:1590590511
The authors of this text show how easy it can be to produce quality, commercial games and, 634
interesting multimedia games using Managed DirectX 9.0 and
programming with604, Visual Quake games, 596, 599-600,601, 617Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
R
ISBN:1590590511
The authors of this text show how easy it can be to produce race conditions, 296
interesting multimedia games using Managed DirectX 9.0 and
programming with Visual Basic .NET on Everett, the latest ramp force, joystick, 342 version of Microsoft's Visual Studio.
randomness,74,93,133-36,284,570 Rational Unified Process (RUP), 81 Table of Contents
ReadLine method, 263
.NET Game Programming with DirectX 9.0
read-only properties, 126 Foreword Preface realism, commercial games and, 634 Introduction real-time games, 483-84,630 Chapter 1 - .Nettrix: GDI+ and Collision Detection
receiving messages, 515-16,530-32
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites recognition, speech, DirectX 436-37.First See Steps: alsoSpeech APIBasics and DirectX vs. GDI+ Chapter 3 - Managed Direct3D
rectangle custom, 12-13. SeeFields, alsononrectangular objects Chapter 4 objects, - River Pla.Net: Tiled Game Scrolling, and DirectAudio Chapter - River Pla.Net II: DirectInput and Writing Text to Screen Redim 5statement, 34 Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
redrawing.See alsodrawing - Magic KindergarteN. II: Animation Techniques and Speech API game fields, 59-60,66 Chapter 8 .Netterpillars II: Multiplayer Games and Directplay sprites,-108 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to windows, Chapter 9 - 66 Chapter 7
Nonmanaged Code
reference rasterizer, 147,171to Pocket PC Bonus Chapter Porting .Nettrix references Appendix A - The State of PC Gaming COMBobjects and, 233 Appendix - Motivations in Games Direct3D, 169Do I Make Games? Appendix C - How Appendix D - Guidelines for Developing Successful Games refresh rates, 173 Index regions, window, 553-56 List of Figures
registry,501-2
List of Tables
reliability, 489 remote sessions connecting to, 512-13 listing,505-12 Render method. See alsodrawing Direct3D application, 184,191-92,202 garbage collection and, 140 main program and, 97 .Netterpillars,107,131,140 .Netterpillars II, 535-38 RiverEngine class, 269 River Pla.Net, 223-25,279,282 replayability,633,613 resolution, tiles and, 251 retread games (sequels), 600-4,608.See alsofranchise games rewards,611-13 game over screen and, 138-40 greater, with known occurrence, 612 greater, with unknown occurrence, 613 increasing, for Pocket PC game, 593-94 relations between, 613
smaller, and more often, 612
.NET Game Programming with DirectX 9.0
R5G6B5 format, by 150Alexandre Santos Lobão and Ellen Hatton right-handed coordinate systems, 153
ISBN:1590590511
Apress © 2003 (696 pages)
Right method, Block class, 41-44
The authors of this text show how easy it can be to produce
ring topology, 481-82 interesting multimedia games using Managed DirectX 9.0 and Riven game, 604,programming 605,608,609with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
RiverEngine class, 262-73 River Pla.Net game, 211-90.See also River Pla.Net II game class diagram, 257-60 .NET Game Programming with DirectX 9.0 coding phase, 261 Foreword collision detection, 280-83 Preface DirectAudio classes, 211,233-49 Introduction DirectMusic class, 239-49 Chapter 1 - .Nettrix: GDI+ and Collision Detection DirectSound class, 236-39 Chapter 2 - game .Netterpillars: Artificial Intelligence and Sprites DirectX engine class, 217-25 Chapter 3 - sprite Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ DirectX class, 225-33 Chapter game 4 field, - River 262-71 Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio improving performance, 289-90 Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen main program, 261 Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow music sound effects, 236-49, 283-85 Techniques and Speech API Chapter 7 and - Magic KindergarteN. II: Animation neverending game map, 289 Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay player animations, 285-88 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 character, player 273-80 Nonmanaged Code project, 250-57 Bonus Chapter Porting .Nettrix to Pocket PC proposal, 249-50 Appendix A - The State of PC Gaming scrolling, 271-73 Appendix B - Motivations in Games scrolling games and, 211-14,256-57 Appendix C - How Do I Make Games? tile-based games and, 211,214-17 Appendix D - Guidelines for Developing Successful Games tiles,251-56
Table of Contents
Index
River Pla.Net II game, 291-346.See also River Pla.Net game List of Figures bullet collision detection, 335-36 List of Tables
Bullets array, 330 class diagram, 317-18 coding phase, 319 collision detection, 327-29 DirectInput and, 291,295-97,319-21 GameFont class to write text to screen, 292-95 handling input device data, 330-32 input classes, 297-301 joystick control of plane, 316 joystick initialization code, 304-5 loading active objects, 321-24 mouse and keyboard initialization code, 301-4 moving bullets, 333-35 moving enemies, 321-29 moving ships and planes, 316-17,324-26 pause feature, 339-41 polling input devices, 306-8 processing input device input, 308-15,319-21 project, 316-18 proposal,315-16 shooting feature, 317,329-36 status line, 317,337-39 support for force-feedback joysticks, 317,341-46
threading concepts, 296
.NET Game Programming with DirectX 9.0
River Raid game,by211, 249,291 ISBN:1590590511 Alexandre Santos Lobão and Ellen Hatton role-playing games (RPGs), 347-48.Seealsoadventure games Apress © 2003 (696 pages)
Roller Coaster Tycoon games, 606,607,608
The authors of this text show how easy it can be to produce
Rotate method, 45-50 interesting multimedia games using Managed DirectX 9.0 and Visual Basic .NET on Everett, the latest rotations,3,45-50,programming 156.See alsowith matrix tranformations version of Microsoft's Visual Studio.
runtime errors, porting games and, 585.See alsoerrors Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index S
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce sales data, PC gaming market, 604-9
interesting multimedia games using Managed DirectX 9.0 and
with 352 Visual Basic .NET on Everett, the latest Sam and Max Hitprogramming the Road game, version of Microsoft's Visual Studio.
saving emulator state, 579
scaling,3,156.See alsomatrix transformations Table of Contents
schedules, commercial games and, 634
.NET Game Programming with DirectX 9.0
scope, project. Seeproposals Foreword Preface scope modifiers, 222-23 Introduction scores.Seerewards Chapter 1
- .Nettrix: GDI+ and Collision Detection
screens. See alsowindows - .Netterpillars: Artificial Intelligence and Sprites adventure game, 354 Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ collision detection for objects on and off, 17 Chapter 4 - River (see Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio configuration configuration screens) Chapter 5 River Pla.Net II: DirectInput andDirectX) Writing Text to Screen DirectX and, 149-50,172-74 (see also Chapter 6 - Magic Adventure Games, ADO.NET, and DirectShow finishing gamesKindergarteN.: and, 621 Chapter 7 field, - Magic II: Animation Techniques and Speech API game 100KindergarteN. (see alsogame fields) Chapter 8 over - .Netterpillars Multiplayer game (seegameII: over screens)Games and Directplay introduction D-iNfEcT: (seeintroduction Multithreading, screens) Nonrectangular Windows, and Access to Chapter 9 Code loading, Nonmanaged from database, 383-87 Bonus Chapter Porting .Nettrix to Pocket PC Magic KindergarteN, 363-69, 381,383-87, 393-94,417,449 Appendix A - Thegames State ofand, PC Gaming multiplayer 478 Appendix .Netterpillars, B - Motivations 98-100, in124-32, Games 138-40 .Nettrix, Appendix C -63 How Do I Make Games? side scroller games, Appendix D - Guidelines for621 Developing Successful Games writing text to, 292-95, 337-39 Index Chapter 2
List of Figures scrolling games, 211-14 List of choosing Tables scrolling type, 213
parallax scrolling, 212-13 player or engine-controlled scrolling, 213 River Pla.Net, 256-57,271-73,277-78, 289 (see alsoRiver Pla.Net game) scrolling direction, 212 side scroller games, 620-21 technical tips for scrolling implementation, 214 seamless tiles, 215-17 Secret of Monkey Island game, 351 sections, critical, 550 seeing distance, 76-77 Segment objects, 234-35,245-46 sender objects, 5 sending messages, 514-15,529-30 sequels, game, 600-4,608.See alsofranchise games serial providers, 492 service providers, DirectPlay, 492,498-502 sessions connecting to remote, 512-13 creating and destroying, 502-5
DirectPlay and, 492-93 Game Programming with DirectX 9.0 listing existing,.NET on remote computer, 505-12 by Alexandre Santos Lobão and Ellen methods,502-13
ISBN:1590590511
Hatton SetCoopLevel enumeration, Apress © 2003237-38 (696 pages)
Set/End Set blocks, The126 authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
Set keyword, 6 programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio. SetMaster methods, 242-43 SetPeerInformation method, 513 Table Contents SGToffiles, 234 .NET Game Programming with DirectX 9.0
Shadows keyword, 223,103
Foreword
Shared keyword, 35,222
Preface
shared properties and methods, 35,54,222 Introduction Chapter 1 - games, .Nettrix:610 GDI+ and Collision Detection shareware Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites Shelley, Bruce, 627
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
ship sprites, 316-17,324-26
shooter5games, Chapter - River603 Pla.Net II: DirectInput and Writing Text to Screen Chapter 6 feature, - Magic 317, KindergarteN.: shooting 329-36 Adventure Games, ADO.NET, and DirectShow Chapter 7 Magic KindergarteN. II: Animation Techniques and Speech API ShowDialog method, 129 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Show method D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 class, Block 50-51 Code Nonmanaged Square class, 32 Bonus Chapter Porting .Nettrix to Pocket PC side scroller games, 620-22 Appendix A - The State 212, of PC Gaming Appendix B of, - Motivations in Games sight, line 76-78 Appendix C - How Do I Make Games?
Sim City games, 72,73,601,606,607,633
Appendix D - Guidelines for Developing Successful Games
Sim Mania Pack, 607
Index
Sims game, The, 607,608 List of Figures List of Tables single-threaded processes, 549
Sinkovec, Igor, 167,423 sizes game field windows, 131 message,486-87 screen,67 skill levels, 490 smaller rewards occurring more often, 612 Smart Device Application, 576 smoothing animations,205-7 graphics,4 game starts, 544-45 software devices, 147 SoftwareVertexProcessing flag, 147 SolidBrush objects, 5,7 sounds commercial games and, 631 D-iNfEcT,571-72 hearing player, 78
hiding latency with, 487 Game Programming with DirectX 9.0 River Pla.Net,.NET 236-39, 283-85 (see also DirectSound) by Alexandre Santos Lobão and Ellen
Speak method, 437, 473 Hatton
ISBN:1590590511
Apressof©character's, 2003 (696 pages) speech, player choice 465-69 The authors of this text show how easy it can be to produce Speech API, 435-48 interesting multimedia games using Managed DirectX 9.0 and converting textprogramming to speech, 437-39 with Visual Basic .NET on Everett, the latest speech engines and applications, version of Microsoft's 435-36 Visual Studio. speech generation classes, 439-48 speech generation in Magic KindergarteN II, 473-76 (see also Magic KindergarteN II game) Tablespeech of Contents generation methods, 445-46 .NETspeech Game Programming with DirectX 9.0 recognition, 436-37 Foreword
SpeechVisemeType enumeration, 438-39
Preface
spider character, .Netterpillars, 141
Introduction
spInProcRecoContext object, Chapter 1 - .Nettrix: GDI+ and 436-37 Collision Detection Chapter - .Netterpillars: Artificialscreens Intelligence and Sprites splash 2screens. Seeintroduction Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ splines, cardinal, 3
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
SpriteLibm 621
sprites 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter attributes, 82-83 Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API bullets as, 329-30 II: Multiplayer Games and Directplay Chapter 8 - .Netterpillars drawing and erasing, 85-86 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 - fast and transparent, 81-82 drawing Nonmanaged Code flexible vertex formats and, Bonus Chapter Porting .Nettrix to 226 Pocket PC Magic KindergarteN, 376, 378-80 Appendix A - The State of PC Gaming mouth animation, 440,443-44 Appendix B - Motivations in Games .Netterpillars,69,80-86,91,101 (seealso.Netterpillars game) Appendix C - How Do I Make Games? New method, 83-85 Appendix D - Guidelines for Developing Successful Games point,160 Index River Pla.Net game, 225-33 List of Figures SpriteLib,620 List of Tables suggested properties and methods, 80-81 transparent,167 spSharedRecoContext object, 436-37 spVoice object, 437-38,443-44 Square class, 31-37 class diagram, 25-27,29 class interface, 31 New and Hide methods, 32-35 Pocket PC version, 587-88 testing,35-37 square objects collision detection for, 14-15 extending proximity algorithms for 3-D, 22 squashing motions, animating, 426-28 Starcraft game, 605,607,617 starting games animated sequences for, 476 smoothing of, 544-45 Start method, 296 Star Trek game, 348
Star Wars games, 606
.NET Game Programming with DirectX 9.0
static objects, 101-10 by Alexandre Santos Lobão and Ellen Hatton statistics, game over screen, 138-40
ISBN:1590590511
Apress © 2003 (696 pages)
status line, 317,337-39
The authors of this text show how easy it can be to produce
StopEx method, 246 interesting multimedia games using Managed DirectX 9.0 and Stop method, 360programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
StopPlaying method GameMusic class, 246-47 TableGameSound of Contents class, 239 .NET Game Programming with DirectX 9.0
StopSquare method, GameField class, 42,51,59-60
Foreword
story-based games, 627
Preface
storyboarding, 363 Introduction Chapter 1 - .Nettrix: GDI+ and Collision Detection storyline Chapter 2 - .Netterpillars: adventure game, 353 Artificial Intelligence and Sprites Chapter commercial 3 - Managed games DirectX and, 633 First Steps: Direct3D Basics and DirectX vs. GDI+
extending Magic KindergarteN, 417-20 Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Magic Chapter 5 KindergarteN, - River Pla.Net 362 II: DirectInput and Writing Text to Screen Chapter 6 games, - Magic627. KindergarteN.: Adventure games Games, ADO.NET, and DirectShow strategy See alsocommercial Chapter 7
Magic KindergarteN. II: Animation Techniques and Speech API streaming -media. SeeDirectShow
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
StreamReader and StreamWriter objects, 263,268
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Nonmanaged Code 426-28 stretching motions, animating,
Bonus Chapter strings, 486-87Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming
structured error handling, 58,245
Appendix B - Motivations in Games
StructureC keyword, Appendix - How Do 165 I Make Games? Appendix stubs,31, D35 - Guidelines for Developing Successful Games Index styles, music, 245-46 List of Figures
SuppressFinalize method, 233
List of Tables
success, commercial. Seecommercial games Sullivan, Paul, 595 Super Mario Brothers game, 620-21 swap chains, 149 SwapEffect enumeration, DirectX, 149-50,180-81,186 synchronization, game field, 535-38 SyncLock/End SyncLock blocks, 296,551 System.Drawing namespace, 5 System.GC object, 140 System object, 60 System Shock game, 609 System.Windows.Forms namespace, 5
Index T
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
authors of this text show how easy it can be to produce tables, adaptableThe percentage, 75-76
interesting multimedia games using Managed DirectX 9.0 and
programming Visual Basic .NET on Everett, the latest talk action, mouse pointer for, with 459-60 version of Microsoft's Visual Studio.
TCP-IP providers, 492
TCP protocol, 489,490-91 Table of Contents
television tie-in games, 607
.NET Game Programming with DirectX 9.0
tempo,615 Foreword Preface Terrarium game, 484 Introduction testing Chapter - .Nettrix: GDI+ and Collision Detection beta1 testing groups, 490 Chapter 2 class, - .Netterpillars: Artificial Intelligence and Sprites Block 51-53 Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Direct3D application, 177-85 Chapter Direct3D 4 - River matrix Pla.Net: transformations, Tiled Game 197-205 Fields, Scrolling, and DirectAudio
gameplay, 629Pla.Net II: DirectInput and Writing Text to Screen Chapter 5 - River multiplayer games, 489 Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow .Netterpillars, Chapter 7 - Magic106-10 KindergarteN. II: Animation Techniques and Speech API NetworkGame class, II: 516-19 Chapter 8 - .Netterpillars Multiplayer Games and Directplay Square class, 35-37 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code tetraminos,618-19
Chapter 9
Bonus Chapter Porting .Nettrix to Pocket PC
Tetris game, 1,618-19
Appendix A - The State of PC Gaming
text converting, to speech, 436,437-39 Appendix C - How Do I Make Games? text-based adventure games, 348-49 Appendix D - Guidelines for Developing Successful Games writing, to screens, 292-95,337-39 Appendix B - Motivations in Games
Index
textoffiles List Figures
reading and writing, 263 tile-based game field and, 256,262-71
List of Tables
text-to-speech (TTS) systems, 436 texture, Direct3D, 163-66,168,182-83,188-92 Thief game, 609 Thread objects, 296,549,566.See alsomultithreading three dimensional graphics. SeeDirect3D;graphics, 3D Tick event, timer, 64 tile-based games, 214-17 creating border tiles, 215-16 drawing basic tile sets, 215 improving performance in drawing tiles, 289-90 including transition tiles, 216-17 optimizing collision detection, 17-18 River Pla.Net, 251-56,259,262, 289-90 (seealsoRiver Pla.Net game) vertex formats and, 164 tiled game fields, collision detection and, 17-18 timer,27-28,61 Titanic game, 605 Tomb Raider game, 604
ToString method, 500,510
.NET Game Programming with DirectX 9.0
Total Annihilationby game, 606 Alexandre Santos Lobão and Ellen Hatton tranquility, 615
ISBN:1590590511
Apress © 2003 (696 pages)
transformation matrices. Seematrix transformations
The authors of this text show how easy it can be to produce
transition tiles, 216-17 interesting multimedia games using Managed DirectX 9.0 and programming .NET on Everett, the latest translations,3,156, 256-57.See with alsoVisual matrix Basic tranformations version of Microsoft's Visual Studio.
transparency color,2,8,82,96,105 TableDirect3D of Contents textures, 188-92 .NETsprites, Game Programming with DirectX 9.0 81-82,86 Foreword
trends, PC gaming market, 604-9.See alsoPC gaming market
Preface
triangles, Direct3D, 159-63
Introduction
Tribes game, 608 GDI+ and Collision Detection Chapter 1 - .Nettrix: Chapter 2 - .Netterpillars: Artificial Intelligence and Sprites trust, player, 613,614 Chapter 3 - Managed Try keyword, 58,245 DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
turn-based games, 483-84,630
tutorials, 632 KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 6 630, - Magic Chapter TV tie-in 7 games, - Magic607 KindergarteN. II: Animation Techniques and Speech API Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay types, data. Seedata types D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 types, message, 486-87 Code Nonmanaged Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index U
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
The authors of this text show how easy it can be to produce Ultima Online, 484
interesting multimedia games using Managed DirectX 9.0 and
with Visual Basic .NET on Everett, the latest Undraw method, programming 85-86 version of Microsoft's Visual Studio.
Undying game, 602-3
Unicode strings, 486-87 Table of Contents
United States' Game Developers Conference, 627
.NET Game Programming with DirectX 9.0
unknown occurrence, greater rewards with, 613 Foreword Preface unmanaged code, 556-58,571-72 Introduction unpredictability,75 Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Unreal Tournament game, 599-600,605
User Datagram Protocol (UDP), Chapter 3 - Managed DirectX First 491 Steps: Direct3D Basics and DirectX vs. GDI+ user interfaces Chapter 4 - River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio adventure games, 351-52, 354-55 and Writing Text to Screen Chapter 5 - River Pla.Net II: DirectInput goals 632 KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 6 for, - Magic improving D-iNfEcT, 573 Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API Magic 394 Games and Directplay Chapter 8 KindergarteN, - .Netterpillars 374-75, II: Multiplayer Magic KindergarteN II, 454 .Nettrix II, 582
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 participant-ship and, 615 Nonmanaged Code
player motivation and complex, 616PC Bonus Chapter Porting .Nettrix to Pocket Appendix USPTO Asite, - The 619State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index V
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
authors of this text show how easy it can be to produce value, consumer The expectation for, 598,609
interesting multimedia games using Managed DirectX 9.0 and
programming values, production, 631,634 with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
variables environmental,74 Visual Basic .NET, 34 Tableinitializing of Contents .NETobject, Game 6 Programming with DirectX 9.0 resetting game, 130 Foreword scope modifiers, 222-23 Preface sprite attributes as public, 82-83 Introduction
VBDX8.DLL reference, 233, 239-40 Chapter 1 - .Nettrix: GDI+ and Collision Detection Chapter 2 351, - .Netterpillars: Artificial Intelligence and Sprites verb list, 381 Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
VertexBuffer object, 163-66
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
vertex collections - River Pla.Net II: DirectInput and Writing Text to Screen DirectX devices and, 147-48 Chapter 6 - Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow as drawing primitives, 159-63 Chapter 7 - Magic KindergarteN. II: Animation Techniques and Speech API flexible vertex formats, 163-66,181-83,193-94,197-98,219,396-97 Chapter 5
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
VertexFormat enumeration, 164 D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 Nonmanaged Code vertical scrollers, 212 Bonus Chapter Porting .Nettrix to Pocket PC
video.SeeDirectShow
Appendix A - The State of PC Gaming
video adapters, 146
Appendix B - Motivations in Games
Video objects, 359-61, 407-8 Appendix C - How Do I Make Games? Appendix - Guidelines for Developing Successful Games Viseme D event IndexMagic KindergarteN II handler, 446-47 List of parameters, Figures 438-39 List of Tables Visual Basic .NET
accessing nonmanaged code, 556-58 comparison operators, 55 data type conversions, 267 data types, 34,244 forms,109 game programming (see.NET game programming) graphics routines, 60 IIF command, 139 imported namespaces, 222 list box items and ToString method, 500 method overload, 85 multithreading,296,548,549,551 (see alsomultithreading) New method, 37 property procedures, 99,126 reading and writing text files, 263 sharing event procedures, 196 structured error handling, 58,245 Structure keyword, 165 visual prototypes, 98 Visual Studio .NET ADO.NET help, 357
declarative attributes help, 558 Programming with DirectX 9.0 enumerations.NET and, Game 52 by Alexandre Santos 575-80 Lobão and Ellen programming for mobile devices,
ISBN:1590590511
Hatton voice generation Apress and recognition. Seespeech API © 2003 (696 pages)
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index W
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
ISBN:1590590511
WAV files, 234 The authors of this text show how easy it can be to produce
interesting multimedia games using Managed DirectX 9.0 and
programming with Visual Basic .NET on Everett, the latest Web sites versionresources, of Microsoft's artificial intelligence 79 Visual Studio. DirectPlay for Pocket PC, 580 DirectX,143 Table of Contents FiringSquad, 595 .NET Game Programming with DirectX 9.0 game communities and, 488 Foreword GameDev.Net,611 Preface GotDotNet,484 Introduction Lupine Games, 617 Chapter 1 - SDK, .Nettrix: Speech 435GDI+ and Collision Detection Chapter 2 .Netterpillars: Artificial Intelligence and Sprites USPTO,619 Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Who Wants To Be A Millionaire? games, 600,607,608,609
winding5fill-mode, 555–56II: DirectInput and Writing Text to Screen Chapter River Pla.Net window6area, 555 KindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter - Magic Chapter 7 -mode, Magic 167, KindergarteN. II: Animation Techniques and Speech API windowed 168,177–85 Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
windows D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter creating 9 - Graphics objects from handles for, 6 Nonmanaged Code Direct3D main, 170–77 Bonus Chapter Porting .Nettrix to Pocket PC DirectX and, 149–50 (see alsoDirectX) Appendix A - The State of PC Gaming forms and, 109 Appendix B - Motivations in Games game field (seegame fields) Appendix - How I Make Games? main,C97, 168 Do (see alsomain windows) Appendix D - Guidelines for Developing Successful Games nonrectangular, 553–56 Indexredrawing,66 List of Figures server configuration, 503–4 List of Tables test, for NetworkGame class, 516–19 Windows GDI+,1–4 logo key, 303 Windows CE and mobile devices, 576–77,580–81 WithEvents keyword, 319 women,628 world, constant, 484–85 world matrix transformation, 257 wrapper classes, 556 write-only properties, 126 writing text to screens, 292–95,337–39
Index
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
X
ISBN:1590590511
The authors of this text show how easy it can be to produce X8R8G8B8 format, 150
interesting multimedia games using Managed DirectX 9.0 and
programming with Visual Basic .NET on Everett, the latest XML files, ADO.NET, 356 version of Microsoft's Visual Studio.
X1R5G5B5 format, 150
X-Wing versus Tie Fighter game, 479 Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
Index
.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
Z
ISBN:1590590511
The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest zoning of Microsoft's with arrays of version bits, 20–21, 54–56 Visual Studio.
z axis, 153
with bits, 18–20 collision detection and, 17 Table of Contents .NET Game Programming with DirectX 9.0 Foreword Preface Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - The State of PC Gaming Appendix B - Motivations in Games Appendix C - How Do I Make Games? Appendix D - Guidelines for Developing Successful Games Index List of Figures List of Tables
.NET Game Programming with DirectX 9.0 List of Figures ISBN:1590590511 by Alexandre Santos Lobão and Ellen Hatton Apress © 2003 (696 pages)
Chapter 1: .Nettrix: GDI+ and Collision Detection The authors of this text show how easy it can be to produce interesting games using Figure 1-1: .Nettrix, this multimedia chapter's sample gameManaged DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Figure 1-2: Using path gradients
Figure 1-3: Changing the alpha from 0 to 255 in a solid color bitmap
Table of Contents
.NET Game DirectXcurve 9.0 that joins points with a spline FigureProgramming 1-4: Creatingwith a smooth Foreword
Figure 1-5: Applying a rotation and scale transformation over a figure Preface Introduction
Figure 1-6: Applying antialiasing to an image
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 - 1-7: .Netterpillars: Intelligence Figure Bounding Artificial boxes for an archerand andSprites a monster Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Figure boxes forScrolling, an archerand and a monster Chapter 4 - 1-8: RiverRevised Pla.Net:bounding Tiled Game Fields, DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Figure 1-9: Two nonoverlapping boxes
Chapter 7 - 1-10: MagicTwo KindergarteN. II: boxes Animation Techniques and Speech API Figure overlapping Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Figure 1-11: Approximating a plane shape with one box and Access to D-iNfEcT: Multithreading, Nonrectangular Windows, Chapter 9 Nonmanaged Code
Figure 1-12: Approximating a plane shape with two boxes
Bonus Chapter Porting .Nettrix to Pocket PC Appendix A - 1-13: The State of PC Gaming Figure Square proximity Appendix B - Motivations in Games
Figure Circle proximity Appendix C - 1-14: How Do I Make Games? Appendix D - Guidelines for Developing Successful Games
Figure 1-15: Diamond proximity
Index
List ofFigure Figures1-16: In a tiled game field, we have an array that maps to screen objects. List of Tables
Figure 1-17: Dividing a screen into 64 zones Figure 1-18: Using zone bits, if we have big objects (like the bricks), there'll be lots of "ghost objects." Figure 1-19: Using zone arrays, we can keep track of which objects are in each zone. The legend shows the bit set in each array element, for each object. Figure 1-20: The class diagram-first draft Figure 1-21: The class diagram-second draft Figure 1-22: The final class diagram Figure 1-23: Our first results with GDI+ Figure 1-24: The square arrangements to form each block Figure 1-25: The squares for the Square block type Figure 1-26: The squares for the Line block type Figure 1-27: Line block- rotation around the second square Figure 1-28: The Z block rotation
Figure 1-29: Rotation of the T block
.NET Game Programming with DirectX 9.0
Alexandre Santos Lobão and Ellen Figure 1-30: by Rotation for the J block
ISBN:1590590511
Hatton Figure 1-31: Apress Testing©the 2003Block (696 pages) class The authors of this text show how easy it can be to produce
Figure 1-32: interesting The final version of .Nettrix multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
Figure 1-33: version Showingofthe next block Microsoft's Visual Studio.
Chapter 2: .Netterpillars: Artificial Intelligence and Sprites
Table of Contents
.NET Game Programming with DirectX 9.0
Figure 2-1: .Netterpillars, this chapter's sample game Foreword Preface
Figure 2-2: The player (good guy) is outside the seeing distance of the NPC (devil).
Introduction
Chapter Figure 1 - 2-3: .Nettrix: The player GDI+ and is behind Collision theDetection NPC, so it can't see the player. Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Figure- 2-4: The NPC tries to see the player. Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 3
Chapter 4 - 2-5: RiverThe Pla.Net: Tiledclass Game Fields, Scrolling, and DirectAudio Figure Sprite Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter Figure 6 - 2-6: Magic The KindergarteN.: class diagram-first Adventure draftGames, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Figure- 2-7: The class diagram-second draft .Netterpillars II: Multiplayer Games and Directplay
Chapter 8
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Figure Chapter 9 - 2-8: The final class diagram Nonmanaged Code BonusFigure Chapter Porting .Nettrix to Pocket PC 2-9: The game main workflow Appendix A - The State of PC Gaming
Figure The intro screen Appendix B - 2-10: Motivations in Games Appendix C - How Do I Make Games?
Figure 2-11: The game configuration screen
Appendix D - Guidelines for Developing Successful Games IndexFigure 2-12: The game field screen is just a form with an image control. List of Figures List ofFigure Tables2-13: The branch images
Figure 2-14: Testing the first basic classes Figure 2-15: The names for the netterpillar images Figure 2-16: Testing the netterpillars Figure 2-17: The .Netterpillars splash screen Figure 2-18: A Game Over screen
Chapter 3: Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Figure 3-1: The walking man, presented as this chapter's sample Figure 3-2: The Cartesian 3-D coordinate systems Figure 3-3: Perspective projection Figure 3-4: Orthogonal projection Figure 3-5: The field of view angle and view planes for perspective projection
Figure 3-6: Moving a triangle on the y axis
.NET Game Programming with DirectX 9.0
by Alexandre Santos Lobão and to Ellen Figure 3-7: Applying a matrix multiplication a 3-D vertex ISBN:1590590511 Hatton
Figure 3-8: AApress cube made © 2003 with (696 pages) triangles The authors of this text show how easy it can be to produce
Figure 3-9: Vertices rendered as a games point list interesting multimedia using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
Figure 3-10: version The same vertices rendered as a line list of Microsoft's Visual Studio. Figure 3-11: The same vertices rendered as a line strip Table of Contents
FigureProgramming 3-12: The same rendered as a triangle list .NET Game with vertices DirectX 9.0 Foreword
Figure 3-13: A complex polygon created with a triangle strip
Preface
Introduction Figure 3-14: A triangle fan example Chapter 1 - .Nettrix: GDI+ and Collision Detection
Figure ApplyingArtificial colors to square vertices Chapter 2 - 3-15: .Netterpillars: Intelligence and Sprites Chapter 3
Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+ Figure- 3-16: Texture mapping with (tu,tv) pairs of values
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter Figure 5 - 3-17: River The Pla.Net main II:window DirectInput interface and Writing Text to Screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Figure- 3-18: The Light Control window Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 7
Chapter 8 - 3-19: .Netterpillars II: Multiplayer Games and Directplay Figure The MatrixControl window Chapter 9
-
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to
Nonmanaged Code Figure 3-20: The filled Adapters, Rendering Devices, and Display Modes list boxes
Bonus Chapter Porting .Nettrix to Pocket PC
Figure The of finished main window Appendix A - 3-21: The State PC Gaming Appendix B - Motivations in Games
Figure 3-22: Walking man textures, from walk1.bmp to walk10.bmp (courtesy of Igor Sinkovec)
Appendix C - How Do I Make Games?
Appendix D - 3-23: Guidelines for Developing Successful Games Figure Running our first DirectX program Index List ofFigure Figures3-24: Running our DirectX program in full-screen mode List of Tables
Figure 3-25: A window, with a flat blue color to be used as a transparent texture. Figure 3-26: Testing the transparent window Figure 3-27: Our old friend walking man in a disco Figure 3-28: The cube 3-D coordinates for the first two facets Figure 3-29: A moving cube with a walking man in each face Figure 3-30: Our walking man, tired of running, now walks at a lazy rate of 10 fps.
Chapter 4: River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Figure 4-1: River Pla.Net, a River Raid clone, is this chapter's sample game Figure 4-2: A basic set of tiles, comprising two terrain types Figure 4-3: Example of border tiles Figure 4-4: Simple variations of border tiles Figure 4-5: Civilization- a successful example of a tile-based game
Figure 4-6: The GameEngine class interface
.NET Game Programming with DirectX 9.0
by Alexandre Santos Lobão and Ellen Figure 4-7: The Sprite class interface
ISBN:1590590511
Hatton Apress © 2003 (696 pages) Figure 4-8: The audio classes The authors of this text show how easy it can be to produce Figure 4-9: Ainteresting basic set of tiles multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest of Microsoft's Visual Figure 4-10: version A first screen based on tilesStudio.
Figure 4-11: The border tiles Table of Contents
FigureProgramming 4-12: The names of the border tiles .NET Game with DirectX 9.0 Foreword
Figure 4-13: A second screen, based on a larger set of tiles
Preface
Introduction Figure 4-14: The "final touch" set of tiles Chapter 1 - .Nettrix: GDI+ and Collision Detection
Figure The finalArtificial screen,Intelligence using all sets tiles Chapter 2 - 4-15: .Netterpillars: andofSprites Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Figure 4-16: The River Pla.Net game class diagram
Chapter 5 - 4-17: River The Pla.Net II: DirectInput and Writing Text to Screen Figure game splash screen Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Figure the scrolling game field Chapter 7 - 4-18: MagicTesting KindergarteN. II: Animation Techniques and Speech API Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Figure 4-19: Images used for the player's plane
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code Figure 4-20: Our plane flying over trouble waters Bonus Chapter Porting .Nettrix to Pocket PC Chapter 9
-
Figure The of plane now collides with any solid obstacles-in this case, a bridge Appendix A - 4-21: The State PC Gaming Appendix B - Motivations in Games
Figure 4-22: Explosion images for dying animation
Appendix C - How Do I Make Games?
Appendix D - 4-23: Guidelines for Developing Games Figure Flashing planes for Successful starting a new life animation Index List of Figures
Chapter 5: River Pla.Net II: DirectInput and Writing Text to Screen
List of Tables
Figure 5-1: River Pla.Net II, this chapter's sample game Figure 5-2: The input classes Figure 5-3: The game intro screen must notify the user of the keys used in the game. Figure 5-4: The values for the X and Y joystick members for each joystick position Figure 5-5: The complete class diagram for River Pla.Net II Figure 5-6: Flying enemy planes in our way Figure 5-7: A message box indicates the first user shot. Figure 5-8: Shooting and destroying enemies Figure 5-9: Score, fuel, and lives-left information, finally! Figure 5-10: Paused game screen Figure 5-11: New force-feedback obstacles appearing on screen
Chapter 6: Magic KindergarteN.: Adventure Games, ADO.NET, and
DirectShow.NET Game Programming with DirectX 9.0 by Alexandre Santos Lobão and Ellen
ISBN:1590590511
Figure 6-1: Magic Hatton KindergarteN., this chapter's sample game Apress © 2003 (696 pages)
Figure 6-2: Leisure Suit Larry in the Land of the Lounge Lizards The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
Figure 6-3: The Secret of Monkey Island programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Figure 6-4: Sam and Max Hit the Road
6-5: Sam and Max Hit the Road dialog icons Table Figure of Contents .NET Game Programming with DirectX 9.0
Figure 6-6: The magic kindergarten school
Foreword
Preface Figure 6-7: The magic kindergarten schoolroom Introduction
Figure A clearing in the forest Detection Chapter 1 - 6-8: .Nettrix: GDI+ and Collision Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Figure 6-9: Another part the forest-the mushroom clearing
Chapter 4 - 6-10: River Inside Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Figure the mouse hole Chapter 5 - River Pla.Net II: DirectInput and Writing Text to Screen
Figure game flow Adventure between screens Chapter 6 - 6-11: MagicThe KindergarteN.: Games, ADO.NET, and DirectShow Chapter 7
Magic KindergarteN. II: Animation Techniques and Speech API Figure- 6-12: Natanael, the player's character
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Figure 6-13: D-iNfEcT: Fiona, Multithreading, the player's teacher, Nonrectangular as a mud Windows, monster and Access to Chapter 9 Nonmanaged Code
6-14: Fiona back to to Pocket humanPC form BonusFigure Chapter Porting .Nettrix Appendix A - The State of PC Gaming
Figure 6-15: Game user interface elements, first draft
Appendix B - Motivations in Games
Appendix C - 6-16: How Do I Make Games? Figure Mouse pointer icons for each action Appendix D - Guidelines for Developing Successful Games IndexFigure 6-17: Magic KindergarteN. class diagram List of Figures
Figure 6-18: Magic KindergarteN. data model
List of Tables
Figure 6-19: The game splash screen Figure 6-20: The kindergarten indoors, including active objects Figure 6-21: The Magic KindergarteN. interface elements in place Figure 6-22: Moving the pointer with the Examine verb Figure 6-23: The mouse pointer triggers an action-turn on the TV. Figure 6-24: The player is finally shown on screen-in this case, inside the mouse hole. Figure 6-25: The player gets the wand, which is then stored in the inventory (right hand). Figure 6-26: The game ending- Fiona is a nice witch again! Figure 6-27: Michael, a supporting character and Natanael's friend Figure 6-28: New objects- a box and a bucket Figure 6-29: The dwarf, king of the mushrooms Figure 6-30: A waterfall in the forest Figure 6-31: An armed mouse
Game Programming with DirectX 9.0 Chapter 7: .NET Magic KindergarteN. II: Animation Techniques and ISBN:1590590511 by Alexandre Santos Lobão and Ellen Speech APIHatton Apress © 2003 (696 pages)
Figure 7-1: Magic KindergarteN. II, this chapter's sample game The authors of this text show how easy it can be to produce interesting multimedia games using Managed DirectX 9.0 and
Figure 7-2: Aprogramming simple walking cycle, with 10 .NET frames with Visual Basic on Everett, the latest version of Microsoft's Visual Studio.
Figure 7-3: A simple walking cycle, with 4 frames 7-4: A 5-frames zombie boy animation cycle Table Figure of Contents .NET Game Programming with DirectX 9.0
Figure 7-5: A squashing and stretching bouncing ball
Foreword
Preface Figure 7-6: The same bouncing movement, without squash and stretch Introduction
Figure A squashing and stretching jumping rabbit Chapter 1 - 7-7: .Nettrix: GDI+ and Collision Detection Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Figure 7-8: Without squashing and stretching, the jumping rabbit looks like a statue.
Chapter 4 - 7-9: RiverAPla.Net: Game Fields, Scrolling, and DirectAudio Figure jumpingTiled rabbit without anticipation Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Figure happy and a sad character-which is which? Chapter 6 - 7-10: MagicAKindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Figure 7-11: A game character in a hurry
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Figure Chapter 9 - 7-12: The walking cycle, divided into three different animations Nonmanaged Code BonusFigure Chapter 7-13: Porting Animations .Nettrix to of Pocket different PCbody parts for creating game animation cycles Appendix A - The State of PC Gaming
Figure 7-14: A simple walking cycle, with 4 frames, a shooting animation, and a simple animation of feet moving
Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
Appendix D - 7-15: Guidelines for Developing Figure The mouth positionsSuccessful with their Games associated sounds Index List ofFigure Figures7-16: A sample of an animation guide with some walking movements List of Tables
Figure 7-17: An animation guide for bike-riding characters Figure 7-18: The relationship between applications and speech engines Figure 7-19: Different mouth animations for Natanael, our game character Figure 7-20: Sidney, the not-so-friendly mouse Figure 7-21: Magic KindergarteN. II class diagram Figure 7-22: Magic KindergarteN. II data model Figure 7-23: The dialog mouse pointer Figure 7-24: There's nothing like cheese to get a mouse out of the way. Figure 7-25: The arrow mouse pointer Figure 7-26: Talking to the mud monster Figure 7-27: Getting an answer from the mud monster Figure 7-28: Natanael's mouth moves as he talks-as expected.
Chapter 8: .Netterpillars II: Multiplayer Games and Directplay
Figure 8-1: .Netterpillars this chapter'swith sample game9.0 .NET Game II, Programming DirectX by Alexandre Santos Lobão and Ellen
Figure 8-2: Peer-to-peer connections Hatton
ISBN:1590590511
Apress © 2003 (696 pages)
Figure 8-3: Client-server connection
The authors of this text show how easy it can be to produce
interesting multimedia games using Managed DirectX 9.0 and Figure 8-4: Ring network topology programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Figure 8-5: A group-based network topology
Figure 8-6: The NetworkGame class implements access to the DirectPlay features.
Table of Contents
.NET Game with DirectX FigureProgramming 8-7: The Service Provider9.0 window Foreword
Figure 8-8: Entering a session name in the Server Configuration window Preface Introduction
Figure 8-9: Join a session window
Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 - 8-10: .Netterpillars: Artificial Intelligence and Sprites Figure The FindHosts method asking for the host name Chapter 3 - Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Figure window test our NetworkGame Chapter 4 - 8-11: River The Pla.Net: Tiledto Game Fields, Scrolling, andclass DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Figure 8-12: The main program workflow for the stand-alone version of .Netterpillars
Chapter 7 - 8-13: MagicThe KindergarteN. II: Animation and Speech API of .Netterpillars Figure main program workflowTechniques for the multiplayer version Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay
Figure 8-14: .Netterpillars II splash screen D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to -
Chapter 9
Nonmanaged Code 8-15: Running a death match BonusFigure Chapter Porting .Nettrix to Pocket PC in .Netterpillars II Appendix A - The State of PC Gaming
Figure 8-16: The game over screen for a death match
Appendix B - Motivations in Games
Appendix C - How Do I Make Games?
Chapter 9: D-iNfEcT: Multithreading, Nonrectangular Windows, and Index Access to Nonmanaged Code Appendix D - Guidelines for Developing Successful Games List of Figures List ofFigure Tables9-1: D-iNfEcT, this chapter's sample game
Figure 9-2: Processes and threads Figure 9-3: A window with two labels forming a cross shape Figure 9-4: An odd cross-shaped window Figure 9-5: A cross-shaped window Figure 9-6: The germ form that will serve as a model for our window shape Figure 9-7: A germ-shaped window Figure 9-8: A gradient-filled, germ-shaped window with borders Figure 9-9: The final interface for the main window Figure 9-10: The main germ window, reproducing ...
Bonus Chapter Porting .Nettrix to Pocket PC Figure 1: .Nettrix II, running on a Pocket PC Figure 2: One of the new Visual Studio .NET 2003 application types
Figure 3: Choosing the platform and the project type
.NET Game Programming with DirectX 9.0
by Alexandre Santos Lobão Figure 4: Choosing the target device forand ourEllen application
ISBN:1590590511
Hatton Figure 5: TheApress Pocket © 2003 PC emulator (696 pages) The authors of this text show how easy it can be to produce
Figure 6: Choosing the target device to run our Managed application interesting multimedia games using DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest
Figure 7: Ourversion game of interface, updated Pocket PCs Microsoft's Visualfor Studio. Figure 8: .Nettrix class diagram Table of Contents
FigureProgramming 9: With just awith fewDirectX updates, .NET Game 9.0here is .Nettrix II. Foreword
Figure 10: Our game is working well, and we have reached "Game Over."
Preface
Introduction
Appendix A: The State of PC Gaming - .Nettrix: GDI+ and Collision Detection
Chapter 1 Chapter 2
- .Netterpillars: Artificial Intelligence and Sprites
Figure- A-1: Alice Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 3
Chapter 4 - A-2: RiverScary? Pla.Net: Tiled Game Fields, Figure Maybe ... Big? Yeah.Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Figure Q3A had the graphics ... Games, ADO.NET, and DirectShow Chapter 6 - A-3: Magic KindergarteN.: Adventure Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Chapter 8
- .Netterpillars II: Multiplayer Games and Directplay
Figure A-4: UT had the gameplay modes
D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Figure Chapter 9 - A-5: Undying had graphics ... Nonmanaged Code BonusFigure Chapter Porting .Nettrix to Pocket PC A-6: And refreshing gameplay Appendix A - The State of PC Gaming Appendix B - Motivations in Games
Appendix C: How Do I Make Games?
Appendix C - How Do I Make Games?
Appendix D - Guidelines for Developing Successful Games
Figure C-1: A screen shot from Quake 3- Arena
Index
List ofFigure FiguresC-2: A tetris clone-Amazing Blocks List of Tables
Figure C-3: Pac-Man screen shot Figure C-4: Galaga-everything explained at a glance Figure C-5: Gauntlet Figure C-6: Where's my Ferrari?
.NET Game Programming with DirectX 9.0
by Alexandre Santos Lobão and Ellen List of Tables Hatton
ISBN:1590590511
Apress © 2003 (696 pages)
Chapter 1: The .Nettrix: Collision authors ofGDI+ this textand show how easy it canDetection be to produce interesting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest Table 1-1: The Block Class Members version of Microsoft's Visual Studio.
Table 1-2: The Square Class Members Table Table of Contents 1-3: The Game Field Class Members .NET Game Programming with DirectX 9.0
Table 1-4: Bits and Results for Some AND Operations Foreword Preface
Chapter 2: .Netterpillars: Artificial Intelligence and Sprites
Introduction Chapter 1
- .Nettrix: GDI+ and Collision Detection
Chapter 2 -2-1: .Netterpillars: Artificial Intelligence and Sprites Table Common Object-Oriented Terminology Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Table Starting Values for anFields, Adaptable Percentage Table Chapter 4 -2-2: River Pla.Net: Tiled Game Scrolling, and DirectAudio Chapter 5
- River Pla.Net II: DirectInput and Writing Text to Screen
Chapter 6
- Magic KindergarteN.: Adventure Games, ADO.NET, and DirectShow
Table 2-3: Adaptable Percentage Table Values After a Successful "V" Formation Attack
Chapter 7 -2-4: Magic KindergarteN. II: Animation Techniques SpeechGuerrilla API Table Adaptable Percentage Table Values Afterand a Failed Attack Chapter 8 - .Netterpillars II: Multiplayer Games and Directplay
Table 2-5: Suggested PropertiesNonrectangular for a Simple Sprite Class D-iNfEcT: Multithreading, Windows, and Access to -
Chapter 9
Nonmanaged Code
Table 2-6: Suggested Methods for a Simple Sprite Class
Bonus Chapter Porting .Nettrix to Pocket PC
Appendix A -2-7: TheThe State of PC Gaming Table Members of the Netterpillar Class Appendix B - Motivations in Games
Table of the Branch Class Appendix C -2-8: HowThe Do Members I Make Games? Appendix D - Guidelines for Developing Successful Games
Table 2-9: The Members of the AINetterpillar Class
Index
List ofTable Figures 2-10: The Members of the GameEngine Class List of Tables
Chapter 4: River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio Table 4-1: Interface Members of the DirectX GameEngine Class Table 4-2: Interface Members for the DirectX Sprite Class Table 4-3: The Tile Codes Table 4-4: The Tile Class Table 4-5: The Player Class Table 4-6: The RiverEngine class
Chapter 5: River Pla.Net II: DirectInput and Writing Text to Screen Table 5-1: The GameFont Class Members Table 5-2: Members of the Common Game Input Classes Table 5-3: Members of the Keyboard Class
Table 5-4: Members of the Mouse Class
.NET Game Programming with DirectX 9.0
by Alexandre Lobão and Ellen Table 5-5: Members of theSantos Joystick Class
ISBN:1590590511
Hatton Apress © 2003 (696 pages)
Chapter 6: The Magic KindergarteN.: Adventure Games, ADO.NET, and authors of this text show how easy it can be to produce DirectShowinteresting multimedia games using Managed DirectX 9.0 and programming with Visual Basic .NET on Everett, the latest version of Microsoft's Visual Studio.
Table 6-1: Result of Each Action on Fiona as Mud Monster 6-2: Result of Each Action on Fiona in Human Form Table Table of Contents .NET Game Programming with DirectX 9.0
Table 6-3: The Active Objects List, with Verbs Results
Foreword
Preface Table 6-4: The Game Engine Class Introduction
Table The Active Object ClassDetection Chapter 1 -6-5: .Nettrix: GDI+ and Collision Chapter 2
.Netterpillars: Artificial Intelligence and Sprites Table -6-6: The Adventure Pointer Class
Chapter 3
- Managed DirectX First Steps: Direct3D Basics and DirectX vs. GDI+
Chapter 4
- River Pla.Net: Tiled Game Fields, Scrolling, and DirectAudio
Chapter 7: Magic KindergarteN. II: Animation Techniques and - River Pla.Net II: DirectInput and Writing Text to Screen Speech APIKindergarteN.: Adventure Games, ADO.NET, and DirectShow Chapter 6 - Magic Chapter 5 Chapter 7
- Magic KindergarteN. II: Animation Techniques and Speech API
Table PlayerVoice Class Interface Members Chapter 8 -7-1: .Netterpillars II: Multiplayer Games and Directplay D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Chapter 9 -7-2: Result of Each Action on Sidney the Mouse Table Nonmanaged Code Bonus Chapter Porting .Nettrix to Pocket PC
Table 7-3: Results of Each Action on the Cheese
Appendix A - The State of PC Gaming
Appendix B -7-4: Motivations in Games Table Mud Monster Answer Block 0 Appendix C - How Do I Make Games?
Table Mud Monster Dialogs Successful Games Appendix D -7-5: Guidelines for Developing Index
Table 7-6: Sidney the Mouse Dialogs
List of Figures List of Tables
Chapter 8: .Netterpillars II: Multiplayer Games and Directplay Table 8-1: .Netterpillars II Messages
Chapter 9: D-iNfEcT: Multithreading, Nonrectangular Windows, and Access to Nonmanaged Code Table 9-1: Logic for the Main Window Events Table 9-2: Logic for the Germ Window Events