Mostrare un'immagine in una finestra con le funzioni dell'API di OpenCV

Da Gambas-it.org - Wikipedia.

OpenCV (Open Source Computer Vision Library) in via generale è una libreria di funzioni open source specifica per la vision computer e realizzata per fornire una infrastruttura comune per applicazioni di ottica artificiale.


Fra le varie possibilità mostreremo come far mostrare in modo molto semplice un'immagine all'interno di una finestra, autonoma rispetto ad altre eventuali generate dall'applicativo Gambas.

Si utilizzerà innanzitutto la libreria nella sua attuale versione: libopencv_highgui.so.2.4.2.


Data la semplicità del codice necessario, verrà descritto di seguito un breve esempio:

' Il valore "CV_WINDOW_AUTOSIZE" fa adattare automaticamente la dimensione della finestra alla dimensione dell'immagine caricata,
' e non consente quindi una successiva modifica manuale di tali dimensioni:
Private Const CV_WINDOW_AUTOSIZE As Byte = 1
Private Const CV_LOAD_IMAGE_COLOR As Byte = 1


Library "libopencv_highgui:2.4.2"

' int cvNamedWindow( const char* name, int flags=CV_WINDOW_AUTOSIZE )
Private Extern cvNamedWindow(name As String, flags As Integer) As Integer

' IplImage* cvLoadImage( const char* filename, int flags )
Private Extern cvLoadImage(filename As String, flagLIC As Integer) As Pointer
 
' void cvShowImage( const char* name, const CvArr* image )
Private Extern cvShowImage(name As String, imageP As Pointer)

' void cvMoveWindow(const char * name, Int x, Int y)
Private Extern cvMoveWindow(name As String, xI As Integer, yI As Integer)

' void cvDestroyWindow( const char* name )
Private Extern cvDestroyWindow(name As String)

' void cvDestroyAllWindows(void)
Private Extern cvDestroyAllWindows()



Public Sub Button1_Click()

 Dim imago As Pointer
 

' Viene impostato l'eventuale titolo della finestra:
   cvNamedWindow("Titolo della finestra", CV_WINDOW_AUTOSIZE)

' Viene caricata l'immagine che dovrà essere mostrata nella finestra: |1|
   imago = cvLoadImage("/percorso/della/immagine", CV_LOAD_IMAGE_COLOR) |2|

' Viene mostrata l'immagine nella finestra. |3|
   cvShowImage("Titolo della Finestra", imago)

End


Public Sub Button2_Click()

' Viene distrutta la finestra individuata sulla base del suo titolo:
   cvDestroyWindow("Titolo della Finestra")

End


Public Sub Button3_Click()

' La seguente funzione distrugge tutte le finestre create con l'API di "OpenCV":
   cvDestroyAllWindows()

End


Public Sub Button4_Click()

' La seguente funzione sposta la finestra, individuata sulla base del suo titolo, alle coordinate X e Y in essa specificate:
   cvMoveWindow("Titolo della Finestra", coord. X, coord. Y)

End




Note

[1] E' possibile caricare solo le immagini dei seguenti formati:

  • Windows bitmaps - BMP, DIB;
  • JPEG files - JPEG, JPG, JPE;
  • Portable Network Graphics - PNG;
  • Portable image format - PBM, PGM, PPM;
  • Sun rasters - SR, RAS;
  • TIFF files - TIFF, TIF.

[2] Il secondo parametro specifica la colorazione dell'immagine:

  • se > 0 (CV_LOAD_IMAGE_COLOR), l'immagine sarà comunque caricata come immagine a colori a 3-canali;
  • se = 0 (CV_LOAD_IMAGE_GRAYSCALE), l'immagine caricata sarà mostrata in scala di grigio;
  • se < 0 (CV_LOAD_IMAGE_UNCHANGED), l'immagine sarà caricata e mostrata così com'è.

[3] Se il 1° argomento della funzione "cvShowImage" ha un testo diverso da quello impostato nella funzione "cvNamedWindow", allora sarà creata un'ulteriore finestra e l'immagine verrà caricata in questa ulteriore finestra.


Riferimenti