J'ai fait un jeux multijoueur en temps réel server-less et offline (Partie 3 - Partie graphique)
Troisième partie d’une série de 3 articles :
Chalenges graphiques
Pour ce projet, j’ai dû faire face à 2 chalenges techniques :
- Reproduire une grille Lego ©.
- Afficher les dessins à l’écran principal avec une animation simulant un flash suivit d’une image type polaroid.
Grille Lego ©
Finalement, faire la grille Lego © a été quelque chose de plutôt simple. Grâce à la libraire FrabricJS, j’ai pu reproduire un pion vu de haut. Une brique est donc l’addition d’un carré avec une ombre sur lequel, j’ai posé 2 cercles avec un jeu de couleurs et d’ombres. Enfin, je rajoute le mot “GDG” à la Place de Lego © et le tour est joué !
Étape 1 : le carré avec l’ombre
this.rectBasic = new fabric.Rect({ |
Étape 2 : le premier cercle (cercle extérieur)
new fabric.Circle({ |
Étape 3 : le second cercle avec une ombre
new fabric.Circle({ |
Étape 4 : L’ajout du texte GDG
new fabric.Text('GDG', { |
Même si cela n’est pas parfait, à une plus petite échelle, cela permet d’avoir un effet plutôt bon !
Le code correspondant est au niveau des fichiers peg.js et circle.js
Animations CSS
L’animation CSS est décomposée en plusieurs animations :
- Un flash.
- L’affichage de mon image sous forme de photo polaroid.
- Le déplacement de mon image dans un coin de mon écran.
Le Flash
Pour réussir cette partie, c’est très simple, il suffit de jouer avec une div blanche avec un dégradé vers de la transparence et il suffit d’afficher cette div pour la faire disparaitre très rapidement.
#flash-effect{ |
Ainsi le fait d’appliquer la classe flash
créera automatiquement cet effet de flash photo.
L’effet Polaroid
Pour faire cet effet avec un nombre minimum d’éléments, j’ai simplement joué avec les before / after et sur les attributs HTML exploitables en CSS.
Ainsi voici le code HTML :
<div class="img-ori-parent" data-author="jefBinomed"> |
et voici le code CSS correspondant :
.img-ori-parent{ |
De cette manière, on peut voir qu’avec simplement un jeu d’ombres, de after, before, on peut donner un effet Polaroid à une image !
L’animation de rétrécissement
Cette animation est assurée par la propriété transition. On écoute ainsi toutes les évolutions de tailles, positions, … et on déclenche une transition de façon à rendre ça plus fluide.
La raison pour laquelle je ne passe pas par la propriété animation
de CSS, est que la position d’arrivée sera complètement aléatoire ! En effet, une fois l’image apparue, on va la positionner dans l’écran de façon aléatoire. Une fois à gauche et une fois à droite. Sa position horizontale et verticale sera certes bornée, mais le résultat sera issu d’un Math.random()
. Donc en utilisant la propriété transition
plutôt que animation
, je peux m’assurer qu’il y aura une animation fluide et prenant en compte tous les cas.
Dans mon animation, j’ai géré 2 états :
- Le parent a la classe
.big
: Dans cet état, l’image est grande et positionnée au centre de l’écran - Le parent n’a plus la classe
.big
: Dans cet état, l’image va prendre une taille plus réduite. Les top & left seront fixés directement par le Javascript
Voici le code CSS à produire pour gérer simplement l’animation :
$size-photo: 200px; |
Voici ensuite comment avec le Javascript j’anime le tout :
- Je déclenche le “flash”.
- Après un léger timeout (le temps du flash), je créé une nouvelle DIV avec la classe
.big
. - Après un deuxième timeout (le temps de laisser le dessin à l’écran pour les participants), je supprime la classe
.big
et je donne des valeurs aléatoires autop
&left
de la DIV parente.
function generateSnapshot(user, dataUrl) { |
Le résultat final
Tout ce dont je n’ai pas parlé
Il reste encore beaucoup de points non abordés et je veux bien répondre aux questions si vous en avez :
- La gestion du compte à rebours.
- La gestion de l’audio & vidéo.
En conclusion, j’ai encore appris pas mal de choses avec ce projet et si je devais revoir certaines parties, je pense que je ferais les choix suivants :
- J’essayerais d’utiliser une autre librairie JS de canvas, D3 ? Car même, si FabricJS est facile d’accès et fait bien le job, j’ai constaté quelques soucis avec le touch et quelques problèmes de performances liés à la librairie sur certains téléphones.
- Je tâcherais d’alléger un peu plus mon arbre firebase, notamment sur le stockage des images. Aujourd’hui mes images sont stockées directement dans l’arbre en base64, ce qui ralentit énormément l’affichage de l’écran de restitution. J’essayerais de stocker ça avec le storage de firebase plutôt qu’en tant que nœud firebase…
Si vous êtes curieux, je vous invite à consulter le code source : Legonnary-Github
Le résultat final :
- App de base
- App Modérateur : Nécessite d’être admin
- App Comptes à rebours : Nécessite d’être admin
- App Restit