readme - Middleware.txt
author bastiena
Fri, 13 Jul 2012 14:57:43 +0200
changeset 48 983d7be910c1
parent 41 d2f735d7763f
child 49 1c2834888adc
permissions -rw-r--r--
Front JS: pointers repaired + help added to gestures
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
41
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
     1
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.
9
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
     2
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
     3
Auteur : Alexandre BASTIEN.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
     4
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
     5
I) TraKERS - Eléments requis :
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
     6
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
     7
Les spécifications de Microsoft font état des éléments matériels et logiciels requis afin de pouvoir utiliser le SDK :
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
     8
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
     9
Besoins matériels :
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    10
    Capteur Kinect.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    11
    Processeur32-bit (x86) ou 64-bit (x64).
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    12
    Dual-core 2.66-GHz ou plus rapide.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    13
    Bus USB 2.0 dédié.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    14
    2 GB RAM.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    15
Besoins logiciels :
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    16
    Microsoft® Visual Studio® 2010 Express ou une autre édition de Visual Studio 2010 (si vous souhaitez développer).
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    17
    Windows 7.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    18
    NET Framework 4.0.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    19
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    20
Vous les trouverez ici si vous le souhaitez : http://www.microsoft.com/en-us/kinectforwindows/develop/release-notes.aspx
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    21
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    22
La version 4.0 du Framework est présente dans l'installation de TraKERS.
41
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    23
Néanmoins, par soucis de taille de l'installeur, il vous sera nécessaire d'installer le SDK 1.5 de Microsoft ici :
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    24
http://www.microsoft.com/en-us/kinectforwindows/develop/developer-downloads.aspx
9
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    25
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    26
II) TraKERS - Structure :
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    27
41
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    28
TraKERS v3.0 est composé de trois modules, le Middleware (utilisant la Kinect afin de détecter des gestes et de suivre la position des mains et plusieurs Fronts (développés en Processing et en Javascript), permettant de récupérer les messages OSC du Middleware par Client/Server TUIO ainsi que les WebSockets du Middleware par Client/Server WebSocket. Pour plus d'informations sur les Fronts, veuillez consulter la documentation située à la racine sous les noms Front Processing et Front Web.
9
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    29
40
bastiena
parents: 9
diff changeset
    30
Afin de permettre au Middleware d'envoyer des messages à un Front sous Processing, un client TUIO a été installé dans le Front et un serveur TUIO dans le Middleware.
bastiena
parents: 9
diff changeset
    31
Si on souhaite envoyer des données à une page web, un serveur WebSocket ayant un fonctionnement identique a été intégré.
9
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    32
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    33
Le middleware dispose d'une interface de debug permettant de connaître en temps réel la position de l'utilisateur à la Kinect. Ces fonctionnalités seront vues plus avant dans la partie Utilisation.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    34
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    35
Les sources des modules sont fournies lors de l'installation, n'hésitez pas à les consulter si besoin est.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    36
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    37
III) TraKERS - Utilisation :
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    38
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    39
Vous pouvez démarrer le Middleware ou bien le Front dans l'ordre que vous voulez.
41
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    40
Lorsque le Middleware est démarré, la Kinect s'allume et affiche ce qu'elle voit. Le capteur (situé le plus à gauche sur la Kinect) est alors allumé en rouge, signe que vous serez détecté si vous entrez dans son champ.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    41
Lorsque le bouton ON a été appuyé, il devient un bouton OFF, et permet d'éteindre la Kinect. Il est à noter que le fait de fermer la fenêtre éteint également le capteur de la Kinect, avant de quitter.
9
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    42
(Plus de détails sur la Kinect : http://fr.wikipedia.org/wiki/Kinect).
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    43
41
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    44
Lorsque vous êtes détectés, le squelette de la personne la plus proche s'affiche. Les rectangles sur la droite indiquent la proximité de l'utilisateur par rapport à la Kinect, plus la barre est remplie de bas en haut, plus l'utilisateur est proche du point d'interaction maximal (point dans lequel il suffit de tendre les bras pour que les mains soient dans la zone de recherche).
9
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    45
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    46
Il existe une zone de détection des mains, située par défaut entre 1m et 1,5m de la Kinect mais configurable. En dehors de cette zone, les mains sont toujours détectées, mais aucun signal n'est envoyé via le serveur TUIO. Il y a deux rectangles en haut de cette fenêtre, permettant d'indiquer si une main est entrée dans ce champ (main gauche/droite dans le champ se traduit par la coloration du rectangle gauche/droit en bleu, et par l'affichage en pixels des coordonnées de la main (sauf pour la profondeur, qui est en mètres).
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    47
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    48
Il est possible de paramétrer des éléments du Middleware, comme la délimitation du champ pour les mains, le host et le port pour le serveur et l'intervalle de temps minimum qui sépare deux détections de gestes.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    49
41
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    50
Si des erreurs surviennent durant le fonctionnement du Middleware, ceux-ci seront affichés en bas de la fenêtre. Lorsqu'un geste est détecté, une image est affichée puis disparaît de la fenêtre.
9
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    51
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    52
A) Position des mains :
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    53
41
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    54
Lorsqu'au moins une main entre dans le champ, ses/leurs coordonnées sont envoyées par le serveur au front.
9
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    55
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    56
B) Détection de gestes :
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    57
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    58
Pour l'instant, plusieurs gestes peuvent être détectés :
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    59
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    60
    SWIPE - Désigne un mouvement de claque horizontal, partant de la droite vers la gauche avec la main droite (et inversement pour la gauche). Durant le geste, la main ne doit pas descendre sous la hanche ni aller au dessus de la tête. Il lui faut une certaine longueur de parcours et elle ne doit aller que vers la gauche pour la main droite et vers la droite pour la main gauche. Le swipe peut donc être pour l'instant gauche ou droit.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    61
    Lorsque ce geste est détecté, le bas de la fenêtre se colore en rouge si le swipe est vers la gauche.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    62
    Lorsque ce geste est détecté, le bas de la fenêtre se colore en violet si le swipe est vers la droite.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    63
    
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    64
    PUSH/PULL - Mouvement de poussée/traction rectiligne dirigé vers la kinect à partir de l'emplacement actuel de la main effectuant le geste.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    65
    Lorsque ce geste est détecté, le bas de la fenêtre se colore en blanc s'il s'agit d'un push.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    66
    Lorsque ce geste est détecté, le bas de la fenêtre se colore en noir s'il s'agit d'un pull.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
    67
    
