Projet Aurélien Benel : https://github.com/benel/SOS21Server
L’objectif est de développer un jeu sérieux multi-joueurs avec des technologies web récentes. Etant 3 à travailler sur le projet nous avons chacun une mission spécifique.
Voici les intitulés des 3 missions :
- Prototypage d'un jeu en 3D isométrique avec HTML5
- Prototypage d'un jeu multi-joueurs avec Ajax et Comet
- Prototypage d'un jeu persistant avec une base NoSQL
L’intérêt est que nous posions ensembles les bases techniques du jeu afin que celui-ci soit poursuivi et maintenu facilement.
-
CouchDB CouchDB fait partie des bases de données dites « NoSQL ». C’est un système de gestion de base de données orienté documents. Développé il y a quelques années par Damien Katz, Jan Lehnardt, Noah Slater, Christopher Lenz, J. Chris Anderson, CouchDB fait partie des logiciels distribués sous licence Apache. CouchDB est presque entièrement réalisé en Erlang, un langage de programmation fonctionnel supportant plusieurs paradigmes (concurrence, temps réel, distribution) principalement basé sur la récursivité.
-
couchapp CouchApp est un ensemble d’application permettant de vous aider à créer vos applications CouchDB. CouchApp prend la forme d’un outil en ligne de commande. Il génère l’ensemble des dossiers, librairies et éventuels codes nécessaires pour avoir une application prête à développer et mise en ligne. CouchApp contient plusieurs choses :
- un générateur de squelette d'applications JavaScript pour CouchDB
- un ensemble de "helpers" et de plugin jQuery orientés CouchDB
- des librairies JavaScript telles mustache.js, markdown.js ...
- un ensemble de commandes permettant particulièrement d'installer/copier votre application dans CouchDB
RQ : jQuery permet de lier la partie client et la partie serveur. Elle se trouve en base et est donc « fournie » par l’application CouchDB. On utilisera surtout Ajax afin d’envoyer et récupérer les données formatées en JSON. Les concepteurs de CouchDB ont aussi prévu une extension nommée jquery.couch.js qui permet de faciliter la manipulation des documents stockés dans la base grâce à des fonctions prédéfinies (dont les noms sont assez explicites pour ne pas les décrire) comme openDoc(), saveDoc() et removeDoc().
-
or any other tools that help you to create web application through Couchdb
- SOS21Server : dossier du jeu sos21
- Argile-forum : dossier du forum de conception participatif
$ cd whateverpath
$ git clone https://github.com/FlorianBruniaux/tx-sos21.git <app_name>
$ cd <app_name>
$ couchapp push . http://<user>:<passwd>@localhost:5984/<db_name>
{
"name": "player_name",
"loggedOn": true,
"place": "ed78748a843191d9c9c5e50887581b77",
"x": 231,
"y": 155.33333333333334,
"updatedAt": [
2013,
4,
15,
16,
20
],
"image": "default",
"spriteheight": 70,
"spritewidth": 60,
"type": "character"
}
{
"name": "nom_objet",
"image": "nom_prite",
"place": "id_place",
"type": "Object",
"place_to": "id_place_to_go",
"x": 50,
"y": 200,
"spriteheight": 30,
"spritewidth": 60,
"colRect": {
"x": 0,
"w": 60,
"y": 0,
"h": 30
},
"animationSheet": {
"default": [0],
"mouseover": [1]
}
}
Type : ["collectableObject", "changeMapObject", "informationObject", "Object"]
Pour ajouter une carte :
1. Sauvegarder la carte en format JSON dans Tiled Map Editor
2. Utiliser le formulaire d'upload d'une carte (en bas de la page index)
{
"name": "ortho",
"type": "place",
"height": 30,
"layers": [
{
"data": [0,0,0,...],
"height": 30,
"name": "ref",
"opacity": 1,
"type": "tilelayer",
"visible": true,
"width": 30,
"x": 0,
"y": 0
}
],
"orientation": "orthogonal",
"properties": {
},
"tileheight": 15,
"tilesets": [
{
"firstgid": 1,
"image": "../images/backgrounds/fond.png",
"imageheight": 480,
"imagewidth": 843,
"margin": 0,
"name": "fond",
"properties": {
},
"spacing": 0,
"tileheight": 420,
"tilewidth": 840
},
{
"firstgid": 2,
"image": "../images/tiles/collision_ortho2.png",
"imageheight": 15,
"imagewidth": 30,
"margin": 0,
"name": "collision_ortho2",
"properties": {
},
"spacing": 0,
"tileheight": 15,
"tileproperties": {
"0": {
"type": "solid"
}
},
"tilewidth": 30
}
],
"tilewidth": 30,
"version": 1,
"width": 30
}
{
"character": "NOM_PERSONNAGE",
"place": "NOM_PLACE",
"verb": "NOM_ACTION",
"effects": {
"economy": 5,
"energy": 5,
"money": 5,
"reputation": 5
},
"updatedAt": [
2013,
4,
4,
21,
31
]
}