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

Traitement d'images Discussion :

Parcourir une image pour récupérer le min et le max


Sujet :

Traitement d'images

  1. #1
    Membre habitué
    Inscrit en
    Septembre 2005
    Messages
    747
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 747
    Points : 174
    Points
    174
    Par défaut Parcourir une image pour récupérer le min et le max
    Salut,

    j'aurais besoin d'aide pour parcourir une image et ainsi récupérer le min et le max de l'image entre les bornes [xmin, ymin, xmax, ymax]
    t_image est une structure qui contient l'image.
    Le champ contenant le tableau de pixel se nomme pixel
    image->pixel[i] permet d'accéder au ième-pixel

    Le prototype de la fonction est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    int min_max(int xMin, int yMin, int xMax, int yMax, t_image *image, int *min, int *max)
    Merci par avance

  2. #2
    Rédacteur

    Avatar de khayyam90
    Homme Profil pro
    Architecte de système d’information
    Inscrit en
    Janvier 2004
    Messages
    10 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Architecte de système d’information

    Informations forums :
    Inscription : Janvier 2004
    Messages : 10 369
    Points : 40 164
    Points
    40 164
    Par défaut
    Bien le bonsoir,

    puisque ton image est représentée par un tableau à une seule dimension, tu as besoin de la largeur de ton image

    une fois que tu as ces infos :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    *min = 255;
    *max = 0;
    for (int i=xmin; i<= xmax; i++)
      for (int j=ymin; j<= ymax; j++){
        if (image->pixels[j*largeur+i] < *min) 
            *min = image->pixels[j*largeur+i];
        if (image->pixels[j*largeur+i] > *max)
            *max = image->pixels[j*largeur+i];
       }
    fonctionnement : tu initialises min et max aux valeurs extrèmes puis tu parcours ton image en testant chaque pixel.

  3. #3
    Membre habitué
    Inscrit en
    Septembre 2005
    Messages
    747
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 747
    Points : 174
    Points
    174
    Par défaut
    Citation Envoyé par khayyam90
    Bien le bonsoir,

    puisque ton image est représentée par un tableau à une seule dimension, tu as besoin de la largeur de ton image

    une fois que tu as ces infos :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    *min = 255;
    *max = 0;
    for (int i=xmin; i<= xmax; i++)
      for (int j=ymin; j<= ymax; j++){
        if (image->pixels[j*largeur+i] < *min) 
            *min = image->pixels[j*largeur+i];
        if (image->pixels[j*largeur+i] > *max)
            *max = image->pixels[j*largeur+i];
       }
    fonctionnement : tu initialises min et max aux valeurs extrèmes puis tu parcours ton image en testant chaque pixel.
    Merci bien pour le code.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    *min = 255;
    *max = 0;
    Ce n'est pas l'inverse ?
    De plus, pourquoi attribué la valeur 255 au max ?
    J'avais fait ceci mais ça m'indiquait une erreur de segmentation.
    Pourrais-tu si tu as une idée m'indiquer, pourquoi j'ai eu ce problème ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    int largeur = xMax-xMin
     
      *min = image->pixels[xMin];
      *max = image->pixels[xMin];
      for(i=xMin; i<xMax; i++)
        for(j=yMin; j<yMax; j++){
          if(min > image->pixels[i*largeur+j])
        *min = image->pixels[i*largeur+j];
     
         if(max < image->pixels[i*largeur+j]){
          *max = image->pixels[i*largeur+j];
         }
       }

  4. #4
    Rédacteur

    Avatar de millie
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    7 015
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 015
    Points : 9 818
    Points
    9 818
    Par défaut
    Si tu as une erreur de segmentation avec : *max = qqch; c'est que dans l'appel à la fonction, tu lui as donné un pointeur non valide (par exemple NULL) ou une zone où tu n'as pas le droit d'accèder.

    Il a donné 255 et 0 car si tu travailles avec un format de gris classique, le maximum de l'image est majoré par 255 et le minimum est minoré par 0. Si tu ne souhaites pas utiliser la contrainte là, tu peux directement donner une valeur quelconque de l'image. Par exemple : image->pixel[0]; (on suppose que l'image est de taille non nulle).
    Je ne répondrai à aucune question technique en privé

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. test champs email avec une image pour bouton de validation
    Par becouet dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 07/06/2006, 23h17
  2. Réponses: 1
    Dernier message: 17/05/2006, 09h19
  3. utiliser des morceaux d'une image pour faire des boutons
    Par Battosaiii dans le forum Interfaces Graphiques en Java
    Réponses: 7
    Dernier message: 14/12/2005, 00h05
  4. [ImageMagick] Parcourir une image pixel par pixel
    Par kip dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 05/10/2005, 14h10
  5. [FLASH 5]un bouton dans une image pour revenir sur une scene
    Par patato valdes dans le forum Flash
    Réponses: 7
    Dernier message: 28/04/2004, 20h21

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