<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en" class="has_sidebar fixed-header earthrise">
<head>
<meta content="text/html; charset=UTF-8" http-equiv="content-type" />
<meta name="description" content="Tutoriel sur le développement et l'utilisation de code Processing utilisant le Middleware TraKERS."/>
<meta name="keywords" content="TraKERS, TraKERS Processing, TraKERS Front Processing, TraKERS Front, Kinect Processing"/>
<title>TraKERS v3.5 - Tutorial Processing</title>
</head>
<body>
<p>TraKERS (Tracking using Kinect and Extracting Robust Skeletons) est une interface basée sur la détection de gestures / positions du squelette envoyé par le SDK Microsoft (1.5) de Kinect. Il est composé d'un Middleware assurant l'interaction avec Kinect, un rendu visuel et l'envoi de notifications sous forme de messages OSC.
Le deuxième module de ce projet est un Front en Processing doté d'un client TUIO et récupérant les messages OSC (sous forme d'objets tels que des Curseurs ou des Strings).</p>
<p>Ce tutoriel concerne ce second module et a pour but d'expliquer le fonctionnement général d'un sketch Processing et la récupération des notifications du Middleware. Il sera agrémenté d'exemples fonctionnels créés pour les besoins de ce tutoriel ou inspirés d'exemples réels disponibles sur le site processing.org.</p>
<h2>Sommaire</h2>
<ol type="I">
<a href="#I"><li>Installation de Processing</li></a>
<a href="#II"><li>Structure d'un sketch</li></a>
<a href="#III"><li>Fonctions principales de Processing</li></a>
<a href="#IV"><li>Récupérer les objets envoyés par le Middleware TraKERS via un Client TUIO</li></a>
<a href="#V"><li>Interactions entre les objets TUIO récupérés et des fonctions de dessin basiques</li></a>
<a href="#VI"><li>Quelques exemples d'implémentation</li></a>
<a href="#VII"><li>Références</li></a>
</ol>
<hr />
<ol type="I" start="1">
<h3><a name="I"><li>Installation de Processing</li></a></h3>
</ol>
<p>Avant de pouvoir modifier les sketches Processing fournis dans l'installateur, il est nécessaire d'installer Processing.<br />
Vous trouverez l'archive ici :</p>
<a href="http://processing.googlecode.com/files/processing-1.5.1-windows.zip">Processing pour Windows avec Java</a><br />
<a href="http://processing.googlecode.com/files/processing-1.5.1-windows-expert.zip">Processing pour Windows sans Java</a>
<p>Une fois téléchargé, il vous suffit de le dézipper, et d'affecter tous les types de fichiers .pde à l'exécutable Processing fourni dans l'archive.</p>
<p>Si ce n'est pas déjà fait, il peut être utile de spécifier dans le path Windows l'emplacement du répertoire où vous avez extrait l'archive.</p>
<hr />
<ol type="I" start="2">
<h3><a name="#II"><li>Structure d'un sketch</li></a></h3>
</ol>
<p>Un sketch est représenté par un dossier, contenant plusieurs choses :
<ul>
<li>Un ou plusieurs fichiers d'extension .pde (Qui contiennent le code Processing). Le .pde principal doit avoir le même nom que le dossier qui les contient.</li>
<li>Un dossier code, contenant les libraries appelées dans les fichiers .pde.</li>
</ul>
Si le sketch a été exporté en application, le dossier principal contient également jusqu'à trois dossiers, qui sont :
<ul>
<li>application.linux (si l'option Linux a été cochée durant l'export).</li>
<li>application.macosx (si l'option Mac OS X a été cochée durant l'export).</li>
<li>application.windows (si l'option Windows a été cochée durant l'export).</li>
</ul>
Ceux-ci contiennent les applications compilées du code source des fichiers .pde.<br />
Il est également possible d'exporter un applet. On obtiendra donc :
<ul>
<li>applet (si l'option Linux a été cochée durant l'export).</li>
</ul>
</p>
<p>Concernant le projet TraKERS, les sketches fournis peuvent contenir différents fichiers .pde (un pour chaque classe), un fichier TuioFunctions.pde permettant de récupérer les objets TUIO envoyés par le Middleware et un fichier principal du même nom que le sketch.</p>
<hr />
<ol type="I" start="3">
<h3><a name="#III"><li>Fonctions principales de Processing</li></a></h3>
</ol>
<p>En Processing, les variables déclarées absolues (en dehors d'une fonction ou d'une classe) sont visibles dans tous les autres fichiers .pde du sketch. Il en va de même pour les classes et fonctions (et non méthodes de classe, qui est une fonction appartenant à la classe et donc ne pouvant être appelée qu'en créant un objet de cette classe).</p>
<p>Il existe deux fonctions principales, qui sont :
<ul>
<li>void setup() : Initialise les différentes variables du sketch.</li>
<li>void draw() : Fonction rappelée automatiquement, destinée à contenir des instructions de dessin ou des appels de fonctions.</li>
</ul>
La gestion des événements souris est naturelle, comme l'indique l'exemple ci-dessous:<br /><br />
<code>
public void setup()<br />
{<br />
size(200,200);<br />
background(0);<br />
}<br />
<br />
public void draw()<br />
{<br />
stroke(255);<br />
if(mousePressed)<br />
{<br />
line(mouseX,mouseY,pmouseX,pmouseY);<br />
}<br />
}<br />
</code>
<br />
</p>
<hr />
<ol type="I" start="4">
<h3><a name="#IV"><li>Récupérer les objets envoyés par le Middleware TraKERS via un Client TUIO</li></a></h3>
</ol>
<p>Les objets TUIO exploités dans le cadre de TraKERS sont de deux types :
<ul>
<li>TuioCursor : Les curseurs sont utilisés pour transmettre des points au Front Processing. On récupère leurs coordonnées sous forme de TuioPoint, qui possèdent comme attributs les valeurs du point en X, Y et Z.</li>
<li>TuioString : Elles comportent une String ayant pour valeur la notification du Middleware en cas de détection de gesture par exemple.</li>
</ul>
</p>
<p>Voici les différentes implémentations permettant d'accéder à ces objets via le client.
On appelle dans cet exemple plusieurs fonctions si des curseurs on été reçus par le client.<br />
Un curseur représente une main dans la zone de recherche des mains présente dans le Middleware.<br /><br />
<code>
void tuioInput()<br />
{<br />
Vector tuioCursorList = tuioClient.getTuioCursors();<br />
<br />
if(tuioCursorList.size() <= 0)<br />
{<br />
//Code si on ne reçoit pas de curseurs <=> que aucune main n'est dans la zone de recherche des mains.<br />
}<br />
<br />
if(tuioCursorList.size() == 1)<br />
{<br />
//Code si une main est détectée.<br />
//Par exemple, on peut faire appel à une fonction qu'on nommera arbitrairement handleOneHand et qui prendra en paramètre le curseur.<br />
handleOneHand(tuioCursorList.elementAt(0));<br />
}<br />
else if(tuioCursorList.size() == 2)<br />
{<br />
//Code si les deux mains sont détectées.<br />
//Par exemple, on peut faire appel à une fonction qu'on nommera arbitrairement handleBothHands et qui prendra en paramètre la liste des curseurs récupérés par le client.<br />
handleBothHands(tuioCursorList);<br />
}<br />
}<br />
</code>
Le code suivant montre comment on peut extraire le point contenu dans le curseur.<br />
<code>
void handleOneHand(TuioCursor handCursor)<br />
{<br />
TuioPoint pt = handCursor.getPosition();//(TuioPoint)pointList.get(j);<br />
//Code manipulant le point.<br />
//Par exemple un affichage de texte.<br />
text(pt.getX() + " " + pt.getY() + " " + pt.getZ());<br />
}<br />
</code>
Le code suivant montre comment on peut extraire les points contenus dans une liste de deux curseurs.<br />
<code>
void handleBothHands(Vector tuioCursorList)<br />
{<br />
TuioCursor handLeftCursor = (TuioCursor)tuioCursorList.elementAt(0);<br />
TuioCursor handRightCursor = (TuioCursor)tuioCursorList.elementAt(1);<br />
TuioPoint pt;<br />
<br />
pt = (TuioPoint)handLeftCursor.getPosition();<br />
//Code pour traiter la position de la première main.<br />
//Par exemple un affichage de texte.<br />
text(pt.getX() + " " + pt.getY() + " " + pt.getZ());<br />
pt = (TuioPoint)handRightCursor.getPosition();<br />
//Code pour traiter la position de la seconde main.<br />
//Par exemple un affichage de texte.<br />
text(pt.getX() + " " + pt.getY() + " " + pt.getZ());<br />
}<br />
</code>
</p>
<p>On appelle dans cet exemple une fonction si un message a été reçu par le client.<br />
Un message représente un événement notifié par le Middleware.<br /><br />
<code>
void tuioInput()<br />
{<br />
Vector tuioStringList = tuioClient.getTuioStrings();<br />
if(tuioStringList.size() <= 0)<br />
{<br />
text("Gesture non détectée.");<br />
}<br />
else<br />
{<br />
TuioString message = (TuioString)tuioStringList.elementAt(0);<br />
text(message.getMessage());<br />
}<br />
}<br />
</code>
</p>
<hr />
<ol type="I" start="5">
<h3><a name="#V"><li>Interactions entre les objets TUIO récupérés et des fonctions de dessin basiques</li></a></h3>
</ol>
<p>Dans les exemples de code vu précédemment, nous aurions pu remplacer la fonction text() par une fonction de votre cru, comme celle-ci :<br /><br />
<code>
//Cette fonction dessine une ellipse à la position (x;y;z) et prend en paramètre la fait qu'il s'agisse de la main droite ou gauche.<br />
void drawEllipse(float x, float y, float z, boolean leftHand)<br />
{<br />
//On met la couleur de ce qui va venir en bleu.<br />
fill(0, 0, 255);<br />
//On ne met pas de bordure à ce qu'on va afficher.<br />
stroke(0,0,0);<br />
//On créer un point, une épaisseur de forme.<br />
//Z est la distance de la main par rapport à Kinect. La zone de recherche des mains est toujours comprise entre minDistHands et maxDistHands<br />
float weight = map(z, minDistHands, maxDistHands, 50, 1);<br />
float redColor = map(z, minDistHands, maxDistHands, 255, 80);<br />
<br />
//S'il s'agit de la main gauche, on colore en tons de rouge.<br />
if(leftHand)<br />
fill(redColor,0,0);<br />
//Sinon en tons de vert.<br />
else<br />
fill(0,redColor,0);<br />
<br />
//Si le trait est assez gros, on color en tons de bleu.<br />
if(weight >= 30)<br />
{<br />
fill(0, 0, redColor);<br />
}<br />
<br />
//On dessine une ellipse.<br />
ellipse(x+20, y+100, weight, weight);<br />
}<br />
</code>
</p>
<hr />
<ol type="I" start="6">
<h3><a name="#VI"><li>Quelques exemples d'implémentation</li></a></h3>
</ol>
<p>Les exemples fournis dans l'installeur sont répartis dans 4 dossiers principaux :
<ul>
<li>Trakers : Permet d'afficher des ellipses sur le passage d'une ou deux mains se situant à une certaine distance de Kinect.</li>
<li>Trakers_gestures : Permet d'afficher le code des gestures détectées par Kinect et notifiées depuis le Middleware.</li>
<li>Fluid_manipulation (code importé de processing.org) : Simule l'action des mains sur un fluide.</li>
<li>Smoke_manipulation (code importé de processing.org) : Simule l'action des mains sur de la fumée.</li>
<li>Interaction examples (code importé de processing.org) : Quelques petits exemples utilisant des formes basiques et réagissant à la position de la main la plus proche de Kinect.</li>
</ul>
</p>
<hr />
<ol type="I" start="7">
<h3><a name="#VII"><li>Références</li></a></h3>
</ol>
<p>Voici quelques liens utiles où se trouvent les dépendances trop lourdes pour être incluses dans cet installeur. Ils vont permettront également d'approfondissant vos connaissances sur Processing ou TUIO.
Il vous est possible d'utiliser eclipse pour compiler du Processing.
<ul>
<li><a href="http://www.microsoft.com/en-us/kinectforwindows/develop/developer-downloads.aspx">SDK Kinect 1.5 de Microsoft</a></li>
<li><a href="http://www.tuio.org/">TUIO</a></li>
<li><a href="http://processing.org/">Processing.org</a></li>
<li><a href="http://bodytag.org/">Autres exemples en Processing</a></li>
<li><a href="http://processing.org/learning/eclipse/">Processing sous eclipse</a></li>
</ul>
</p>
<p>Si vous expérimentez des difficultés ou souhaitez nous soumettre une requête, veuillez consulter le fichier contact.txt à la racine du projet.</p>
</body>
</html>