begin process at 2010 03 22 03:09:54
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Graphique

 > COMPARER 2 IMAGES

COMPARER 2 IMAGES


 Information sur la source

Note :
9,6 / 10 - par 10 personnes
9,60 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :Graphique Classé sous :comparaison, image, setpixel, getpixel Niveau :Expert Date de création :05/02/2003 Date de mise à jour :12/01/2006 02:25:04 Vu / téléchargé :11 944 / 1 446

Auteur : max12

Ecrire un message privé
Site perso
Ce membre participe au partage de revenus publicitaires
Commentaire sur cette source (6)
Ajouter un commentaire et/ou une note


 Description

Cliquez pour voir la capture en taille normale
Ce code sert a faire la comparaison entre 2 images, l'utiliser c'est surtout pour une webcam par exemple, pour la détection de mouvement (Sa sachant que l'image même si on bouge pas est jamais 100% pareil)

Il serais facile d'optimiser, il suffirait d'enlever quelque option surtout, celle qui ne vous servent absolument a rien.

Source

  • Public Type lRetour
  • lRougeStat As Variant
  • lVertStat As Variant
  • lBleuStat As Variant
  • lMoyenneStat As Variant
  • End Type
  • Declare Function SetPixel Lib "gdi32" (ByVal hdc As Long, ByVal X As Long, ByVal Y As Long, ByVal crColor As Long) As Long
  • Declare Function GetPixel Lib "gdi32" (ByVal hdc As Long, ByVal X As Long, ByVal Y As Long) As Long
  • Declare Function GetTickCount Lib "kernel32" () As Long
  • Public Function Comparaison(cBox As PictureBox, cBox2 As PictureBox, cResult As PictureBox _
  • , Optional Sensible As Long = 10, Optional Mode As Long = 1, _
  • Optional cRouge As Boolean = True, Optional cVert As Boolean = True, Optional cBleu As Boolean = True, _
  • Optional GreyScale As Boolean = False) As lRetour
  • On Error Resume Next 'Une erreur peu si vite arrivé
  • 'Début de la déclaration de variable
  • Dim X As Long, Y As Long
  • Dim R1 As Long, V1 As Long, B1 As Long
  • Dim R2 As Long, V2 As Long, B2 As Long, r As Long
  • Dim Couleur As Long, Couleur2 As Long, EcrirePixel As Boolean
  • Dim lOR As Long, lOV As Long, lOB As Long, Debut As Long
  • '=====================================================
  • 'Ici on a le code de comparaison
  • '=====================================================
  • cResult.Cls
  • Debut = GetTickCount
  • For X = 0 To cBox.ScaleWidth Step Mode
  • For Y = 0 To cBox.ScaleHeight Step Mode
  • Couleur = GetPixel(cBox.hdc, X, Y)
  • '///Séparation des couleurs pour la première image
  • If cRouge = True Then R1 = Int(Couleur And &HFF)
  • If cVert = True Then V1 = Int((Couleur And &H100FF00) / &H100)
  • If cBleu = True Then B1 = Int((Couleur And &HFF0000) / &H10000)
  • '///Séparation des couleurs pour la première image
  • Couleur2 = GetPixel(cBox2.hdc, X, Y)
  • '///Séparation des couleurs pour la 2 image
  • If cRouge = True Then R2 = Int(Couleur2 And &HFF)
  • If cVert = True Then V2 = Int((Couleur2 And &H100FF00) / &H100)
  • If cBleu = True Then B2 = Int((Couleur2 And &HFF0000) / &H10000)
  • '///Séparation des couleurs pour la 2 image
  • 'FrmMain.List1.AddItem R1 & " " & R2
  • ' SetPixel cResult.hdc, X, Y, RGB(R1, V1, 0)
  • EcrirePixel = False
  • 'Comparaison au niveau du rouge
  • If (Not ((R1 > (R2 - Sensible)) And (R1 < (R2 + Sensible)))) And cRouge = True Then
  • lOR = lOR + 1
  • EcrirePixel = True
  • End If
  • 'Comparaison au niveau du vert
  • If (Not ((V1 > (V2 - Sensible)) And (V1 < (V2 + Sensible)))) And cVert = True Then
  • lOV = lOV + 1
  • EcrirePixel = True
  • End If
  • 'Comparaison au niveau du bleu
  • If (Not ((B1 > (B2 - Sensible)) And (B1 < (B2 + Sensible)))) And cBleu = True Then
  • lOB = lOB + 1
  • EcrirePixel = True
  • End If
  • If EcrirePixel = True Then
  • '//Représentation graphique, pas forcément utile
  • If GreyScale = True Then
  • GreyColor = Int((((R1 + R2) / 2) + ((B1 + B2) / 2) + ((V1 + V2) / 2)) / 3)
  • SetPixel cResult.hdc, X, Y, RGB(GreyColor, GreyColor, GreyColor)
  • Else
  • SetPixel cResult.hdc, X, Y, RGB(((R1 + R2) / 2), ((V1 + V2) / 2), ((B1 + B2) / 2))
  • End If
  • '//Représentation graphique, pas forcément utile
  • End If
  • Next Y
  • Next X
  • 'Retour des statistique
  • With Comparaison
  • .lRougeStat = Format((((lOR / ((cBox.ScaleWidth * cBox.ScaleHeight) / Mode)) * 100) * Mode), "##0.0000")
  • .lVertStat = Format(((lOV / ((cBox.ScaleWidth * cBox.ScaleHeight) / Mode)) * 100 * Mode), "##0.0000")
  • .lBleuStat = Format(((lOB / ((cBox.ScaleWidth * cBox.ScaleHeight) / Mode)) * 100 * Mode), "##0.0000")
  • .lMoyenneStat = Format(((Int(Comparaison.lRougeStat) + Int(Comparaison.lVertStat) + Int(Comparaison.lBleuStat)) / 3), "###.0000")
  • End With
  • '//A virer absolument, c'est seulement pour la démonstration
  • FrmMain.Caption = "Temps d'exécution : " & (GetTickCount - Debut) / 1000 & " seconde(s)"
  • cResult.Refresh
  • End Function
Public Type lRetour
    lRougeStat As Variant
    lVertStat As Variant
    lBleuStat As Variant
    lMoyenneStat As Variant
End Type
Declare Function SetPixel Lib "gdi32" (ByVal hdc As Long, ByVal X As Long, ByVal Y As Long, ByVal crColor As Long) As Long
Declare Function GetPixel Lib "gdi32" (ByVal hdc As Long, ByVal X As Long, ByVal Y As Long) As Long
Declare Function GetTickCount Lib "kernel32" () As Long
Public Function Comparaison(cBox As PictureBox, cBox2 As PictureBox, cResult As PictureBox _
, Optional Sensible As Long = 10, Optional Mode As Long = 1, _
Optional cRouge As Boolean = True, Optional cVert As Boolean = True, Optional cBleu As Boolean = True, _
Optional GreyScale As Boolean = False) As lRetour

On Error Resume Next 'Une erreur peu si vite arrivé
'Début de la déclaration de variable
Dim X As Long, Y As Long
Dim R1 As Long, V1 As Long, B1 As Long
Dim R2 As Long, V2 As Long, B2 As Long, r As Long
Dim Couleur As Long, Couleur2 As Long, EcrirePixel As Boolean
Dim lOR As Long, lOV As Long, lOB As Long, Debut As Long
'=====================================================
'Ici on a le code de comparaison
'=====================================================
cResult.Cls
Debut = GetTickCount
For X = 0 To cBox.ScaleWidth Step Mode
    For Y = 0 To cBox.ScaleHeight Step Mode
        Couleur = GetPixel(cBox.hdc, X, Y)
        '///Séparation des couleurs pour la première image
            If cRouge = True Then R1 = Int(Couleur And &HFF)
            If cVert = True Then V1 = Int((Couleur And &H100FF00) / &H100)
            If cBleu = True Then B1 = Int((Couleur And &HFF0000) / &H10000)
        '///Séparation des couleurs pour la première image
        Couleur2 = GetPixel(cBox2.hdc, X, Y)
        '///Séparation des couleurs pour la 2 image
        If cRouge = True Then R2 = Int(Couleur2 And &HFF)
        If cVert = True Then V2 = Int((Couleur2 And &H100FF00) / &H100)
        If cBleu = True Then B2 = Int((Couleur2 And &HFF0000) / &H10000)
        '///Séparation des couleurs pour la 2 image
        'FrmMain.List1.AddItem R1 & " " & R2
'        SetPixel cResult.hdc, X, Y, RGB(R1, V1, 0)
        EcrirePixel = False
        
        'Comparaison au niveau du rouge
        If (Not ((R1 > (R2 - Sensible)) And (R1 < (R2 + Sensible)))) And cRouge = True Then
                lOR = lOR + 1
                EcrirePixel = True
        End If
        'Comparaison au niveau du vert
        If (Not ((V1 > (V2 - Sensible)) And (V1 < (V2 + Sensible)))) And cVert = True Then
                lOV = lOV + 1
                EcrirePixel = True
        End If
        'Comparaison au niveau du bleu
        If (Not ((B1 > (B2 - Sensible)) And (B1 < (B2 + Sensible)))) And cBleu = True Then
                lOB = lOB + 1
                EcrirePixel = True
        End If
        If EcrirePixel = True Then
            '//Représentation graphique, pas forcément utile
            If GreyScale = True Then
                GreyColor = Int((((R1 + R2) / 2) + ((B1 + B2) / 2) + ((V1 + V2) / 2)) / 3)
                SetPixel cResult.hdc, X, Y, RGB(GreyColor, GreyColor, GreyColor)
            Else
                SetPixel cResult.hdc, X, Y, RGB(((R1 + R2) / 2), ((V1 + V2) / 2), ((B1 + B2) / 2))
            End If
            '//Représentation graphique, pas forcément utile
        End If
    Next Y
Next X
'Retour des statistique
    With Comparaison
        .lRougeStat = Format((((lOR / ((cBox.ScaleWidth * cBox.ScaleHeight) / Mode)) * 100) * Mode), "##0.0000")
        .lVertStat = Format(((lOV / ((cBox.ScaleWidth * cBox.ScaleHeight) / Mode)) * 100 * Mode), "##0.0000")
        .lBleuStat = Format(((lOB / ((cBox.ScaleWidth * cBox.ScaleHeight) / Mode)) * 100 * Mode), "##0.0000")
        .lMoyenneStat = Format(((Int(Comparaison.lRougeStat) + Int(Comparaison.lVertStat) + Int(Comparaison.lBleuStat)) / 3), "###.0000")
    End With
'//A virer absolument, c'est seulement pour la démonstration
FrmMain.Caption = "Temps d'exécution : " & (GetTickCount - Debut) / 1000 & " seconde(s)"
cResult.Refresh
End Function

 Conclusion

Absolument rien !

 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Historique

12 janvier 2006 02:25:04 :
Mot clef

 Sources du même auteur

Source avec Zip Source avec une capture VBFRANCE MESSENGER + SERVEUR, ANCIENNE SOURCE
Source avec Zip Source avec une capture ÉDITEUR HEXADÉCIMAL
Source avec Zip Source avec une capture ÉCRAN DE VEILLE, APERÇU, OPTIONS (SANS DIRECT X) RESSEMBLE U...
Source avec Zip Source avec une capture DÉFORMER UNE IMAGE, FAIRE DES VAGUES (SIN) (UPDATED)
Source avec Zip Source avec une capture ANALYSEUR MATHÉMATIQUE

 Sources de la même categorie

Source avec Zip Source .NET (Dotnet) COMPARAISON D'IMAGE par mafieulemouton
Source avec Zip Source avec une capture Source .NET (Dotnet) RECADRER_IMAGE par Le Pivert
Source avec Zip Source avec une capture Source .NET (Dotnet) EDITION DE CARACTÈRES MATRICIELS (POUR BITMAP, CF CODE 128) par Blodox
Source avec Zip Source avec une capture CRÉATION D'UN MASQUE GRAPHIQUE POUR MODIFIER LA COULEUR D'UN... par Dudule_73
Source avec Zip Source avec une capture Source .NET (Dotnet) GÉNÉRATEUR DE CODE 128 (CODE-BARRE) par Blodox

 Sources en rapport avec celle ci

Source avec Zip Source .NET (Dotnet) COMPARAISON D'IMAGE par mafieulemouton
Source avec Zip Source avec une capture OPÉRATIONS SUR UNE LISTE D'IMAGES par antho2005
Source avec Zip Source avec une capture STEGANOGRAPHIE AVEC ENCODAGE DE TEXTE par MalcolMZ
RÉCUPÉRATION D'UNE MATRICE DE PIXELS À PARTIR D'UNE IMAGE SA... par uraniumdesig
Source avec Zip Source .NET (Dotnet) GETPIXEL TRÈS RAPIDE par ShadowTzu

Commentaires et avis

Commentaire de jack le 08/02/2003 16:23:52 administrateur CS

Ô les belles lignes de code que voilà ;-)