40
bastiena
parents: 9
diff changeset
    68
    JUMP - Action de sauter vers le haut.
41
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    69
    
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    70
    FALL - Action de s'accroupir.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    71
    
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    72
    BEND - Action de se pencher en avant.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    73
    
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    74
    KNEE-UP - Action de lever le genou.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    75
    
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    76
C) Paramètres de configuration.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    77
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    78
Ceux-ci sont accessibles dans le fichier config.txt situé dans le même dossier que l'exécutable du Middleware nommé MainModule.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    79
Ils sont actuellement de la forme :
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    80
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    81
Les valeurs nominales min/max définissent la distance min (plus proche) et max (plus éloignée) par rapport à la Kinect et pas à l'utilisateur.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    82
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    83
Les variables de types float acceptent les valeurs de type N.Mf ou N,M. N étant un entier relatif et M étant un entier naturel.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    84
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    85
minDistHands:1,0                    Distance min de la zone de recherche pour les mains.                                        Type float.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    86
minDist:1,0                            Distance min de la zone de détection globale de l'utilisateur.                                 Type float.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    87
takenPoints:10                        Nombre de points pris dans une courbe de recherche. (En développement).                        Type entier.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    88
directionChangeTresholdXY:10        Pixels parcourus avant de segmenter une courbe. (En développement).                            Type entier.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    89
imagesToShow:20                        Nombre d'images à afficher dans la mosaïque du Front IDILL. (Autre projet).                    Type entier.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    90
maxDistHands:1,5                    Distance max de la zone de recherche pour les mains.                                        Type float.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    91
maxDist:3,0                            Distance max de la zone de détection globale de l'utilisateur.                                Type float.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    92
zeroPoint:1,9                        Distance du point d'interaction maximal.                                                    Type float.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    93
directionChangeTresholdZ:0,1        Nombre de mètres avant de segmenter une courbe en profondeur. (En développement).            Type float.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    94
tuioConnexionHost:127.0.0.1            Host du serveur TUIO.                                                                        Type string.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    95
tuioConnexionPort:8080                Port du serveur TUIO.                                                                        Type entier.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    96
tuioTimerElapsing:1000                Temps de latence en ms pour l'affichage et l'envoi des notifications de gesture. TUIO.        Type entier.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    97
wsConnexionHost:127.0.0.1            Host du serveur WebSocket.                                                                    Type string.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    98
wsConnexionPort:8090                Port du serveur WebSocket.                                                                    Type entier.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
    99
wsTimerElapsing:1000                Temps de latence en ms pour l'affichage et l'envoi des notifications de gesture. WS            Type entier.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   100
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   101
Voici les règles à respecter lors de l'affectation des valeurs des paramètres :
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   102
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   103
1) maxDistHands doit être supérieur à 0f.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   104
2) minDistHands doit être supérieur à 0f.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   105
3) maxDistHands doit être inférieur ou égal à maxDist.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   106
4) minDistHands doit être inférieur ou égal à maxDist.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   107
5) minDistHands doit être inférieur à maxDistHands.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   108
6) zeroPoint doit être supérieur ou égal à maxDistHands.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   109
7) minDistHands doit être inférieur ou égal à minDist.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   110
8) zeroPoint doit être inférieur à maxDist.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   111
9) tuioConnexionPort doit être supérieur ou égal à 0.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   112
10) wsConnexionPort doit être supérieur ou égal à 0.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   113
11) tuioTimerElapsing doit être supérieur ou égal à 0.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   114
12) wsTimerElapsing doit être supérieur ou égal à 0.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   115
13) imagesToShow doit être supérieur ou égal à 1.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   116
14) takenPoints doit être supérieur à 0.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   117
15) directionChangeTresholdXY doit être supérieur ou égal à 0.
d2f735d7763f Middleware:
bastiena
parents: 40
diff changeset
   118
16) directionChangeTresholdZ doit être supérieur ou égal à 0.
9
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
   119
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
   120
IV) Mention(s) importante(s) pour le debug :
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
   121
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
   122
Il semblerait que l'implémentation actuelle de TUIO dans ce projet ne gère pas le multi-client.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
   123
Par conséquent, le premier client Processing à se connecter au Middleware est le seul à recevoir des messages.
0f44b7360c8d Installer updated
bastiena
parents:
diff changeset
   124
40
bastiena
parents: 9
diff changeset
   125
Par contre, le serveur WebSocket permet de gérer le multi-client.
bastiena
parents: 9
diff changeset
   126
Si vous expérimentez des difficultés ou souhaitez me soumettre une requête, voici mon adresse : alexandre.bastien@iri.centrepompidou.fr
bastiena
parents: 9
diff changeset
   127
48
983d7be910c1 Front JS:
bastiena
parents: 41
diff changeset
   128
Paramétrage : Le Middleware était conçu à l'origine pour permettre une modification de la configuration via une fenêtre durant le runtime. Il semblerait que Fleck provoque un comportement innatendu de cette fenêtre. Par conséquent, il est nécessaie de modifier le fichier config.txt à la racine de Middleware si on souhaite modifier les paramètres du Middleware. En cas de problème, le fichier ErrorFile.txt est créé dans ce même dossier.
983d7be910c1 Front JS:
bastiena
parents: 41
diff changeset
   129
983d7be910c1 Front JS:
bastiena
parents: 41
diff changeset
   130
Si vous expérimentez des difficultés ou souhaitez nous soumettre une requête, veuillez consulter le fichier contact.txt à la racine du projet.