aboutsummaryrefslogtreecommitdiffstats
path: root/doc/Rapport final.tex
blob: 66d7d7beb3c4a52e249899cd3c45ba713b920627 (plain)
1
2
3
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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
\documentclass{article}
\usepackage{luatextra}
\usepackage{polyglossia}
\usepackage{ulem}
\usepackage{framed}
\usepackage{color}
\usepackage{listings}
\usepackage{geometry}
\usepackage{amsmath}
\usepackage{unicode-math}
\usepackage{hyperref}
\usepackage{titling}

\setlength{\droptitle}{-5em}   % This is your set screw

\usepackage{ifluatex}
\ifluatex
  \usepackage{pdftexcmds}
  \makeatletter
  \let\pdfstrcmp\pdf@strcmp
  \let\pdffilemoddate\pdf@filemoddate
  \makeatother
\fi
\usepackage{svg}

\setmathfont{xits-math.otf}

\setmainlanguage{french}
\setmainfont{Latin Modern Roman}

\definecolor{dkgreen}{rgb}{0,0.6,0}
\definecolor{gray}{rgb}{0.5,0.5,0.5}
\definecolor{mauve}{rgb}{0.58,0,0.82}

\lstset{language=bash,
  basicstyle={\small\ttfamily},
  keywordstyle=\color{blue},
  commentstyle=\color{dkgreen},
  stringstyle=\color{mauve},
  tabsize=4
}


\geometry{margin={0.7in,0.7in}}

\newcommand\image[2]{
\directlua{
local image = img.scan({filename = "#1"})

image.height = image.height * #2
image.width  = image.width  * #2

node.write(img.node(image))
}
}

\title{Rapport final projet Applications du Web — Candy box}
\author{Alexandre RENOUX - Pierre-Emmanuel NOVAC}

\begin{document}

\maketitle
%%\tableofcontents

Le site web a été nommé CraftMine, et est disponible à l'adresse \url{https://craftmine.piernov.org/}.

\section{Fonctionnalités}
\subsection{Ce qui a été fait}
\subsubsection{Mine}
  Développée comme prévu. Le développement a été très rapide et tient en peu de lignes de code.
\subsubsection{Guilde de mineurs}
  Développée comme prévu. Le développement a été très rapide et tient en peu de lignes de code.
\subsubsection{Magasin}
  Développé en majorité comme prévu. Le développement a été plus long et a demandé la rédaction de bien plus de code. Il fait appelle à plus de fonctions pour lire du XML, gérer le stockage dans la session, générer le HTML, gérer l'inventaire, etc...
\subsubsection{Donjon}
  Développé en partie comme prévu. C'est la fonctionnalité qui a été la plus difficile et la plus longue à implémenter, et cela se vérifie sur la longueur du code.
\subsubsection{Enregistrement et chargement de partie}
  Développé comme prévu. Le joueur a aussi la possibilité de télécharger/téléverser un fichier de sauvegarde. La génération et la lecture du XML a posé quelques problèmes au début mais finalement les fonctions sont assez concises. Le téléversement n'a pas été facile à implémenter: on trouve beaucoup d'informations contradictoires et la plupart d'entre elles reposent sur jQuery.
\subsubsection{Interface utilisateur}
  Développée en majorité comme prévu. C'est principalement un travail de recherche pour comprendre comment structuer correctement le code HTML de manière à ce que la bibliothèque CSS Bootstrap applique correctement les styles.
  
\subsection{Ce qui n'a pas été fait}
Et qui sera peut être fait plus tard:
\begin{itemize}
  \item Ajouter des objets
  \item Ajuster les coûts des objets et les statistiques des personnages.
  \item Rédiger de la documentation complète.
  \item Quelques bugs sur la gestion des objets.
  \item Utiliser des icônes plus jolies (en SVG).
  \item Choix et nombre aléatoire des monstres dans le donjon.
  \item Et plus encore...
\end{itemize}

  
\section{Répartition du travail}
  Les fonctionnalités liées à la mine et à l'enregistrement/chargement de la partie ainsi que l'interface utilisateur ont été développées par Pierre-Emmanuel, qui avait aussi entamé le développement du magasin.\\
  La guilde de mineurs et le donjon ont été développées par Alexandre. Il a aussi poursuivi le développement du magasin.\\
  Le développement s'est fait grâce à l'outil Git, dont le dépôt est consultable à l'adresse \url{http://git.piernov.org/candybox/}. Alexandre a développé les fonctionnalités qui lui avaient été attribuées sur sa branche alexichi, tandis que Pierre-Emmanuel développer les différentes fonctionnalités en parallèle sur sa branche et les branches feat/ correspondantes. Il s'occupait aussi de la fusion des branches pour mettre en commun sur la branche master le code développé séparément.
  
\section{Organisation du code}
  Les fonctions développées en PHP sont généralement concises et découpées de manière logique. En Javascript en revanche, du fait de la génération de code HTML, des traitements plus lourds et des fonctions moins intuitives, le code est moins clair et plus long.
  
  \subsection{Javascript}
  Les différentes fonctions Javascript viennent modifier et compléter le contenu de la page dynamiquement. Les scripts ont été séparés dans différents fichiers correspondant chacun à un aspect de l'application. Ainsi les fichiers suivant ont été créés:
  
  \subsubsection{js/craftmine.js}
  Ce fichier contient la déclaration du tableau data qui contient des données à propos du joueur utiles côté client.\\
  La fonction sendRequest permet d'envoyer des requêtes POST au serveur. Elle décode par ailleurs les données reçus sous forme de JSON et affiche les messages d'erreurs/informations le cas échéant.\\
  Les fonctions de la mine y sont aussi présentes.\\
  
  La fonction initCraftMine est exécutée au chargement de la page par init pour récupérer les données de la sessions précédentes et mettre à jour l'affichage en conséquence.
  init appelle aussi les fonctions pour charger le bon onglet, pour actualiser la liste des sauvegardes et pour incrémenter l'or de la mine.
  \subsubsection{js/dungeon.js}
  Des fonctions pour faire évoluer le personnage dans le donjon.
  
  \subsubsection{js/gui.js}
  Ce fichier contient quelques méthodes pour afficher des messages d'informations/erreurs dans les boîtes appropriées.\\
  changeTab() permet de charger l'onglet correspondant à ce qui a été spécifié dans l'URL. Elle réimplémente une fonctionnalité de la bibliothèque Bootstrap mais permet alors de s'affranchir du chargement de Bootstrap et jQuery, qui seraient démesurées pour cette simple fonctionnalité.
  \subsubsection{js/guild.js}
  Deux simples fonctions envoyant une requête au serveur pour créer la guilde de mineurs et recruter un mineur.
  \subsubsection{js/perso.js}
  Pour mettre à jour les informations du personnage (expérience, niveau, vie).
  \subsubsection{js/savegame.js}
  Les différentes fonctions pour gérer les actions des boutons de l'onglet Save. À noter l'utilisation de window.open() pour lancer le téléchargement de la sauvegarde sur le client. Cette fois-ci, les paramètres sont passés en GET pour plus de simplicité.\\
  uploadSave utilise des fonctionnalités récentes de HTML5/XMLHttpRequest2 pour l'envoi de fichier au serveur.
  \subsubsection{js/shop.js}
Des fonctions pour gérer le magasin et l'inventaire, ainsi que les actions des objets.

\subsection{PHP}

Le fichier craftmine.php gère les requêtes reçues du client et lance les fonctions correspondantes. Le fichier upload.php est dédié à la réception du fichier de sauvegarde envoyé par le client. Les fonctions sont, comme pour les scripts Javascript, répartis dans différents fichiers.

\subsubsection{account.inc}
Des fonctions pour gérer débiter/créditer de l'or.
\subsubsection{craftmine.inc}
Répond à la requête d'initCraftMine pour envoyer les données de la session précédente au chargement de la page. Fait appelle à différentes fonctions des autres fichiers en conséquence.
\subsubsection{inc/dungeon.inc}

\subsubsection{inc/guild.inc}
Des fonctions de gestion de la guilde de mineurs
\subsubsection{inc/Inventory.inc}
Une classe qui décrit l'inventaire du personnage, implémenté comme singleton dont la référence est stockée dans la session.
\subsubsection{inc/Item.inc}
Une classe qui décrit un objet dans l'inventaire ou dans le magasin.
\subsubsection{inc/messages.inc}
La liste des messages d'information/erreur envoyés par le serveur ainsi que les fonctions utilisées pour le faire.
\subsubsection{inc/mine.inc}
Des fonctions pour la gestion de la mine.
\subsubsection{inc/Monster.inc}
Une classe qui décrit un monstre du donjon.
\subsubsection{inc/perso.inc}
Des fonctions pour gérer les informations (vie, niveau, expérience) du personnage.
\subsubsection{inc/savegame.inc}
Un ensemble de fonctions pour gérer chacune des requêtes de gestion des sauvegardes. Les sauvegardes sont enregistrées en XML, des fonctions ont été développées pour générer du XML à partir d'un tableau (en prenant en compte les objets pour lesquels on fait appel à leur méthodes addToXML) et générer un tableau à partir du XML. Elles sont aussi utilisées lors du téléversement d'un fichier de sauvegarde, pour le réécrire et ainsi s'assurer qu'il est valide.
\subsubsection{inc/shop.inc}
Les différentes fonctions pour les interactions avec le magasin. loadShop lit un fichier XML pour générer les objets.

\subsection{Autres}

\subsubsection{index.xhtml}
La page XHTML principale auquel le client accède et que le Javascript modifie dynamiquement. Elle est structurée pour pouvoir utiliser Bootsrap. Elle possède un doctype HTML5 bien que cela ne soit pas strictement nécessaire. À la fin du chargement, elle fait appelle à la méthode init.
\subsubsection{.htaccess}
Pour forcer le serveur à charger la page index.xhtml lorsque le client accède au répertoire.
\subsubsection{css/bootstrap.min.css}
Le fichier CSS officiel de Bootstrap pour avoir une interface plus jolie.
\subsubsection{css/craftmine.css}
Un fichier CSS pour quelques personnalisations supplémentaires de l'interface.
\subsubsection{css/Symbola.ttf}
Police utilisée pour les icônes des objets, fournit par le serveur au cas où le client ne la possède pas.
\subsubsection{data/items.xml}
La liste des objets du magasin au format XML.
\subsubsection{data/monsters.xml}
La liste des monstres du donjon au format XML.

\subsection{Documentation}
\paragraph{phpDocumentor} Le code source PHP a été commenté à l'aide de la syntaxe PHPDoc, et une documentation au format HTML a été générée (dans le répertoire doc/phpdoc).

\paragraph{JSDoc} Nous aurions aimé utiliser JSDoc, à l'image de PHPDoc, pour documenter le code Javascript, mais par manque de temps cela n'a pas été fait.

\section{Choix techniques}
\subsection{Javascript}
Nous avons utilisé des fonctionnalités plutôt récentes en Javascript comme l'objet classList pour ajouter/supprimer une classe en Javascript, utilisé dans notre cas pour changer l'apparence de l'onglet actif. XMLHttpRequest2 a aussi été utilisé pour le téléversement des fichiers de sauvegarde. De ce fait, les navigateurs ancien ou avec une prise en charge limitée du Javascript ne pourront pas faire fonctionner correctement le site web. Ces navigateurs sont entre autres Internet Explorer version 9 et antérieures, ou Opera Mini. Le site web a été développé sous Firefox, et testé sous Chromium.\\
Aucune bibliothèque Javascript externe n'est utilisée.
\subsection{XHTML}
Le XHTML a été utilisé pour sa rigueur et ainsi s'éviter des libertés dans le code HTML. Des navigateurs anciens ne le prennent pas en charge et ne pourront pas du tout afficher la page.
\subsection{Bootstrap}
La bibliothèque CSS Bootstrap est utilisé pour avoir un rendu visuel correct sans trop d'effort. Elle fournit en effet des styles d'éléments qui conviennent et très peu de propriétés ont dû être ajoutées. Nous n'utilisons pas la bibliothèque Javascript de Bootstrap.
\subsection{JSON}
Le format de données JSON est utilisé pour transmettre des informations du serveur au client. Celui-ci est en effet très simple à utiliser et des méthodes sont présentes à la fois en Javascript et en PHP nativement pour encoder/décoder des données sous format JSON.
\subsection{XML}
Les sauvegardes, les objets du magasin et les monstres sont enregistrés au format XML pour être facilement modifiable. Il aurait été intéressant d'enregistrer d'autres données comme les bâtiments sous ce même format et ainsi rendre le site web plus extensible.
\subsection{PHP}
Le langage PHP est utilisé côté serveur car très adapté au développement de site web. Nous ne l'utilisons en revanche pas pour générer des pages HTML mais simplement pour traiter les requêtes envoyées du client, les données étant retournées au format JSON.\\
Certaines fonctionnalités comme l'inventaire et ses objets font appel à de la programmation orienté objet. Ceci n'était en aucun cas nécessaire mais a été fait simplement pour expérimenter les possibilités de PHP. Les autres fonctionnalités n'ont pas été développés en programmation orienté objet.

\section{Planification}

\subsection{Planification théorique}

\begin{itemize}
\item 1ère semaine: développement des fonctionnalités de la mine, de la guilde de mineur et du magasin.
\item 2e semaine: développement du donjon et de l'enregistrement de la partie au format XML.
\item 3e semaine: amélioration de l'interface utilisateur et finalisation du code.
\end{itemize}

\subsection{Planification effective}
\subsubsection{Semaine 1}
Les fonctionnalités de la mine et de la guilde des mineurs ont été correctement développées.\\
Le magasin n'a pas été finalisé dans les temps, mais il était en partie fonctionnel.\\
Le développement de l'interface utilisateur a été attaquée bien qu'à l'origine prévue pour la fin: le développement du magasin est en partie lié à son affichage, et il nous trouvions dommage d'avoir une interface repoussante jusqu'à la fin...

\subsubsection{Semaine 2}
Le magasin a été finalisé. Le chargement des objets à partir d'un fichier XML a été plus long que prévu.\\
Les fonctionnalités d'enregistrement au format XML et de chargement de la partie ont été correctement développées, mais les fonctions pour créer le XML à partir du tableau session et charger le XML dans le tableau session ont pris du temps à être réalisées, retardant le développement des autres fonctionnalités.\\
Du retard a été pris sur le développement du donjon qui n'a été qu'en partie développé et n'est pas encore fonctionnel.

\subsubsection{Semaine 3}
L'interface utilisateur utilise désormais correctement Bootstrap 3 et semble finalisée. \\
La possibilité de téléverser un fichier de sauvegarde a été ajoutée. \\
Le donjon n'est pas totalement terminé mais est fonctionnel. \\
Le code a été en partie relu, mais n'a pas été testé en profondeur.


\end{document}