🎮 my_rpg 🗡️ Drysfa Xaar

Drysfa Xaar

Table of contents 📑

Description 📝

The my_rpg is a project carried out by groups of 4 (see Contributors, during our 1st year in EPITECH Grand Ecole program.
Its purpose is to create in C a Role Playing Game.
An RPG, or role-playing game, is a type of video game where you embody a character and progress through a story by completing quests, fighting enemies and developing your character’s skills.
In our rpg, you play the role of a little spirit trapped in a labyrinth, and your aim is to escape from the maze.

Usage ⚔️

You can run my_rpg like this :

./my_rpg  

For more information, please see the help section or the tutorial.

> ./my_rpg -h  
USAGE  
 ./my_rpg  
DESCRIPTION  
 A role-playing game made by Gianni TUERO, Lou PELLEGRINO, Nicolas TORO and Raphaël LAUNAY.  

Result 🚩

The result of this project is an almost perfect my_rpg.
If you discover a problem or an error, don’t hesitate to create an issue and report it to us as soon as possible.

my.epitech.eu result

Category Percentage Numbers of tests Crash
Minimal functions 0% 0/1 No
repository size 100% 1/1 No
Results 50% 1/2 No

Keynote result

We got the best my_rpg of our class.

Project Mark :

Mark : 68  
Preliminary (2 / 2) :  
  
Error management (2 / 2) :  
  
Window management (3 / 3) :  
Tri state  
Events (1 / 1) :  
  
Animations (2 / 2) :  
Tout suer la meme sprite sheet  
sfClock and framerate (3 / 3) :  
OK  
Basic button (2 / 2) :  
OK  
Welcome menu (1 / 1) :  
OK  
Settings option (2 / 2) :  
Volume slider  
Setting option : volume (2 / 2) :  
Separation des deux  
Setting option : window (3 / 3) :  
OK  
Saving system (part I) (2 / 2) :  
Save  
Ingame menu access (1 / 1) :  
OK  
Character's option : characteristics (3 / 3) :  
Carac  
Character's option : inventory (2 / 3) :  
Que des armes  
Character's option : equipement (3 / 3) :  
OK  
Saving system (part II) (1 / 3) :  
Save le character  
Setting's option : volume & window (1 / 1) :  
OK  
Setting's option : commands (2 / 2) :  
OK  
General informations (2 / 2) :  
NPC visible  
Character informations (3 / 3) :  
OK  
NPC and ennemies informations (3 / 3) :  
OK  
Visuals rendering (1 / 2) :  
Render 2D  
Colliding system (2 / 2) :  
Collisions avec meshing  
Fightings effects (1 / 3) :  
Animation d'attaque  
Environnement effects (0 / 3) :  
  
The universe (1 / 4) :  
  
Quest and NPC (2 / 4) :  
  
Fighting system (4 / 4) :  
ARPG  
Gains (4 / 4) :  
OK  
Global architecture (2 / 3) :  
  
Game engine (0 / 10) :  
  
Rigor code (-1 / 0) :  
  
Skills/abilities tree (0 / 4) :  
  
Configuration files (1 / 3) :  
Simple texte   
Map editor (0 / 5) :  
  
Procedural generation (5 / 5) :  
Génération procédurale  
Scripting language (0 / 2) :  
  
Bonus (0 / 20) :  
  

Oral Mark :

Mark : 4142  
Testing Policy (2 / 4) :  
  
Methodology and Organisation (40 / 40) :  
Organisation  
Involvment (100 / 400) :  
  
Oral Presentation (4000 / 4000) :  
Du coup, et voilà  
Des caractères non joueurs  
Ne faites pas référence aux groupes précédents, la keynote est la votre.  
Librairie != bibliothèque  
Video des 3 hunters très bon  
video du  hunter très bon  
CSFML a expliciter  
Démonstration en video.  
Difficultés techniques intéressantes mais montrez !  

Features

Feature Mandatory Must Should Could
The player needs to have characteristics
The player can fight enemies AND the characteristics impact the fights results
The player have an inventory which can contain a limited set of items
The player can earn experience by winning fights and/or accomplishing specific actions
The player can level up thanks to experience AND upgrading its characteristics
The game contains NPC
The game contains at least one quest
The game contains a how to play system at the very beginning
Collision system including moving and static elements with different shapes
Camera movements (zoom, translation, rotation)
3D effects (depth scaling, isometric projection…)
Buttons must have at least 3 different states
Saving system (You can try to use sfView elements) ✅🤷
The window may be closed using events
The windows may have different modes: Window mode, Full-screen mode
The windows may have different resolutions, at least two (1920x1080, and an other)
The game manages inputs from the mouse click and keyboard
The game contains animated sprites rendered thanks to sprite sheets
Animations in your program are frame rate independent ✅🤷
Animations and movements in your program are timed by clocks ✅🤷
Main menu
Must contain at least these options: Start the game, Resume game (grayed out if not possible), Settings, Quit the game
The settings option must contain: Sound and music volume options, A window size and resolution options
In-game menu
Must be accessible by pressing the Escape key
Must contain at least these options: Character options (equipment and inventory management, characteristics management), Saving, Loading, Settings (the same as main menu), Commands list ✅🤷
Splash screen at the beginning
Command edit into the in-game menu
As much information as possible about the game should be stored in a configuration file
The game should have an advanced collision system to manage complex fighting
The game should contain a simple particle system: with at least 2 types of particle, particle effects (changing colors, scaling, bouncing, fading) to simulate realistic environment (wind, fire, rain, snow…)
Could have a skill tree, unlocking different abilities (active and passive)
Could have a complete particle engine
Could use scripting to describe entities
Could have a map editor ✅🤷

Tests and code coverage

Unit tests were performed using criterion.
In this project, only the library code is covered.
Unit tests are still to be performed, but a large part of the code is already covered:

You can compile the project and run the unit tests with this command :

make tests_run  

For more details, please click here.

Compilation 🛠️

You can compile the project with this command :

make  

If you want clean the project, you can run this command :

make fclean  

You can clean and compile the project with make re.

You can compile the unit tests with this command :

make unit_tests  

Documentation 📚

The documentation is accessible here.

You can generate the documentation with this command :

make doc  

You need multiple package for generate them :

Code mandatory 📦

Of course, in exceptional cases, we may depart from these rules.

What’s next ? 🚀

Contributors 👥

For this project, we were a group of 4 people. Here are the people in the group: