You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Votre projet doit conserver la structure telle que donnée dans le template.
Lorsque la commande mvn clean package est exécutée, un fichier jar nommé <teamId>-0.1-SNAPSHOT.jar doit être présent dans le répertoire target.
Librairie externes
L'utilisation de libraries externes de manière non-maîtrisée peut entraîner des erreurs lors de l'exécution.
Si une erreur arrive suite à l'utilisation d'une librarie non incluse de base dans le template, votre livraison échoue.
Il vous est donc fortement recommandé de ne pas ajouter de librairie dans votre projet.
Cockpit.java
Votre projet doit obligatoirement contenir une classe nommée Cockpit tel que donnée dans le template.
Cette classe doit être positionnée dans le package fr.unice.polytech.si3.qgl.<teamid>.
La classe Cockpit doit contenir les méthodes suivantes:
InitGame
public void initGame(String game);
Cette méthode sera invoquée avec en paramètre une instance de String contenant un JSON au format initGame (voir définition plus bas ou exemple).
NextRound
public String nextRound(String round);
Cette méthode sera invoquée avec en paramètre une instance de String contenant un JSON au format nextRound (voir définition plus bas ou exemple).
Cette méthode doit retourner une instance de String contenant un JSON au format actions (voir définition plus bas ou exemple).
Les actions retournées sont vérifiées puis éxécutée. Si l'action n'est pas valide (voir règles du jeu ou description JSON plus bas) alors elle sera ignorée.
GetLogs
public List<String> getLogs();
Cette méthode est invoquée à la fin de la partie.
Elle vous permets de générer vos propres logs.
Vous pouvez retourner des chaînes de caractères dans le format de votre choix.
Seule limite: vous ne pouvez retourner qu'un maximum de 100 Strings, et aucune ne doit dépasser les 200 caractères.
Ces logs vous seront donnés dans le rapport d'exécution de la partie.
Interfaces JSON
InitGame
Propriétés
Type
goal
#RegattaGoal OU #BattleGoal
ship
#Bateau
sailors
#Marin[]
shipCount
integer
RegattaGoal
Propriétés
Type
mode
"REGATTA"
checkpoints
#Checkpoint[]
BattleGoal
Propriétés
Type
mode
"BATTLE"
Checkpoint
Propriétés
Type
position
#Position
shape
#Circle OU #Rectangle
Position
Propriétés
Type
x
double
y
double
orientation
double
Circle
Propriétés
Type
type
"circle"
radius
double
Rectangle
Propriétés
Type
type
"rectangle"
width
double
height
double
orientation
double
Bateau
Propriétés
Type
type
"ship"
life
integer
position
#Position
name
string
deck
#Deck
entities
(#Rame OU #Voile OU #Gouvernail #Vigie)[]
shape
#Circle OU #Rectangle
Deck
Propriétés
Type
width
integer
length
integer
Rame
Propriétés
Type
type
"oar"
x
integer
y
integer
Voile
Propriétés
Type
type
"sail"
x
integer
y
integer
openned
boolean
Gouvernail
Propriétés
Type
type
"rudder"
x
integer
y
integer
Vigie
Propriétés
Type
type
"watch"
x
integer
y
integer
Marin
Propriétés
Type
id
integer
x
integer
y
integer
name
string
NextRound
Propriétés
Type
ship
#Bateau
wind
#Vent
visibleEntities
(#Courant OU #AutreBateau OU #Recif)[]
Vent
Propriétés
Type
orientation
double
strength
double
Courant
Propriétés
Type
type
"stream"
position
#Position
shape
#Circle OU #Rectangle
strength
double
AutreBateau
Propriétés
Type
type
"ship"
position
#Position
shape
#Circle OU #Rectangle
life
integer
Recif
Propriétés
Type
type
"reef"
position
#Position
shape
#Circle OU #Rectangle
Actions
(#MOVING OU #LIFT_SAIL OU #LOWER_SAIL OU #TURN OU #OAR OU #USE_WATCH)[]