"SHIFT" est un jeu Fast Platformer en vue FPS où le joueur incarne un cyborg agile et rapide employé par une entreprise de nettoyage. Son but est de débarrasser des zones des parasites occupant les lieux le plus rapidement possible grâce à son dispositif de téléportation et de tuer le parasite mère.
Genre: Fast FPS / Fast Platformer
Moteur de jeu: Unity
Taille d'équipe: 3
Durée: Février 2024 - Juin 2024
Plateforme: PC (Itch.io)
Moteur de jeu: Unity
Taille d'équipe: 3
Durée: Février 2024 - Juin 2024
Plateforme: PC (Itch.io)
Dans le cadre de notre projet semestrielle de deuxième année, nous devions concevoir un jeu avec pour thème l'état critique avec le logiciel de développement unity.
Résumé de la mécanique :
Pour se déplacer le joueur peut marcher, s'accroupir, courir, sauter et glisser.
Il dispose d'un téléporteur qu'il peut lancer et sur lequel il peut se téléporter en conservant la vitesse du téléporteur et sa position.
Il dispose de 2 charges de téléportation que l'on peut recharger et tirant sur des cibles parasites.
La mécanique est relativement simple à comprendre et à prendre en main.
Il dispose d'un téléporteur qu'il peut lancer et sur lequel il peut se téléporter en conservant la vitesse du téléporteur et sa position.
Il dispose de 2 charges de téléportation que l'on peut recharger et tirant sur des cibles parasites.
La mécanique est relativement simple à comprendre et à prendre en main.
Rôle et Responsabilité :
Au sein du projet j'ai été principalement en charge de la programmation, j'ai notamment développé les comportements de notre téléporteur au sein de l'environnement, les menus du jeu, une sauvegarde locale des temps du joueur et des rebinds de touches.
J'ai également fait l'UI en jeu en utilisant des placeholders pour préparer le travail de l'UI design, afin qu'il n'ait qu'à remplacer les sprites et quelques outils pour aider le level designer. Ainsi, que l'intégration du travail de chacun et la résolution des divers conflits que cela engendrait
Lanceur :
Un des problèmes que nous avons rencontrés avec notre lanceur était que sa vitesse au lancement n'était pas suffisante, ce qui faisait que le téléporteur passait derrière l'avatar du joueur lorsque ce dernier atteignait une certaine vitesse. Augmenter la force de lancé n'était pas possible, car à une vitesse plus faible de l'avatar, le téléporteur aurait été propulsé beaucoup trop rapidement.
Pour résoudre ce problème et donner l'impression que le téléporteur se déplace à une vitesse élevée, même lorsqu'il n'est pas lancé dans la direction du déplacement de l'avatar, j'ai utilisé un produit scalaire. Cela permet d'ajouter une partie de la vitesse du joueur à celle du téléporteur, donnant ainsi une impression de mouvement supplémentaire sans que le téléporteur soit lancé trop fort ni passe derrière le joueur.
On peut voir le fonctionnement actuellement comme lancer une balle d'une voiture en mouvement, la balle va à la vitesse de la voiture additionnée à celle du lancer.
Rebind des inputs :
Notre cible étant porté sur des joueurs Hardcore et ayant un attrait pour le speedrun, il me semblait important pour eux de pouvoirs changer leurs touches selon leur besoin et habitude.
J'ai donc utilisé un sample mis à disposition par Unity que j'ai adapté à nos besoins et en y ajoutant des gestions qui n'étaient pas présentes comme ne pas pouvoir attribuer 2 fois le même input à différentes actions.
J'ai donc utilisé un sample mis à disposition par Unity que j'ai adapté à nos besoins et en y ajoutant des gestions qui n'étaient pas présentes comme ne pas pouvoir attribuer 2 fois le même input à différentes actions.
Sauvegarde Locale :
Dans le même raisonnement que le rebind des touches, permettre aux joueurs de conserver une trace de leurs performances entre sessions de jeu me semblait plus que pertinent, j'ai donc ajouté un système de sauvegarde grâce au PlayerPrefs de Unity, que je souhaite plus tard changer en un fichier json, plus simple à manipuler et à accéder que les PlayerPrefs et crypté.
J'y stocke ainsi les meilleurs temps par niveau et les rebinds de touche du joueur.
J'y stocke ainsi les meilleurs temps par niveau et les rebinds de touche du joueur.
Temps et Niveaux :
Les temps sont stockés en chaine de caractère sous la forme nomScene_temps, afin de les transformer en dictionnaire dans unity, ce qui correspond à une sauvegarde temporaire que j'utiliserais dans ma gestion de code, il me permet de récupérer le meilleur temps de chaque niveau, remettre à jour la sauvegarde locale et en même temps le dictionnaire.Pour notre écran de sélection de niveau, j'ai choisi de le gérer de façon dynamique afin d'éviter à notre level designer de devoir en créer un à chaque nouveau niveau. La seule condition est que le niveau doit être dans les builds settings.
J'ai également ajouté une preview du niveau qui va récupérer une image dans un dossier Ressources portant le nom du niveau associé.
Médailles :
La cible de notre jeu ayant une attirance pour le complétionnisme, j'ai donc proposé à mon groupe, un système de médaille que le joueur récupère en fonction du temps qu'il met à compléter un niveau. Cela permet de motiver le joueur à recommencer et améliorer son temps, tout en affichant le temps minimum pour atteindre la prochaine médaille, ou son meilleur temps, sur l'écran de fin.
Dans le GameManager, j'ai créé un tableau de données regroupant les 3 temps pour obtenir les 3 médailles de chaque niveau. Cela me permet de gérer l'affichage des médailles dans le menu de sélection de niveau et dans l'écran de fin, je n'ai ainsi pas à paramétrer les temps à deux endroits en même temps et j'évite ainsi des erreurs malencontreuses.
La cible de notre jeu ayant une attirance pour le complétionnisme, j'ai donc proposé à mon groupe, un système de médaille que le joueur récupère en fonction du temps qu'il met à compléter un niveau. Cela permet de motiver le joueur à recommencer et améliorer son temps, tout en affichant le temps minimum pour atteindre la prochaine médaille, ou son meilleur temps, sur l'écran de fin.
Dans le GameManager, j'ai créé un tableau de données regroupant les 3 temps pour obtenir les 3 médailles de chaque niveau. Cela me permet de gérer l'affichage des médailles dans le menu de sélection de niveau et dans l'écran de fin, je n'ai ainsi pas à paramétrer les temps à deux endroits en même temps et j'évite ainsi des erreurs malencontreuses.
Altimètre :
J'ai pu remarquer lors de playtest que certains joueurs avaient du mal visualiser où le sol se trouvait par rapport à eux, surtout lorsqu'ils étaient au-dessus de parasite et voulaient attendre le dernier moment pour se téléporter, ils finissaient par mourir.
Pour pallier ce problème, j'ai décidé d'ajouter un altimètre dans l'UI en jeu, afin de donner l'information aux joueurs de leur position par rapport au sol au sein du niveau se trouvant juste en dessous d'eux.
J'ai pu remarquer lors de playtest que certains joueurs avaient du mal visualiser où le sol se trouvait par rapport à eux, surtout lorsqu'ils étaient au-dessus de parasite et voulaient attendre le dernier moment pour se téléporter, ils finissaient par mourir.
Pour pallier ce problème, j'ai décidé d'ajouter un altimètre dans l'UI en jeu, afin de donner l'information aux joueurs de leur position par rapport au sol au sein du niveau se trouvant juste en dessous d'eux.
Marqueurs de cible :
Notre avatar étant un cyborg, j'ai décidé d'ajouter un feedback visuel représentant un marquage de verrouillage que l'on peut retrouver dans certaines machines ou avion de chasse, lorsqu'une cible est en vue du joueur.
Notre avatar étant un cyborg, j'ai décidé d'ajouter un feedback visuel représentant un marquage de verrouillage que l'on peut retrouver dans certaines machines ou avion de chasse, lorsqu'une cible est en vue du joueur.
Intégration sonore :
Je me suis chargé d'intégrer les feedbacks sonores de notre projet en créant d'abord des placeholders dans FMOD. J'ai choisi de créer un SoundManager afin de centraliser la gestion audio du projet, de simplifier l'appel des sons en évitant leur dispersion à travers tous nos scripts, ce qui réduit le risque d'erreur. Je les place ensuite dans des EventUnity qui sont activés sous certaines conditions.
J'ai également adapté le script de la musique d'ambiance qu'un membre de mon groupe a fait afin de ne pas la stopper à chaque changement de scène (niveaux + menus) en plaçant le script dans le DontDestroyOnLoad.
Galerie du projet