Introduction to game development for the Web

Phishing Attack
What Is Phishing Attack?
11th September 2019
Which One to Choose RDBMS(Mysql) / MongoDB ?
17th September 2019
Phishing Attack
What Is Phishing Attack?
11th September 2019
Which One to Choose RDBMS(Mysql) / MongoDB ?
17th September 2019
Show all

Introduction to game development for the Web

The modern web has quickly become a viable platform not only for creating stunning, high quality games, but also for distributing those games. 

The range of games that can be created is on par with desktop and native OS counterparts. With modern Web technologies and a recent browser, it’s entirely possible to make stunning, top-notch games for the Web. And we’re not talking about simple card games or multi-player social games that have in the olden days been done using Flash®. We’re talking about kick-ass 3D action shooters, RPGs, and more. Thanks to massive performance improvements in JavaScript just-in-time compiler technology and new APIs, you can build games that run in the browser (or on HTML5-powered devices like those based on Firefox OS) without making compromises.

The HTML5 game platform

You can truly think of the Web as a better target platform for your game. As we like to say, “the Web is the platform.” Let’s take a look at the core of the Web platform:

FunctionTechnology
Audio Web Audio API
Graphics WebGL (OpenGL ES 2.0)
Input Touch eventsGamepad API, device sensors, WebRTCFull Screen APIPointer Lock API
Language JavaScript (or C/C++ using Emscripten to compile to JavaScript)
Networking
WebRTC
 and/or WebSockets
Storage IndexedDB or the “cloud”

The Business Case

As a game developer, whether you’re an individual or a large game studio, you want to know why it makes sense to target the Web with your next game project. Let’s look at how the Web can help you.

  1. The reach of the Web is enormous; it’s everywhere. Games built with HTML5 work on smartphones, tablets, PCs and Smart TVs.
  2. Marketing and discoverability are improved. You’re not limited to promoting your app on someone else’s app store. Instead, you can advertise and promote your game all over the Web as well as other media, taking advantage of the Web’s inherent linkability and shareability to reach new customers.
  3. You have control where it matters: Payments. You don’t have to hand over 30% of your revenues to someone else just because your game is in their ecosystem. Instead, charge what you want and use whatever payment processing service you like.
  4. Again with more control, you can update your game whenever you want. No waiting breathlessly for approval while someone hidden within another company decides whether or not your critical bug fix will ship today or tomorrow.
  5. Control your analytics! Instead of relying on someone else to make all the decisions about what analytics you need, you can collect your own — or choose the third party that you like the best — to gather information about your sales and your game’s reach.
  6. You get to manage your customer relationship more closely, in your own way. No more having customer feedback filtered through an app store’s limited mechanisms. Engage with your customers the way you want to, without a middleman.
  7. Your players can play your game anywhere, anytime. Because the Web is ubiquitous, your customers can check their game’s status on their phones, tablets, their home laptops, their work desktops, or anything else.

Web Technologies For Game Developers

For the tech folks, let’s dig into the APIs the Web brings to the table that cater to game developers. Here’s a thorough list to give you a taste of what the Web can do for you:

1. Full Screen API

This simple API lets your game take over the entire screen, thereby immersing the player in action.

2. Typed Arrays

JavaScript typed arrays give you access to raw binary data from within JavaScript; this lets you manipulate GL textures, game data, or anything else, even if it’s not in a native JavaScript format.

3. Gamepad API

If you want your users to be able to use gamepads or other game controllers to work your game, you’ll need this API.

4. Web Audio API

This API for controlling the playback, synthesis, and manipulation of audio from JavaScript code lets you create awesome sound effects as well as play and manipulate music in real time.

5. HTML And CSS

Together, these two technologies let you build, style, and lay out your game’s user interface. Part of HTML is the <canvas>element, which provides one way to do 2D graphics.

6. WebGL

Lets you create high-performance, hardware-accelerated 3D (and 2D) graphics from Web content. This is a Web-supported implementation of OpenGL ES 2.0.

7. WebRTC

The WebRTC (Real-Time Communications) API gives you the power to control audio and video data, including teleconferencing and transmitting other application data back and forth between two users. Want your players to be able to talk to each other while blowing up monsters? This is the API for you.

8. WebSockets

The WebSocket API lets you connect your app or site to a server to transmit data back and forth in real-time. Perfect for multiplayer gaming action, chat services, and so forth.

9. Pointer Lock API

The Pointer Lock API lets you lock the mouse or other pointing device within your game’s interface so that instead of absolute cursor positioning you receive coordinate deltas that give you more precise measurements of what the user is doing, and prevent the user from accidentally sending their input somewhere else, thereby missing important action.

10. Web Workers

Workers give you the ability to spawn background threads running their own JavaScript code, to take advantage of modern, multi-core processors.

11. IndexedDB

A powerful data storage API for maintaining user data on their own computer or device. A great way to save game state and other information locally so it doesn’t have to be downloaded every time it’s needed. Also useful to help make your game playable even when the user isn’t connected to the Web (such as when they’re stuck on an airplane for hours on end).

12. JavaScript

JavaScript, the programming language used on the Web, is blazing fast in modern browsers and getting faster all the time. Use its power to write the code for your game, or look at using technologies like Emscripten or Asm.js to easily port your existing games.

13. SVG (Scalable Vector Graphics)

Lets you build vector graphics that scale smoothly regardless of the size or resolution of the user’s display.