IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C++ Discussion :

Traitement des images


Sujet :

C++

  1. #1
    Futur Membre du Club
    Inscrit en
    Septembre 2009
    Messages
    6
    Détails du profil
    Informations forums :
    Inscription : Septembre 2009
    Messages : 6
    Points : 6
    Points
    6
    Par défaut Traitement des images
    Bonjour
    je suis nouveau dans le forum, et j'ai un grand probleme urgent encore. j'ai un projet à realiser sur les traitement des images. je dois lire une image et l'analyser.

    - S'il est dans le bon sens (sinon faire une rotation)
    - detecter le code bare et l'afficher
    - si l'image est incliné, la redresser

    c'est une texte scannée par une imprimente, donc l'image peut etre renversé ou incliné legerement. on m'impose d'utiliser le visual C++, moi j'avais directement penser utiliser opencv, mais sincerment je crois que je suis tombé dans le mauvais choix.

  2. #2
    Membre chevronné
    Avatar de Joel F
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Septembre 2002
    Messages
    918
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2002
    Messages : 918
    Points : 1 921
    Points
    1 921
    Par défaut
    google:

    - transformée de hough pour determiner l'axe principal des objets
    - interpolation 2D pour la rotation

  3. #3
    Futur Membre du Club
    Inscrit en
    Septembre 2009
    Messages
    6
    Détails du profil
    Informations forums :
    Inscription : Septembre 2009
    Messages : 6
    Points : 6
    Points
    6
    Par défaut
    Merci beaucoup pour la reponce.

    j'ai pensé à cela, avec hough il me donne toute les lignes de la page. en plus comme ca lit les les phrases comme s'il etait des lignes.
    je ne sais comment faire pour trouver l'angle d'inclinaison. si vous pouvais m'aider un peu plus
    voila le code que j'ai fait:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    #include <cv.h>
    #include <highgui.h>
    #include <math.h>
     
    //--------------- focnction de rotation ----------------------- 
    IplImage *rotateImage(const IplImage *src, float angleDegrees) {
         // Create a map_matrix, where the left 2x2 matrix
         // is the transform and the right 2x1 is the dimensions.
         float m[6];
         CvMat M = cvMat(2, 3, CV_32F, m);
         int w = src->width;
         int h = src->height;
         float angleRadians = angleDegrees * ((float)CV_PI / 180.0f);
         m[0] = (float)( cos(angleRadians) );
         m[1] = (float)( sin(angleRadians) );
         m[3] = -m[1];
         m[4] = m[0];
         m[2] = w*0.5f; 
         m[5] = h*0.5f; 
         // Make a spare image for the result
         CvSize sizeRotated;
         sizeRotated.width = cvRound(w);
         sizeRotated.height = cvRound(h);
         // Rotate
         IplImage *imageRotated = cvCreateImage( sizeRotated,
         src->depth, src->nChannels );
         // Transform the image
         cvGetQuadrangleSubPix( src, imageRotated, &M);
         return imageRotated;
    }
     
     
    int main(int argc, char** argv) {
         IplImage* img =cvLoadImage("D:/11a.png", 0);
     
         // ----------- Dans les 10 lignes suivant c'est hough --------------//
         IplImage* dst = cvCreateImage( cvGetSize(img), 8, 1 );
         IplImage* color_dst = cvCreateImage( cvGetSize(img), 8, 3 );
         CvMemStorage* storage = cvCreateMemStorage(0);
         CvSeq* lines = 0;
         int i;
         cvCanny( img, dst, 50, 200, 3 );
         lines = cvHoughLines2( dst, storage, CV_HOUGH_PROBABILISTIC, 1    ,CV_PI/180, 80, 30, 10 );
         for( i = 0; i < lines->total; i++ ) {
              CvPoint* line = (CvPoint*)cvGetSeqElem(lines,i);
              cvLine( color_dst, line[0], line[1], CV_RGB(255,0,0), 3, 8 );
         }
     
    IplImage *test_rotation =rotateImage(img,-10);
    //cvCvtColor(img,greyImage,CV_BGR2GRAY);
     
     
    //--------------- affichage ---------------------
     
     
    cvNamedWindow( "result",CV_WINDOW_AUTOSIZE);
    cvNamedWindow( "rotation",CV_WINDOW_AUTOSIZE);
    cvNamedWindow( "testrotation",CV_WINDOW_AUTOSIZE);
    cvShowImage( "result", img );
    cvShowImage( "rotation", color_dst );
    cvShowImage( "testrotation", test_rotation );
    cvWaitKey(0);
    cvReleaseImage( &img );
    cvReleaseImage( &color_dst );
    cvReleaseImage( &test_rotation );
    cvDestroyWindow("result");
    cvDestroyWindow("rotation");
    cvDestroyWindow("testrotation");
    }

  4. #4
    Membre confirmé Avatar de themadmax
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    446
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 446
    Points : 496
    Points
    496
    Par défaut
    Pense a utilisé la balise code.

    Je comprend pas trop si tu as trouvé les lignes composante de ton image pouquoi n'arrive tu pas a determiner l'angle de rotation ?

    dans les exemple opencv il utililse cette fonction pour determiné l'angle entre 2 ligne (3 pts)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    /**
    finds a cosine of angle between vectors
    from pt0->pt1 and from pt0->pt2
    */
    double angle( CvPoint* pt1, CvPoint* pt2, CvPoint* pt0 )
    {
        double dx1 = pt1->x - pt0->x;
        double dy1 = pt1->y - pt0->y;
        double dx2 = pt2->x - pt0->x;
        double dy2 = pt2->y - pt0->y;
        return (dx1*dx2 + dy1*dy2)/sqrt((dx1*dx1 + dy1*dy1)*(dx2*dx2 + dy2*dy2) + 1e-10);
    }
    ________________________________________________
    http://bliquid.fr : Blog sur Android et l'Acer Liquid

Discussions similaires

  1. Traitement des images dans forms6i
    Par ImedBenMansour dans le forum Forms
    Réponses: 3
    Dernier message: 19/05/2008, 17h37
  2. Traitement des images RGB
    Par tapouni dans le forum Images
    Réponses: 6
    Dernier message: 13/05/2008, 17h15
  3. traitement des images 3D en vc++
    Par karimfl dans le forum MFC
    Réponses: 0
    Dernier message: 23/04/2008, 10h26

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo