>> La recherche se fait sur tous les élements du jeu Minecraft <<
Aidez nous a financer le site: Joignez l'utile à l'agréable et profitez d'FR-Minecraft sans publicités en devenant VIP ! Ou ajoutez FR-Minecraft dans vos exceptions, nous n'abusons pas des pubs
Aidez nous a financer le site: Joignez l'utile à l'agréable et profitez d'FR-Minecraft sans publicités en devenant VIP ! Ou ajoutez FR-Minecraft dans vos exceptions, nous n'abusons pas des pubs

Mod API: l'avenir du modding

Le 02/07/2012 à 13h52
Aidez nous a financer le site: Joignez l'utile à l'agréable et profitez d'FR-Minecraft sans publicités en devenant VIP ! Ou ajoutez FR-Minecraft dans vos exceptions, nous n'abusons pas des pubs

Samedi 20h, EvilSeph, Grum et Tahg, développeurs de bukkit mais aussi et surtout développeurs de Minecarft chez Mojang ont organisé un grande réunion entre eux et la communauté des développeurs de Mod Minecraft.


La liste des invités

De grand nom dans la scène Minecraftienne internationnale étaient invités à cet échange:
- Afforess (Spout)
- Amaranth (Bukkit)
- Cojo (mod Tropicraft)
- DV8FromTheWorld (MC Port Central)
- FlowerChild (Better Than Wolves)
- Jarvix (Canary)
- Kulttuuri (MinecraftEdu)
- Eloraam (RedPower/Forge)
- LexManos (Forge)
- medsouz (SocialMiner)
- Xie (Xie's Mod)
- RoyAwesome (Spout)
- UltraMoogleMan (Kataminey Damacraft/CCTV/etc)
- Searge (projet MCP (support de 98% des mods Minecraft))
- Snowl (Minecraft beta and classic server dev)
- sk89q (WorldEdit/WorldGuard/CraftBook/Bukkit)

Les discutions nous ont permis de comprendre les grandes lignes de l'evolution future de Minecraft, et plus particulièrement de l'API de modding.


Mais d'abord, c'est quoi ca, cette API de modding ?

Il est existe actuellement de très nombreux mod pour minecraft. "mod" signifie "modification" car ils modifient le jeu (au niveau gameplay, mais aussi techniquement parlant). Ces mod permettent d'ajouter des mobs, des blocs, des craftings, etc... Les développeurs de mod peuvent faire à peu près tout ce qu'ils veulent comme modification !
Problème: cela n'est pas supporté par Mojang, et cela a de nombreuses consequences :
- 2 mods avec des fonctionnalités similaires seront totalement incompatible (impossible d'installer les 2 en même temps)
- L'installation des mod est souvent très fastidieuse (neccessite certaines compétances techniques)
- Les mods sont fait pour fonctionner en mode solo uniquement, très rare sont les mod fonctionnant en mode multijoueur, et dans ces cas là un plugin serveur est neccessaire. De plus les serveurs moddés deviennent incompatibles avec le jeu normal (sans le mod).
- Le développement de mod est extremement laborieux pour les developpeurs, en effet faire un mod consiste à modifier le jeu lui même. Hors Mojang crypte ses sources (obfusque pour être précis) pour se protéger des copies, ce qui rend la tâche complexe. C'est la raison d'être du projet MCP qui permet de développer des plugins à partir de ces sources obfusquées.

API signifie "Application Programming Interface", soit en francais une Interface de Programmation d'Application. En d'autres termes c'est une interface qui permet de faire communiquer 2 logiciels ensemble, une sorte de language commun, par exemple faire communiquer Minecraft avec ses mods. L'API de modding permettra de résoudre tous les problèmes des mods en même temps ! Cela remplacera les mods actuels par un système de plugin (techniquement un plugin est une extension du jeu, et non une modification).
- Les plugins seront facile à installer (copier un fichier jar dans le dossier plugin, et c'est tout)
- Plus de problème de conflits entre les mods: plusieurs plugins pourront agir sur les mêmes données
- Développement des plugins grandement facilité : l'API fourni aux développeurs de mod sera publique et documentée (et bien sur non obfusquée)
- Les plugins solo pourront également fonctionner en multijoueur si on les installe sur un serveur !

Cependant ce projet néccessite de réécrire une grande partie de Minecraft, il va prendre des mois (voir des années).


Quels seront les évolutions dans Minecraft ?

Partant de ce constat, les développeurs Mojang ont demandé aux developpeurs de Mod ce qu'ils souhaitaient, et ont presenté leur projet.

Premier changement important, le fonctionnement même du jeu Minecraft: Le mode solo va devenir un mode client-serveur en local. Cette première étape a déjà était franchie et vous pourrez la découvrir avec la sortie de la version 1.3. Au niveau gameplay cela ne changera pas grand chose, en revanche techniquement c'est une révolution. Les développeurs de Minecraft n'auront plus à faire le boulot en double: une fois pour le mode solo, et une fois pour le mode multijoueur, tout sera centralisé !

Ensuite autre changement majeur (technique toujours): la partie cliente perdra énormement de controle sur le jeu et par conséquent la charge du serveur va augmenter. Prenons un exemple concret :
- Aujourd'hui lorsqu'un joueur marche, le joueur appuie sur la touche "avancer", le client (son jeu) calcule son déplacement et envoit la nouvelle position X/Y/Z au serveur, le serveur valide ce changement et le renvoit à tous les autres joueurs du serveur. Cela fonctionne bien, c'est rapide est réactif, mais ca rend egalement le cheat très facile: si le joueur utilise un mod pour voler, le client envoi au serveur une position dans les airs, et le serveur renvoi cette position à tout le monde: le joueur cheat, sans aucun problème.
- Demain le rôle du client sera réduit à un terminal: Le joueur veux avancer, il appuie sur "avancer", son jeu (client) ne calcule plus rien, il envoit directement la commande avancer au serveur qui lui calculera son deplacement, et renvera la nouvelle position à tous les joueurs. Tous les cheat majeurs deviendront impossible ! Le client sera limité à la gestion de la partie graphique (c'est a dire l'affichage du monde, seuls les cheat graphique seront par conséquent encore possible).
--> Problème, cela augmentera énormement la charge de travail pour les serveurs, cela n'engendrera-t-il pas de nombreux lag en plus ? Autre probleme, le jeu sera-t-il encore réactif lors qu'il faudra attendre un aller/retour serveur pour voir son personnage avancer apres avoir appuyé sur la touche "avancer" ? Les développements futurs nous le diront.

Concernant l'installation des plugins, là encore de gros changement. Actuellement la procédure classique consiste a dezippé son minecraft.jar, à remplacer des fichiers *.class, puis à le recompresser. Cela est fastidieux et difficile techniquement pour les non initiés.
Les développeurs de chez Mojang en charge du projet de l'API de modding, qui sont également les développeurs du projet Bukkit (le logiciel de serveur minecraft le plus populaire, possédant un système de plugin très evolué) vont reprendre le système de plugin de Bukkit pour l'adapté à Minecraft.
Et sur bukkit, l'installation d'un plugin est beaucoup plus simple ! Télécharger votre plugin, copier le dans le dossier "plugins"... c'est fini, ca marche :-) Les plugins Minecraft fonctionneront sur ce même principe. Il est probable que Mojang mettent en place un site dédié à l'hébergement de plugins, ce qui pourrait par exemple permettre d'installer des plugins directement depuis le jeu lui même !

Coté serveur cela devrait beaucoup bouger également.
D'abbord la possibilité prochaine pour les serveurs de proposer leur pack de textures à leur joueurs, pack de texture qui s'appliquera directement à la connection au serveur. Cettte annonce avait déjà était faite, mais ce qui est nouveau c'est que ce principe pourrait être identique pour les mods Minecraft ! Ainsi un joueur qui se connecte à un serveur pourrait recevoir du serveur un certain nombre de mod qui seront installés le temps de la partie sur ce serveur. Cela permettrai d'offrir des serveurs multijoueurs aux fonctionnalité toujours plus variés, puisque les mod client seront compatible avec les serveurs multijoueurs ! Par extension il est possible qu'un système d'authentification du jeu lui même permette de s'assurer que les joueurs n'utilisent plus des versions modifiées de Minecraft, cela pour lutter contre le cheat. (Les versions modifiées n'ayant plus de raison d'être, puisque les plugins remplaceront les mods).

Cet article a été publié par Tronics, le 2012-07-02 13:52:59.
Partager :
Commentaires de la news Minecraft
Mod API: l'avenir du modding :
le 02/07/2012 à 15:10
ben dis donc ! j'espère encore être de ce monde quand tous ça sera opérationnel !!
pc1971 (anonyme)
le 02/07/2012 à 15:23
c'est un truc de malade !
Batman (anonyme)
le 02/07/2012 à 15:38
Pas Mal Du tout !! Je suis très très très Impatient :
le 02/07/2012 à 19:04
sa me fait penser a spoutcraft tout sa avec le système de téléchargement de Plug-in qui s’installe et on peut jouer
le 02/07/2012 à 19:39
Ils font un de ces boulots à Mojang ! Vivement qu'on voit ça !
Nigel10102020 (anonyme)
le 02/07/2012 à 20:14
Ha oui c'est un truc de fou !
EssentialCrafterLP (anonyme)
le 02/07/2012 à 20:18
Mais une question. Pour les Home Server, si ils gardent la meme connections (500kb) alors le temps de reponse sera plus grand puisque le pack de textures devra etre envoier ou pas ... Et en plus souvent les Home server n ont pas un processeur de malade type amd - intel 3.50 GHz cache L2 10 MB pour calculer le deplacement des joueuers ... Esperons une version 'light'
fantome ff (anonyme)
le 02/07/2012 à 20:23
WAOW super vive la 1.3!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!super cool tous ca
le 02/07/2012 à 20:42
j'espère que le mod Aether sera disponible en Plug-in à la suite des ses changements vivement tout sa !
Sylenzio (anonyme)
le 02/07/2012 à 21:10
J'espère aussi qu'il mettront le mod aether :) Pk pas l'intégrer au jeu ! Enfin bref que du lourd qu'on nous apprend la :) Bien pour les futurs joueurs de Minecraft :D
le 02/07/2012 à 23:03
ça a l'air monstrueux mais c'est vrai que ça fait peur, au niveau des lag et il n'y aura plus de mod ? (retennons en exemple que moi, qui arrive a installer des mods en solo sans bug sur mon mac, j'ai tut le mal du monde a installer un plugin sur mon server bukkit, a la maniere "facile") et
pour des serveurs qui pourrons avoir des txture pack, ça c'est cool !
le 03/07/2012 à 00:35
oui et bien plus encore que les texture pack les plug-in installer sur les serveur devrai s'installer sur notre client minecraft le temps de jouer sur le serveur. Plus besoin de launcher et ça aussi c'est cool !
opfjpepdjed (anonyme)
le 03/07/2012 à 11:35
trop long j'ai pas tout lus
le 04/07/2012 à 00:07
C'est vrai que , au niveau des lags , ce va être dur car la plupart des serveur quelquil soit ,lagge , par conséquent , cela ferait lagger encore plus les serveur , cela deviendrai injouable !!!
Ensuite , au niveau des mods et des pack de texture sur les serveurs , très très bonnes chose car par exemple , la map de serveur étant une ville romaine , cela permettrait de mettre un pack de texture romain qui donnerait tout le charme au serveur ! Quand aux mods , ca risque de faire lagger les serveurs , mais bon , on verra une fois la MAJ sorti !!
Cela m'annonce tout de même très prometteur , j'ai hâte de voir tous ca , malheureusement ca risque de leur prendre pas mal de temps pour faire tous ca !!!