Commentaire de PereNoel le 08/02/2003 16:24:00

C'est tres cool ! Bonne prog ! Bravooo ! Clap ! Clap ! Clap !

Commentaire de Vbsupernul le 08/02/2003 16:24:54

Voilà mon piti, un commentaire, enfin ;)
Bien bien !
Bien commentée & tt !
9/10

Commentaire de mehdibou le 08/02/2003 16:58:05

ho, mais que c'est joli tout ça ;)

Commentaire de clementpat le 16/10/2004 21:23:27

super bien pensé !

Commentaire de asem67 le 14/04/2005 00:04:06

slt.
c'est coool ces ce que je cherche
merci

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

Couleur SetPixel différente de couleure GetPixel sous Windows 2000 [ par cushy007 ] Couleur SetPixel différente de couleure GetPixel sous Windows 2000 [ par cushy007 ] Salut, J'ai un probl&#232;me sous Windows 2000 avec les couleurs des API SetPixel et GetPixel. La couleur que me renvoie GetPixel est diff&#233;rente Getpixel sans voir l'image [ par loskiller62 ] Le GetPixel ne fonctionne que si on visualise l'image (picturebox) à l'ecran. Ca me pose un problème si l'image est trop grande car alors on ne peut p SetPixel et AutoRedraw [ par neria ] Salut tous le monde !Je vais essayer de faire court :J'essaye d'afficher une image contenue dans un tableau a l'aide de l'API SetPixel. Le problème c' GetPixel et SetPixel [ par MoiDebutantVB ] Je me rapelle avoir vu une source .Net qui utilisait GetPixel et Set Pixel ainsi qu'une Api et une autre méthode pour remplacer une couleur d'une bitm Construire une image depuis un buffer couleur (.NET) [ par ad vitam aeternam ] Bonjour à tous!Voila, je possède un robot POB-LITE (cf: pob-technology.com). J'ai donc crée un petit logiciel me permet de le diriger à distance depui Pb d'impression avec Setpixel [ par aldebarre ] Bonjour J'utilise l'api setpixel pour modifier la couleur de certaines zone d'une image se trouvant ds un picturebox mais mon souci est que quand enregistrer une image créer avec setpixel [ par chodavins ] bonjour,j'ai créé une image dans une picturebox avec une succéssion de setpixel, et quand je veux enregistrer cette image avec savepicture j'optiens u API : HDC et Setpixel [ par Stephane ] Salut &#224; tous voila, dans le cadre d'un projet encadr&#233;, je realise une compression d'images. Mon probl&#232;me est que au moment d'afficher ordre d'affichage des images [ par cqui789 ] Bonjour (Re), Ce coup-ci, je vais parler d'images. J'ai sur ma form une serie d'images. au design de la form, je peut choisir pour chaque image send


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Mars 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
293031    

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,764 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales