2017-05-23 17:36:54 +02:00
# ifndef FONCTION_H
# define FONCTION_H
2017-05-25 13:55:18 +02:00
/**
* \ file fonction . h
* \ author Jacques / Antoine
* \ date avril - mai 2017
* \ brief Bibliothèque , Headers et Documentation des fonctions
*
*/
2017-05-23 17:36:54 +02:00
/*INCLUDE*/
# include <stdio.h>
# include <stdlib.h>
# include <cv.h>
# include <highgui.h>
//#include <opencv2/highgui.hpp> //Pour le cvRound
//#include "opencv2/videoio/videoio_c.h" //Pour le CvCapture*
//#include <cxcore.h>
//#include <SFML/Window.h>
# include <SFML/Audio.hpp>
# include <SFML/Graphics.hpp>
# include <SFML/Window.hpp>
2017-05-25 18:05:22 +02:00
//#include <SFML/System.hpp> //inutilisé pour le moment
2017-05-23 17:36:54 +02:00
/*DEFINE*/
//ATTENTION AFFICHAGE OPENCV INCOMPATIBLE AVEC AFFICHAGE SFML
//ATTENTION SFML SUPPORTE UN NOMBRE LIMITE DE SPRITE EN FCT DU PC
# define JEU 0.15
2017-05-25 13:55:18 +02:00
/**
* \ def SFML
* \ brief Programme en mode affichage interface utilisateur
*
* \ def CONFIG
* \ brief Programme en mode configuration couleur
*
* \ def KIRBY
* \ brief Programme en mode suivi de Kirby ( Objet rose )
*
* \ def ETOILE
2017-05-30 18:12:25 +02:00
* \ brief Programme en mode suivi de l ' é toile ( Objet jaune )
2017-05-25 13:55:18 +02:00
*
* \ def JEU
* \ brief Coefficient de tolérance pour le suivi d ' objet
2017-05-30 18:12:25 +02:00
*
* \ def MAX_FACE
* \ brief Nombre maximum de faces traitées
2017-05-25 13:55:18 +02:00
*/
2017-05-25 18:05:22 +02:00
//#define CONFIG
# define SFML
2017-05-23 17:36:54 +02:00
# define KIRBY
//#define ETOILE
# define MAX_FACE 2
2017-05-30 18:12:25 +02:00
/**
* \ struct face
* \ brief Contient les informations sur chaque face détectée : positions , largeur
* \ param point coordonnées en x et y du centre de la face
* \ param largeur largeur de la face
*/
2017-05-23 17:36:54 +02:00
/*STRUCTURE*/
typedef struct _face {
2017-05-30 18:12:25 +02:00
CvPoint point ; /*!< coordonnées en x et y du centre de la face */
int largeur ; /*!< largeur de la face */
2017-05-23 18:00:19 +02:00
} face ;
2017-05-23 17:36:54 +02:00
2017-05-23 18:00:19 +02:00
typedef face * pface ;
2017-05-23 17:36:54 +02:00
2017-05-25 13:55:18 +02:00
2017-05-23 17:36:54 +02:00
/*HEADERS*/
2017-05-25 13:55:18 +02:00
/**
* \ fn void maj_angle ( int vecX , int vecY , int rayon , double * angle )
* \ brief Met à jour \ a angle selon la distance entre le centre de la caméra et la cible , avec un tolérance circulaire définie par rayon
* \ author Jacques
* \ param vecX composante X de la cible par rapport au centre de l ' image
* \ param vecY composante Y de la cible par rapport au centre de l ' image
* \ param rayon tolérance avant changement d ' angle
* \ param angle tableau contenant les deux angles à modifier
*/
2017-05-23 17:36:54 +02:00
void maj_angle ( int vecX , int vecY , int rayon , double * angle ) ; //Met à jour l'angle selon la distance CentreCamera - Cible
2017-05-25 13:55:18 +02:00
/**
* \ fn int ajust_pos ( int pos , int ref )
* \ brief permet d ' é viter des positions supérieures à ref considérées comme aberrantes .
* \ details retourne 0 si la position est supérieure à ref .
* \ author Jacques
* \ param pos position à tester
* \ param ref position de référence
* \ return renvoie la position corrigée
*/
2017-05-23 17:36:54 +02:00
int ajust_pos ( int pos , int ref ) ;
2017-05-25 13:55:18 +02:00
/**
* \ fn void controle_moteur ( double * angle )
* \ brief Fonction d ' envoie des angles aux moteurs
* \ details
* \ author Jacques
* \ param angle tableau des angles moteurs
*/
2017-05-23 17:36:54 +02:00
void controle_moteur ( double * angle ) ; //Envoie les angles au moteur
2017-05-25 13:55:18 +02:00
/**
* \ fn int limite_moteur ( int val_pwm )
* \ brief Fonction qui vérifie que les valeurs envoyees aux moteurs sont correctes
* \ details Valeur minimale = 30 , valeur maximale = 130 ( déterminées expérimentalement )
* \ author Jacques
* \ param val_pwm valeur pwm dont on veut vérifier la valeur
* \ return renvoie l ' angle corrigée
*/
2017-05-23 17:36:54 +02:00
int limite_moteur ( int val_pwm ) ; //Verifie que les valeurs envoyees aux moteurs sont correctes
2017-05-25 13:55:18 +02:00
/**
* \ fn void config ( int * LowH , int * HighH , int * LowS , int * HighS , int * LowV , int * HighV )
* \ brief Fonction d ' affichage du panneau de configuration de la \ a couleur à suivre
* \ author Antoine
* \ details Panneau de configuration comprenant 6 slidebarres pour configurer la couleur suivie en HSV . La fonction modifie les valeurs limites LowH /
* HighH de la plage HUE , LowS / HighS de la plage SATURATION , LowV / HighV de la plage VALUE .
* \ param LowH Valeur \ a basse de la plage de HUE suivie .
* \ param HighH Valeur \ a haute de la plage de HUE suivie .
* \ param LowS Valeur \ a basse de la plage de SATURATION suivie .
* \ param HighS Valeur \ a haute de la plage de SATURATION suivie .
* \ param LowV Valeur \ a basse de la plage de VALUE suivie .
* \ param HighV Valeur \ a haute de la plage de VALUE suivie .
*/
2017-05-23 17:36:54 +02:00
void config ( int * LowH , int * HighH , int * LowS , int * HighS , int * LowV , int * HighV ) ; //Affiche le panneau de configuration de tracking avec les arguments comme valeur de base
2017-05-25 13:55:18 +02:00
/**
* \ fn void affichage_config ( IplImage * frame , IplImage * HSV , IplImage * Binaire ) ;
* \ brief Fonction d ' affichage du flux vidéo , du flux en HSV et de sa binarisation
* \ author Antoine
* \ param frame image contenant la frame capturé par la caméra
* \ param HSV image contenant l ' image passé en HSV
* \ param Binaire image contenant l ' image binarisée
*/
2017-05-23 17:36:54 +02:00
void affichage_config ( IplImage * frame , IplImage * HSV , IplImage * Binaire ) ; //Affiche le flux vidéos et ses différent traitements
2017-05-25 13:55:18 +02:00
/**
* \ fn void Affichage_Tracking ( IplImage * frame , int posX , int posY , int width , int height )
* \ brief Fonction d ' affichage des informations de suivi
* \ details Dessine sur \ a frame la zone de tolérance de suivie au centre de l ' image et le curseur de position de l ' objet ayant pour coordonées \ a posX et \ a posY
* \ author Antoine
* \ param frame image a modifier
* \ param posX composante X du curseur a dessiner
* \ param posY composante Y du curseur a dessiner
* \ param width largeur ( en \ a pixel ) de \ a frame
* \ param height hauteur ( en \ a pixel ) de \ a frame
*/
2017-05-23 17:36:54 +02:00
void Affichage_Tracking ( IplImage * frame , int posX , int posY , int width , int height ) ; //Dessine les informations de tracking sur frame
2017-05-25 13:55:18 +02:00
/**
* \ fn void Position_moy ( IplImage * Binaire , int * posX , int * posY )
* \ brief Effectue le baricentre des pixels d ' une image binaire pour obtenir la postion de l ' objet
* \ author Antoine
* \ param Binaire image binarisée ( matrice de 0 ou de 1 )
* \ param posX contient la composante X du barycentre
* \ param posY contient la composante Y du barycentre
*/
2017-05-23 17:36:54 +02:00
void Position_moy ( IplImage * Binaire , int * posX , int * posY ) ; //Effectue le baricentre des pixels d'une image binaire pour obtenir la postion de l'objet
2017-05-25 13:55:18 +02:00
/**
* \ fn void traitement ( IplImage * frame , IplImage * HSV , IplImage * Binaire , int LowH , int HighH , int LowS , int HighS , int LowV , int HighV )
* \ brief Effectue une binarisation de \ a frame en fonction des bornes \ a HSV
* \ details Passe la frame en HSV puis binarise l ' image en fonction des bornes LowH , HighH , LowS , HighS , LowV , HighV
* \ author Antoine
* \ param frame image contenant la frame capturé par la caméra
* \ param HSV image contenant l ' image passé en HSV au terme de la fonction
* \ param Binaire image contenant l ' image binarisée au terme de la fonction
* \ param LowH Valeur \ a basse de la plage de HUE suivie .
* \ param HighH Valeur \ a haute de la plage de HUE suivie .
* \ param LowS Valeur \ a basse de la plage de SATURATION suivie .
* \ param HighS Valeur \ a haute de la plage de SATURATION suivie .
* \ param LowV Valeur \ a basse de la plage de VALUE suivie .
* \ param HighV Valeur \ a haute de la plage de VALUE suivie .
* \ bug Nécessite changement de l ' utilisation de cvInRangeS sur certain PC
*/
2017-05-23 17:36:54 +02:00
void traitement ( IplImage * frame , IplImage * HSV , IplImage * Binaire , int LowH , int HighH , int LowS , int HighS , int LowV , int HighV ) ; //Effectue une binarisation de frame en fonction des bornes HSV
2017-05-30 18:12:25 +02:00
/**
* \ fn int image_CV2SFML ( IplImage * imcv , sf : : Image imFlux )
* \ brief Convertit une image opencv ( IplImage ) en une image SFML ( sf : : Image )
* \ author Antoine
* \ param imcv image OpenCv à convertir
* \ param imFlux image SFML convertie en sortie de la fonction
* \ return 0 si la convertion est réussie
* \ bug A debugger ! Inutilisable en l ' é tat
*/
2017-05-23 17:36:54 +02:00
int image_CV2SFML ( IplImage * imcv , sf : : Image imFlux ) ; //Construction de imsf (RGBA) à partir de imcv (BGR), avec alpha constant (=1)
2017-05-30 18:12:25 +02:00
/**
* \ fn CvHaarClassifierCascade * init_cascade ( )
* \ brief Charge les fichiers cascades pour la reconnaissance faciale
* \ details fichier ( s ) chargé ( s ) : " haarcascade_frontalface_alt.xml "
* \ author Jacques
* \ return Renvoie la cascade
*/
2017-05-23 17:36:54 +02:00
CvHaarClassifierCascade * init_cascade ( ) ;
2017-05-30 18:12:25 +02:00
/**
* \ fn void detect_and_draw ( IplImage * img , CvHaarClassifierCascade * cascade , face * * tab_face )
* \ brief Détecte et renvoie un rectangle pour chaque visage sur l ' image
* \ author Jacques
* \ param img Image sur laquelle on veut détecter des visages
* \ param cascade structure contenant les données pour alimenter l ' algorithme de reconnaissance d ' image
* \ param tab_face tableau des faces détectées
*/
void detect_and_draw ( IplImage * img , CvHaarClassifierCascade * cascade , face * * tab_face ) ;
/**
* \ fn int * get_color ( IplImage * image , face * rec_face )
* \ brief retourne la couleur moyenne des pixels dans rec_face
* \ author Antoine / Jacques
* \ param image image d ' où on cherche la moyenne
* \ param imFlux image SFML convertie en sortie de la fonction
* \ return 0 si la convertion est réussie
*/
void get_color ( IplImage * image , face * rec_face , int * BGR ) ;
2017-05-23 17:36:54 +02:00
# endif