mirror of
https://github.com/AntoineHX/LivingMachine.git
synced 2025-06-27 22:55:24 +02:00
structure face
This commit is contained in:
commit
1712fc1120
102 changed files with 8159 additions and 20 deletions
BIN
Code/KirbyTrack
BIN
Code/KirbyTrack
Binary file not shown.
|
@ -1,3 +1,16 @@
|
|||
/**
|
||||
* \file KirbyTrack.c
|
||||
* \author Jacques / Antoine
|
||||
* \date avril - mai 2017
|
||||
* \brief Figure Imposé : Suivi d'un objet coloré.
|
||||
*
|
||||
* \details Suivie d'un Kirby (Rose) ou d'une étoile (Jaune) par une caméra avec mode interface utilisateur ou configuration
|
||||
* \bug SFML ne supporte qu'un nombre limité de sprite en fonction du PC
|
||||
* \bug Affichage OpenCV incompatible avec SFML
|
||||
* \todo Optimisation du chargement de la frame en image SFML
|
||||
*/
|
||||
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <cv.h>
|
||||
|
@ -6,7 +19,22 @@
|
|||
#include <SFML/Audio.hpp>
|
||||
#include <SFML/Graphics.hpp>
|
||||
#include <SFML/Window.hpp>
|
||||
|
||||
/**
|
||||
* \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
|
||||
* \brief Programme en mide suivi de l'étoile (Objet jaune)
|
||||
*
|
||||
* \def JEU
|
||||
* \brief Coefficient de tolérance pour le suivi d'objet
|
||||
*/
|
||||
//#define CONFIG
|
||||
#define SFML
|
||||
|
||||
|
@ -19,18 +47,120 @@
|
|||
//ATTENTION SFML SUPPORTE UN NOMBRE LIMITE DE SPRITE EN FCT DU PC
|
||||
|
||||
/*Headers*/
|
||||
void maj_angle(int vecX, int vecY, int rayon, double* angle); //Met à jour l'angle selon la distance CentreCamera - Cible
|
||||
int ajust_pos(int pos, int ref);
|
||||
void controle_moteur(double* angle);//Envoie les angles au moteur
|
||||
/**
|
||||
* \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
|
||||
*/
|
||||
void maj_angle(int vecX, int vecY, int rayon, double* angle); //Met à jour l'angle selon la distance CentreCamera - Cible
|
||||
|
||||
/**
|
||||
* \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
|
||||
*/
|
||||
int ajust_pos(int pos, int ref);
|
||||
|
||||
/**
|
||||
* \fn void controle_moteur(double* angle)
|
||||
* \brief Fonction d'envoie des angles aux moteurs
|
||||
* \details
|
||||
* \author Jacques
|
||||
* \param angle tableau des angles moteurs
|
||||
*/
|
||||
void controle_moteur(double* angle);//Envoie les angles au moteur
|
||||
|
||||
/**
|
||||
* \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
|
||||
*/
|
||||
int limite_moteur(int val_pwm);//Verifie que les valeurs envoyees aux moteurs sont correctes
|
||||
|
||||
/**
|
||||
* \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.
|
||||
*/
|
||||
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
|
||||
|
||||
/**
|
||||
* \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
|
||||
*/
|
||||
void affichage_config(IplImage* frame, IplImage* HSV, IplImage* Binaire); //Affiche le flux vidéos et ses différent traitements
|
||||
|
||||
/**
|
||||
* \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
|
||||
*/
|
||||
void Affichage_Tracking(IplImage* frame, int posX, int posY, int width, int height); //Dessine les informations de tracking sur frame
|
||||
|
||||
/**
|
||||
* \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
|
||||
*/
|
||||
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
|
||||
|
||||
/**
|
||||
* \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.
|
||||
*/
|
||||
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
|
||||
|
||||
/**
|
||||
* \fn int main(int argc, char* argv[])
|
||||
* \brief Entrée du programme
|
||||
* \author Antoine / Jacques
|
||||
* \return EXIT_SUCCESS : Arrêt normal du programme, EXIT_FAILURE : Le programme a rencontrée une erreur au cours de son execution
|
||||
*/
|
||||
int main(int argc, char* argv[])
|
||||
{
|
||||
//Initialisations
|
||||
|
|
Binary file not shown.
|
@ -1,3 +1,4 @@
|
|||
|
||||
EXEC= KirbyTrack Navy
|
||||
|
||||
LDFLAGS = -lsfml-graphics -lsfml-window -lsfml-system -lsfml-audio `pkg-config opencv --libs`
|
||||
|
|
BIN
Code/Navy
Executable file
BIN
Code/Navy
Executable file
Binary file not shown.
15
Code/Navy.c
15
Code/Navy.c
|
@ -81,7 +81,9 @@ int main(int argc, char* argv[])
|
|||
break;
|
||||
}
|
||||
|
||||
detect_and_draw(frame,cascade);
|
||||
|
||||
pface tab_face[2];
|
||||
detect_and_draw(frame,cascade,tab_face);
|
||||
|
||||
#ifdef SFML
|
||||
//Affichage SFML
|
||||
|
@ -137,7 +139,6 @@ int main(int argc, char* argv[])
|
|||
|
||||
window.draw(button_tracking);
|
||||
|
||||
/*
|
||||
//Dessin du bouton reset
|
||||
sf::Texture txBut2;
|
||||
sf::Sprite button_reset;
|
||||
|
@ -149,10 +150,11 @@ int main(int argc, char* argv[])
|
|||
|
||||
button_reset.setTexture(txBut2);
|
||||
button_reset.setScale(0.5,0.5);
|
||||
button_reset.setPosition(sf::Vector2f(width+20, 60));
|
||||
button_reset.setPosition(sf::Vector2f(width+20, 100));
|
||||
|
||||
window.draw(button_reset);
|
||||
*/
|
||||
|
||||
/*
|
||||
//Ajout du texte
|
||||
sf::Font font;
|
||||
if (!font.loadFromFile("Stock SFML/arial.ttf")){
|
||||
|
@ -176,6 +178,7 @@ int main(int argc, char* argv[])
|
|||
text.setPosition(sf::Vector2f(width+100, 35));
|
||||
|
||||
window.draw(text);
|
||||
*/
|
||||
/*
|
||||
//Link
|
||||
sf::Texture txLink;
|
||||
|
@ -195,7 +198,7 @@ int main(int argc, char* argv[])
|
|||
window.display();
|
||||
#endif
|
||||
|
||||
|
||||
/*
|
||||
if(tracking){
|
||||
//Mouvements moteurs
|
||||
//printf("-PREMAJ_ANGLE...: %d %d\n",width,height);
|
||||
|
@ -205,7 +208,7 @@ int main(int argc, char* argv[])
|
|||
|
||||
cvWaitKey(50);
|
||||
}
|
||||
|
||||
*/
|
||||
|
||||
#ifdef CONFIG
|
||||
/*
|
||||
|
|
BIN
Code/Navy.o
Normal file
BIN
Code/Navy.o
Normal file
Binary file not shown.
Binary file not shown.
Before Width: | Height: | Size: 91 KiB After Width: | Height: | Size: 69 KiB |
|
@ -189,12 +189,9 @@ CvHaarClassifierCascade* init_cascade(){
|
|||
}
|
||||
|
||||
// Function to detect and draw any faces that is present in an image
|
||||
void detect_and_draw( IplImage* img, CvHaarClassifierCascade* cascade )
|
||||
void detect_and_draw( IplImage* img, CvHaarClassifierCascade* cascade, pface* tab_face)
|
||||
{
|
||||
|
||||
pface* tab_face[2];
|
||||
|
||||
|
||||
// Create memory for calculations
|
||||
static CvMemStorage* storage = 0;
|
||||
int scale = 1;
|
||||
|
@ -237,11 +234,12 @@ void detect_and_draw( IplImage* img, CvHaarClassifierCascade* cascade )
|
|||
cvRectangle( img, pt1, pt2, CV_RGB(255,0,0), 3, 8, 0 );
|
||||
|
||||
if(i < MAX_FACE){
|
||||
tab_face[i]->point =
|
||||
tab_face[i]->point.x = (pt1.x + pt2.x)/2;
|
||||
tab_face[i]->point.y = (pt1.y + pt2.y)/2;
|
||||
tab_face[i]->largeur = r->width;
|
||||
|
||||
printf("VALEURS FACES : %d %d %d\n",tab_face[i]->point.x,tab_face[i]->point.y,tab_face[i]->largeur);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -33,9 +33,9 @@
|
|||
typedef struct _face{
|
||||
CvPoint point;
|
||||
int largeur;
|
||||
} face
|
||||
} face;
|
||||
|
||||
typedef struct pface *face;
|
||||
typedef face* pface;
|
||||
|
||||
|
||||
/*HEADERS*/
|
||||
|
@ -54,7 +54,7 @@ void traitement(IplImage* frame, IplImage* HSV, IplImage* Binaire, int LowH, int
|
|||
int image_CV2SFML(IplImage* imcv, sf::Image imFlux); //Construction de imsf (RGBA) à partir de imcv (BGR), avec alpha constant (=1)
|
||||
|
||||
CvHaarClassifierCascade* init_cascade();
|
||||
void detect_and_draw( IplImage* img, CvHaarClassifierCascade* cascade );
|
||||
void detect_and_draw( IplImage* img, CvHaarClassifierCascade* cascade, pface* tab_face );
|
||||
|
||||
|
||||
#endif
|
||||
|
|
BIN
Code/fonction.o
Normal file
BIN
Code/fonction.o
Normal file
Binary file not shown.
Loading…
Add table
Add a link
Reference in a new issue