README.md 3.46 KB
Newer Older
E201139E's avatar
E201139E committed
1
# Le fichier executable est "default.appli.java""
E201139E's avatar
E201139E committed
2
### La documentation des classes écrite pendant cette semaine se trouve dans le dossier "/doc"
E201139E's avatar
E201139E committed
3

jwars62's avatar
save  
jwars62 committed
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
# Projet S2 : Bataille Navale

![French_battleship_Brennus_NH_64443](img/French_battleship_Brennus_NH_64443.jpg)

## Présentation rapide 

Il va s'agir de développer une application cliente permettant de jouer 
en réseau à la bataille navale : https://fr.wikipedia.org/wiki/Bataille_navale_(jeu)

Un serveur de jeu est accessible en ligne sous la forme d'une API Rest
 (http://37.187.38.219/api/v0) et une librairie Java 
 interfaçant le serveur vous est fournie (en partie).


## Travail à faire

### initialisation du projet

1. créez un git spécifique à votre groupe sur le gitlab de l'université : 
 https://gitlab.univ-nantes.fr/
 
2. ajoutez comme "maintainer" votre enseignant-référent et M. Arnaud Lanoix    

3. déposez sur votre git, l'ensemble des sources récupérées ici :
https://gitlab.univ-nantes.fr/iut.info1.project/battleship-student-project-2021/-/archive/master/battleship-student-project-2021-master.zip
OU faites un fork de ce dépot.



 **Vous respecterez la structure imposée en terme de dossiers/paquetages**
 
  NB :le source récupéré contient un repertoire lib/ 
     contenant une archive jar `battleship-library-1.x.jar`
     
  il faut ajouter ce .jar comme une librairie dans votre IDE préféré
     
  il s'agit de code qui vous est fourni, que vous devrez utiliser
  mais que vous ne pouvez pas modifier


### implémentation de `ships.*`

2. il vous faut (terminer de) développer le modèle de données représentant 
la flotte de bateaux ; pour cela, il vous faut coder 
les classes suivantes (dans `src/info1/ships/`) : 
    *  `Coord` implémentant `ICoord`
    *  `Ship` implémentant `IShip` et (si nécessaire) modifier les classes "filles" fournies
    *  `NavyFleet` implémentant `INavyFleet`
    
Les interfaces à implémenter sont présentes dans `battleship-library-1.x.jar` ; 
elles sont sont documentées dans la javadoc fournie (documentation/javadoc).

NB :des cas de tests écrit en Junit 5.4 vous 
permettront de valider votre implémentation :
   * `CoordTest`
   * `NavyFleetTest`
   * `ShipTest`

![package ships](documentation/package_ships.png)


### utilisation de `info1.network.Network` ...


vous pouvez maintenant utiliser la classe `Network` pour échanger avec le serveur, 
càd créer ou rejoindre une partie, puis jouer, càd effectuer un tir 
sur une coordonnée précise.

![package network](documentation/package_network.png)

La classe `Network` est documentée dans la javadoc fournie (documentation/javadoc).

Plus de détail sur l'usage de la classe Network dans ![HowToUseNetwork](documentation/HowtoUseNetwork.md).

La classe de tests `RunningGameTest` illustre également l'utilisation de `info1.network.Network` ; elle devrait 
fonctionner une fois que vous avez correctement implémenter les classes du package `ships.*`.s

### ... et développement d'une interface graphique

Développez une interface graphique en Swing vous permettant de jouer, cad

1. positionner des bateaux

2. créer une flotte de bateaux

3. initialiser une partie sur le serveur

4. rejoindre une partie initialisée sur le serveur

5. jouer via le serveur

6. gagner ;-)



## Remarques 

Chaque groupe aura un enseignant-référent qui passera
vous voir régulièrement afin de vous assister 
mais aussi évaluer votre travail.





_Image du bateau issue de https://en.wikipedia.org/wiki/French_battleship_Brennus_