Accueil > > > COMPARER 2 IMAGES
COMPARER 2 IMAGES
Information sur la source
Description
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 !
Historique
- 12 janvier 2006 02:25:04 :
- Mot clef
Sources du même auteur
Sources de la même categorie
Commentaires et avis
|
Derniers Blogs
MBA : POURQUOI FAIRE ET COMMENT LE CHOISIR ?MBA : POURQUOI FAIRE ET COMMENT LE CHOISIR ? par ROMELARD Fabrice
Formation initiale Durant la formation, le découpage classique est le suivant (je donnerai les équivalences Suisse lorsque je les connaîtrais) : Ecole primaire jusqu'au Collège : Formation générale permettant d'obtenir les méthodes...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice Y'A DES ERREURS QUI PEUVENT RENDRE LE DéVELOPPEUR VIOLENTY'A DES ERREURS QUI PEUVENT RENDRE LE DéVELOPPEUR VIOLENT par Aleks
Quand on a ce genre d'erreur sans log :
Et bas on a juste envie de choper le gas de Microsoft qu'a développé ça et lui foutre des baffes de Coboye ! ...
Cliquez pour lire la suite de l'article par Aleks [HYPER-V 3] PRéSENTATION DES COMMANDLETS POWERSHELL[HYPER-V 3] PRéSENTATION DES COMMANDLETS POWERSHELL par Pierrick CATRO-BROUILLET
Avec la sortie prochaine de la Beta Consumer Preview de Windows 8, j'avais envie de revenir sur une des fonctionnalités que j'attends le plus et que, en bon geek que je suis, j'utilise déjà : Hyper-V 3 ainsi son module PowerShell.
Il y a déjà pléthor...
Cliquez pour lire la suite de l'article par Pierrick CATRO-BROUILLET IIS7 - COMPRESSION GZIPIIS7 - COMPRESSION GZIP par cyril
La compression GZIP permet d'améliorer les performances de navigation en compressant ce qu'envoie le serveur à un client. Pour comprendre comment cela fonctionne, regardons ce qu'il se passe au niveau HTTP lorsqu'un client tente d'accéder à une ress...
Cliquez pour lire la suite de l'article par cyril SHAREPOINT 15 TECHNICAL PREVIEW MANAGED OBJECT MODEL SOFTWARE DEVELOPMENT KITSHAREPOINT 15 TECHNICAL PREVIEW MANAGED OBJECT MODEL SOFTWARE DEVELOPMENT KIT par Matthew
http://www.microsoft.com/download/en/details.aspx?id=28768&utm_source=feedburner&utm_medium=feed&utm_campaign=Feed%3A+MicrosoftDownloadCenter+(Microsoft+Download+Center) ...
Cliquez pour lire la suite de l'article par Matthew
Logiciels
Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning Academy System (17.1.3.0)ACADEMY SYSTEM (17.1.3.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|