Créer des jeux pour le Web moderne
Les bons développeurs de jeux savent que pour exploiter les opportunités d'une plate-forme particulière, il est important d'adopter ses caractéristiques uniques. Quelles sont les caractéristiques uniques du Web ? Qu'est-ce qui définit un jeu Web ?
Lors de la Google I/O 2019, j'ai présenté mon point de vue sur l'état de l'écosystème des jeux Web, les bonnes pratiques actuelles pour le développement de jeux Web modernes et l'évolution du secteur. Dans cet article de blog, je vais résumer certains des points clés de ma conférence, que vous pouvez regarder en intégralité sur YouTube:
Les défis des jeux Web
Avant de rejoindre Google, j'ai créé un jeu mobile appelé Duet, qui a été téléchargé près de 20 millions de fois. Cette expérience m'a appris que trois ingrédients essentiels sont nécessaires pour créer une entreprise prospère à partir d'un jeu:
- Un jeu fonctionnel
- Utilisateurs
- Un moyen de monétiser les utilisateurs
Sans ces trois éléments, un développeur de jeux ne peut pas réussir. De nos jours, ces deux derniers points sont les plus importants. Les écosystèmes HTML5 fermés tels que WeChat, Facebook Instant Games et d'autres ont démontré qu'il était possible de créer des jeux avec HTML5.
Bonnes pratiques modernes
Par "jeu fonctionnel", j'entends les trois éléments les plus essentiels qui font fonctionner un jeu:
- Performances
- Visuels
- Audio
Dans chacun de ces domaines, la plate-forme Web a fait des progrès significatifs ces dernières années. Pour les performances du processeur, nous avons accès à une nouvelle norme performante appelée WebAssembly. Côté graphisme, WebGL 1.0 est bien compatible avec les différents navigateurs, et les futures normes telles que WebGPU positionnent la plate-forme Web pour un avenir extensible de la programmation graphique semblable à Vulkan et Metal. Enfin, pour l'audio Web, nous avons l'API Web Audio courante et plus récemment l'API Audio Worklet.
Récemment, Unity a présenté en avant-première un nouvel environnement d'exécution appelé Project Tiny, qui est axé sur la création de jeux 2D pour les plates-formes basées sur HTML5. Project Tiny applique une nouvelle conception modulaire à la structure du moteur Unity, ce qui permet de réduire la taille du moteur Unity de base à moins d'un mégaoctet.
D'un point de vue technique, il n'a jamais été aussi facile de se lancer dans le développement de jeux Web.
Entrer dans la boucle
Un bon jeu ne se résume pas à de bonnes performances, des graphismes et un son de qualité. Pour être excellent, un jeu doit être amusant.
L'aspect ludique est un élément difficile à mesurer dans un produit. Lorsqu'un jeu est suffisamment amusant, intéressant ou innovant, les utilisateurs veulent en parler à leurs amis. En d'autres termes, ils veulent partager l'expérience. Exploiter cette opportunité et la combiner au Web est une combinaison puissante qui offre un potentiel de croissance virale important. Sur le Web en particulier, sans plate-forme de découverte centrale, le meilleur moyen d'acquérir des utilisateurs est de s'assurer que nos jeux sont aussi viraux que possible.
Les bons développeurs de jeux savent que pour tirer parti d'une plate-forme particulière, que ce soit au niveau logiciel ou matériel, il est important d'exploiter ses caractéristiques uniques. Par exemple, si vous créez un jeu pour une console avec des commandes de mouvement, vous devez probablement réfléchir au meilleur moyen de les intégrer.
En d'autres termes, vous devez respecter les attentes des utilisateurs de la plate-forme pour laquelle vous créez votre application. Quelles sont les attentes des utilisateurs du Web ? Ils s'attendent à ce que le contenu Web se charge rapidement et soit rapidement interactif. Dans ma présentation, j'ai donné plusieurs exemples de façons, sur et hors du Web, dont les jeux ont été conçus pour se charger rapidement, attirer les utilisateurs dans leurs univers de jeu, les engager et leur donner des incitations supplémentaires pour partager leurs expériences.
Personnellement, je pense que la clé pour créer un jeu Web réussi est de s'appuyer sur cette caractéristique unique du Web. Plus précisément, la solidité de la structure d'URL du site Web et de la boucle de partage à laquelle les utilisateurs peuvent participer.
Voici un exemple de jeu Web que j'ai créé à l'aide de Construct 3. Il exploite l'URL de manière amusante et attrayante.
Space Board est un jeu très simple qui peut se jouer sur mobile avec des commandes tactiles ou sur ordinateur avec un clavier. L'objectif est de parcourir un labyrinthe d'obstacles pour atteindre un objectif à la fin.
Comment Space Board exploite-t-il l'URL de manière unique ? En encodant la structure des niveaux dans l'URL elle-même. Tous les niveaux sont définis comme une grille de 10 x 10 objets (par exemple, des murs, des tourelles ennemies, des clés, des portes verrouillées, etc.). L'URL liste ensuite toutes les positions de grille individuelles et leur contenu. Un mur est représenté par le caractère W
. Un espace vide est un caractère de soulignement.
Exemple :
https://io-space-board.firebaseapp.com/?gameWorld=_wwwwwwwwww___ww__eww_k__d___ww___ww___ww_wwwww_www_wwwww_www___ww___ww_s_ww_f_ww___ww___wwwwwwwwwwww
Ce n'est pas très joli, mais ça fait le job.
Une fois qu'il a terminé un niveau dans Space Board, le joueur peut concevoir son propre niveau à l'aide de l'éditeur de niveau simple illustré ci-dessus. En permettant aux joueurs de concevoir leurs propres niveaux, nous leur offrons la possibilité de personnaliser leur expérience. Lorsqu'un utilisateur se sent connecté à un jeu et qu'il a le sentiment d'en être le propriétaire grâce à la création et à la personnalisation, il est plus susceptible de vouloir partager cette "chose" avec le monde entier.
Le désir de partager un jeu est le début de la boucle virale que nous souhaitons atteindre avec nos jeux Web. Ce mécanisme de conception et de partage de jeux n'est qu'un exemple parmi d'autres. Je vous invite à regarder ma conférence pour en découvrir d'autres.
de retour sur investissement
À l'heure actuelle, il existe deux écoles de pensée concernant la façon dont un développeur de jeux peut générer des revenus grâce aux jeux Web:
- Monétiser directement les jeux
- les traiter comme un canal d'acquisition ;
Traiter les jeux Web comme un canal d'acquisition signifie exploiter la version Web de votre jeu iOS/Android/ordinateur de bureau comme un mécanisme pour attirer vos joueurs et les convaincre de télécharger votre binaire iOS/Android/ordinateur de bureau plus volumineux. Vous générez ensuite des revenus grâce aux backends de paiement et de facturation intégrés de la plate-forme iOS/Android/ordinateur.
La monétisation est généralement un mélange de publicité et de microtransactions. Le Web doit encore faire des efforts pour rivaliser avec les plates-formes mobiles dans la publicité pour les jeux. Par exemple, les formats comme les annonces vidéo avec récompense sont extrêmement populaires pour les jeux mobiles depuis plusieurs années, mais les réseaux publicitaires ne les déploient que maintenant sur le Web.
Néanmoins, certains développeurs de jeux continuent de réussir sur le Web ouvert grâce à la publicité via des bannières traditionnelles et des annonces vidéo interstitielles. Pour en savoir plus sur ces formats, consultez AdSense pour les jeux.
Pour les microtransactions, le Web offre une flexibilité totale grâce au nombre illimité de modes de paiement pouvant être implémentés. Toutefois, cette qualité est à double tranchant. L'inconvénient est que les joueurs ont moins confiance implicite envers un nouveau site Web qu'ils découvrent par rapport aux méthodes de paiement des plates-formes mobiles familières.
L'API Payment Request est une solution qui offre une interface utilisateur de paiement plus cohérente sur le Web. Cette API appelle une UI affichée par le navigateur et simplifie l'acquisition des informations de paiement telles que les cartes de crédit et les adresses de facturation. Toutefois, obtenir les informations de paiement n'est que la première étape d'une transaction. Vous avez également besoin d'une plate-forme de facturation backend.
L'avenir
Ces dernières années, nous avons vu plusieurs jeux Web connaître un succès surprenant. Slither.io a développé une activité mixte sur le Web et sur une plate-forme spécifique, qui démontre l'énorme couverture et l'opportunité de croissance virale que le Web offre. Des portails tels que Poki.com innovent dans leur expérience utilisateur et lancent de nouveaux jeux chaque jour, y compris des titres qui égalent la fidélité de leurs homologues mobiles, comme Subway Surfers ou Crossy Road.
De plus, si vous regardez au-delà du Web ouvert, vous pouvez constater que les jeux Web décollent déjà. Les écosystèmes fermés tels que WeChat et LINE proposent des jeux satisfaisants qui ne sont pas jouables sur le Web ouvert, mais qui sont basés sur des technologies Web telles que HTML5 et WebViews. C'est un signe clair que le Web a atteint un niveau de fidélité capable de rivaliser avec les jeux mobiles spécifiques à une plate-forme, peut-être pas dans la définition classique de la fidélité, mais dans une métrique plus importante: l'attention des joueurs.