https://sexinfo.simon511000.fr/
Ce projet est un site en ligne sous forme de quizz pouvant être joué par n'importe qui. Le quizz porterait sur des questions autour de la sexualité, principalement à propos de ses risques. Les utilisateurs auront le choix entre 4 réponses (de la même manière que Kahoot).
100 joueurs maximum en simulanés dans un lobby. 3 vies par personne par partie sous format battle royale. La réponse des questions sera affiché quand tout le monde aura choisi sa réponse ou que le temps imparti est écoulé. De ce fait, il y a bien un temps imparti par réponse, un peu de la même manière qu'un Kahoot.
Chaque question rapporte de l'xp ce qui permet d'augmenter le niveau des joueurs, et un certain nombre de pièces qui permettent d'achet des objets.
Les objets permettent d'avoir des avantages/désavantages en partie.
Le jeu est mis en scène par un présentateur, dont chaque question est présenté via un voice-over. Sur la scène, une grille des joueurs encore "vivant" seront présents. Chaque utilisateur est représenté par un avater, avec un skin qu'il pourrait définir depuis son profile.
Acceuil
Acceuil présentant le site en lui même, et contenant la connexion des utilisateurs.
Jeu
Contenu du jeu en lui même.
Leaderboard
Affichage en temps réel du classement des joueurs, qui serait sous forme de :
Rang | Nom de l'utilisateur | Niveau | xp |
---|---|---|---|
#1 | Moi | 12 | 1304xp |
#2 | Lui | 11 | 1240xp |
... | ... | ... | ... |
Profil
Profil de l'utilisateur lié à son compte Discord, qui contiendrais :
- Photo de profile (de Discord)
- Niveau
- xp
- Sélection de Skin (choix entre 4, +1 spécial)
- Liste d'Achievement
- Objets (+ achat d'objets)
Informations
Une page dédié aux informations par rapport au sujet de cette nuit de l'info était prévue.
Nous nous sentions capable de faire ce projet si et seulement si on aurait eu plus de temps pour apprendre, car nous n'avions tous pas assez d'expérience (5 premières années de BUT, 1 de seconde année de BUT).
C'est un problème notamment sur la communication entre le client et le serveur (et aussi le fait qu'on puisse pas obtenir les infos des ids de Discord) qui a progressivement bloqué chaque tâches prévues.
Docker
Docker a été utilisé pour packager l'application à la fois en développement et en production.
React
Le React permet de rendre le site internet intéractif.
Socket.io
Socket.io a utilisé pour la communication en temps réel entre les clients et le serveur.
MariaDB
MariaDB est le SGBD qui a été utilisé pour ce projet.
Asprite
Aseprite a été utilisé pour le graphisme, soit la réalisation des sprites.
Défis qui auraient dû être réalisé pour ce projet. Ceux indiqués avec ❌ n'ont pas pu être réalisés, et ✅ pour ceux qui ont pu être fait.
Docker ✅
Le défi était de réaliser un dépôt Git (dans notre cas via Github) et un Readme en markdown (soit le fichier que vous lisez actuellement). Au final, celui ci est devenu la pièce principal du projet pour expliquer ce dont nous avons voulu faire.
Le défi d'Easter Egg était de placer des Easter Egg de manière intelligente. Nous avions imaginé d'intégrer ces Easter Egg dans la liste des achievements, mais pas de manière aussi explicit que ceux ci.
C'est à dire que l'on mettrais seulement leur nom et une petite description, sans expliquer comment l'obtenir. Ce qui forcerait aux joueurs de réfléchir à une manière de trouver ces Easter Egg, et les infos dans la liste d'Achievement aurait été des indices.
Nous nous sommes dit que nous allions surtout en chercher en fonction du rendu du site. Mais sachant qu'il n'a pas pu être finalisé, notre liste est plutôt maigre honnêtement. Voici tout de même notre liste :
Le bot Discord aura été utilisé pour pouvoir configurer des lobbies (dans un stade beaucoup plus avancé), mais il aurait surtout permis d'intéragir avec l'API pour obtenir des informations sur les utilisateurs, principalement des statistiques.
Nous avons poussé le concept de Discord au point de l'utiliser en temps qu'authentification pour le site. Nous aurions pensé que ça aurait été simple au vu de l'expérience des membres, mais nous nous sommes confrontés au fait que Discord ait changé entièrement son API il y a un peu plus d'un an, ce qui nécessitait de tout réapprendre.
Le bot aurait très propablement été fait via discord.js
, et discord.py
en recours.
Accessibilité ❌/✅
En théorie le site aurait été assez accessible, et il l'aurait été encore plus pour les utilisateurs de Discord avec les fonctionnalités prévus avec l'intégration du bot.
On pourrait dire que le site n'est donc peu accessible car il n'es littéralement pas fonctionnel en l'état, mais de ce fait, il n'y a aucune discrimination en terme d'accessiblité.