1.3 !! :)
Maxou44210 (anonyme)
le 04/07/2012 à 10:59
Sur d'autres jeux, la plupart du temps c'est le serveur qui calcule les coordonnées du joueur, le problème ici c’est que le serveur consomme déjà énormément (Le serveur peux me prends jusqu'à 3Go de ram et 4/5 GHz de processeur !) La solution qui permettrait de résoudre tous les problème de consommation excessive serait de totalement recoder le jeu ! Dans un langage plus adapté comme le C/C++, la tache serait incroyable mais ça permettrait de supprimer tous les lag présent sur le client et le serveur :), car le Java n'est pas adapté pour faire de gros jeux comme celui-ci ! On a pu le voir, la version Xbox de minecraft à été totalement recoder et ne pose pas de problème de lag coté client alors que la Xbox 360 a des capacité technique inférieure à la plupart des pc actuellement dans le commerce.

Voil :D
smider (anonyme)
le 05/07/2012 à 11:11
Si je comprends bien les serveurs multijoueurs vont disparaitre ?
le 05/07/2012 à 18:32
trop cool !!!
norfair (anonyme)
le 05/07/2012 à 23:39
vive le modding vive minecraft vive fr-minecraft.net
gwendal123 (anonyme)
le 16/07/2012 à 18:02
j'arrive pas à telecharger des mods

Vous devez être connecté pour laisser un commentaire.