Differenze tra le versioni di "Uso della classe DesktopWatcher"

Da Gambas-it.org - Wikipedia.
 
(5 versioni intermedie di uno stesso utente non sono mostrate)
Riga 1: Riga 1:
La classe '''DesktopWatcher''' osserva il desktop sullo schermo. Essa consente all'utente di essere in grado di rilevare l'attività dello schermo con i gestori di eventi:
+
La classe '''DesktopWatcher''', utilizzabile attivando i Componenti ''gb.desktop'' e ''gb.desktop.x11'', osserva il desktop sullo schermo. Essa consente all'utente di essere in grado di rilevare l'attività dello schermo con i gestori di eventi:
  ''variabileTipoDesktopWatcher_nomeEvento(parametro-eventuale)''.
+
  variabileTipoDesktopWatcher_NomeEvento([parametro-eventuale])
 
 
''DesktopWatcher'' solleva i seguenti eventi:
 
* ''_ActiveWindow'': l'evento è sollevato se si cambia desktop, ossia se si passa ad un altro desktop dello schermo; e se la finestra attiva è cambiata. Per sapere ora quale è, usare ''Desktop.ActiveWindow'' .
 
* ''_Change'': il desktop virtuale corrente è cambiato.
 
* ''_Count'': il numero dei desktop virtuali è cambiato.
 
* ''_Geometry'': la geometria del desktop è mutata.
 
* ''_WindowGeometry'': l'evento è sollevato, se una specifica finestra è stata spostata o ridimensionata.
 
* ''_WindowIcon'': l'evento è sollevato, se l'icona di una specifica finestra è cambiata.
 
* ''_WindowName'': l'evento è sollevato, se il nome o il nome visibile di una specifica finestra è cambiato.
 
* ''_WindowState'': l'evento è sollevato, se lo stato di una specifica finestra è cambiato.
 
* ''_Windows'': l'evento viene sollevato se l'elenco delle finestre è cambiato, cioè se una finestra è stata aperta, chiusa, o se l'ordine di sovrapposizione è cambiato. Per scorrere la lista e vedere quali finestre vi sono, usare ''Desktop.Windows'' .
 
  
 +
''DesktopWatcher'' solleva i seguenti Eventi:
 +
* "_ActiveWindow()": l'Evento è sollevato se si cambia desktop, ossia se si passa ad un altro desktop dello schermo; e se la finestra attiva è cambiata. Per sapere ora quale è, usare ''Desktop.ActiveWindow'' .
 +
* "_Change()": il desktop virtuale corrente è cambiato.
 +
* "_Count()": il numero dei desktop virtuali è cambiato.
 +
* "_Geometry()": la geometria del desktop è mutata.
 +
* "_WindowGeometry()": l'evento è sollevato, se una specifica finestra è stata spostata o ridimensionata.
 +
* "_WindowIcon()": l'evento è sollevato, se l'icona di una specifica finestra è cambiata.
 +
* "_WindowName()": l'evento è sollevato, se il nome o il nome visibile di una specifica finestra è cambiato.
 +
* "_WindowState()": l'evento è sollevato, se lo stato di una specifica finestra è cambiato.
 +
* "_Windows()": l'evento viene sollevato se l'elenco delle finestre è cambiato, cioè se una finestra è stata aperta, chiusa, o se l'ordine di sovrapposizione è cambiato. Per scorrere la lista e vedere quali finestre vi sono, usare ''Desktop.Windows'' .
  
 
===Esempi pratici===
 
===Esempi pratici===
Riga 18: Riga 17:
 
   
 
   
 
   
 
   
  '''Public''' Sub Form_Open()
+
  Public Sub Form_Open()
 
   
 
   
 
   With dw = New DesktopWatcher(Me) As "dw"
 
   With dw = New DesktopWatcher(Me) As "dw"
Riga 25: Riga 24:
 
   End With
 
   End With
 
   
 
   
  '''End'''
+
  End
 
   
 
   
 
   
 
   
Riga 32: Riga 31:
 
  ' ''se viene spostato il focus da una finestra di un programma alla finestra di un altro programma;''
 
  ' ''se viene spostato il focus da una finestra di un programma alla finestra di un altro programma;''
 
  ' ''allora viene sollevato questo evento:''</font>
 
  ' ''allora viene sollevato questo evento:''</font>
  '''Public''' Sub dw_ActiveWindow( )
+
  Public Sub dw_ActiveWindow()
 
    
 
    
  TextArea1.Text &= "Modifica all'interno del Desktop !\n"
+
  TextArea1.Text &= "Modifica all'interno del Desktop !\n"
 
+
  '''End'''
+
  End
 
   
 
   
 
   
 
   
  <FONT color=gray>' ''Se si cambia desktop, ossia se si passa ad un altro desktop dello schermo,''
+
  <FONT color=gray>' ''Se si cambia desktop, ossia se si passa ad un altro desktop dello schermo, allora viene sollevato questo evento:</font>
' ''allora viene sollevato questo evento:</font>
+
  Public Sub dw_Change()
  '''Public''' Sub dw_Change( )
 
 
    
 
    
  TextArea1.Text &= "Cambio Desktop !\n"
+
  TextArea1.Text &= "Cambio Desktop !\n"
 
    
 
    
  '''End'''
+
  End
 
   
 
   
 
   
 
   
  <FONT color=gray>' ''Questo evento viene sollevato se l'elenco delle finestre è cambiato,''
+
  <FONT color=gray>' ''Questo evento viene sollevato se l'elenco delle finestre è cambiato, cioè se una finestra è stata aperta, chiusa, o se l'ordine di sovrapposizione è cambiato:''</font>
' ''cioè se una finestra è stata aperta, chiusa, o se l'ordine di sovrapposizione è cambiato:''</font>
+
  Public Sub dw_Windows()
  '''Public''' Sub dw_Windows( )
 
 
    
 
    
  TextArea1.Text &= "Evento _Windows !\n"
+
  TextArea1.Text &= "Evento _Windows !\n"
 
    
 
    
  '''End'''
+
  End
  
  
In quest'altro esempio verrà sollevato l'evento "''_WindowGeometry( )''" della Classe "''DesktopWatcher''", qualora venga modificata una dimensione della finestra del programma:
+
In quest'altro esempio verrà sollevato l'Evento "_WindowGeometry()" della Classe ''DesktopWatcher'', qualora venga modificata una dimensione della finestra del programma:
 
  Private dwt As DesktopWatcher
 
  Private dwt As DesktopWatcher
 
   
 
   
 
   
 
   
  '''Public''' Sub Form_Open()
+
  Public Sub Form_Open()
 
    
 
    
 
   dwt = New DesktopWatcher As "DesktopWatcher"
 
   dwt = New DesktopWatcher As "DesktopWatcher"
 
    
 
    
  '''End'''
+
  End
 
   
 
   
 
   
 
   
  '''Public''' Sub DesktopWatcher_WindowGeometry(dwd As DesktopWindow)
+
  Public Sub DesktopWatcher_WindowGeometry(dwd As DesktopWindow)
 
   
 
   
 
   Print dwd.W, dwd.H
 
   Print dwd.W, dwd.H
 
    
 
    
  '''End'''
+
  End
  
  
In quest'altro esempio si utilizzerà l'Evento "_Windows" della Classe "DesktopWatcher", per osservare l'apertura della finestra di Dialogo utile per caricare un file.
+
In quest'altro esempio si utilizzerà l'Evento "_Windows()" della Classe ''DesktopWatcher'', per osservare l'apertura della finestra di Dialogo utile per caricare un file.
 
<BR>In tal caso il "Titolo" della finestra di Dialogo ".OpenFile" dovrà essere "certo" e "univoco".
 
<BR>In tal caso il "Titolo" della finestra di Dialogo ".OpenFile" dovrà essere "certo" e "univoco".
 
  Private wa As DesktopWatcher
 
  Private wa As DesktopWatcher
Riga 81: Riga 78:
 
   
 
   
 
   
 
   
  '''Public''' Sub Form_Open()
+
  Public Sub Form_Open()
 
    
 
    
 
  <FONT Color=gray>' ''Osserva tutte le finestre, presenti e quelle eventuali future, sulla Scrivania:''</font>
 
  <FONT Color=gray>' ''Osserva tutte le finestre, presenti e quelle eventuali future, sulla Scrivania:''</font>
 
   wa = New DesktopWatcher As "DWatch"
 
   wa = New DesktopWatcher As "DWatch"
 
    
 
    
  '''End'''
+
  End
 
   
 
   
  '''Public''' Sub Button1_Click()
+
   
 +
Public Sub Button1_Click()
 
    
 
    
 
   With Dialog
 
   With Dialog
  <FONT Color=gray>' ''Il "Titolo" della finestra di Dialo deve essere certo e univoco.''
+
  <FONT Color=gray>' ''Il "Titolo" della finestra di Dialog deve essere <SPAN Style="text-decoration:underline">certo</span> e <SPAN Style="text-decoration:underline">univoco</span>.''
 
  ' ''(In questo esempio è impostato il titolo: Abcde).''</font>
 
  ' ''(In questo esempio è impostato il titolo: Abcde).''</font>
 
     .Title = "Abcde"
 
     .Title = "Abcde"
Riga 97: Riga 95:
 
   End With
 
   End With
 
    
 
    
  '''End'''
+
  End
 +
 
   
 
   
  '''Public''' Sub DWatch_Windows()  <FONT Color=gray>' ''Se la l'elenco delle finestre aperte sulla Scrivania è cambiato...''</font>
+
  Public Sub DWatch_Windows()  <FONT Color=gray>' ''Se la l'elenco delle finestre aperte sulla Scrivania è cambiato...''</font>
 
    
 
    
 
  <FONT Color=gray>' ''...allora si verifica se si è aperta proprio la finestra "Abcde":''</font>
 
  <FONT Color=gray>' ''...allora si verifica se si è aperta proprio la finestra "Abcde":''</font>
Riga 109: Riga 108:
 
   Endif  
 
   Endif  
 
    
 
    
  '''End'''
+
  End

Versione attuale delle 15:30, 22 giu 2024

La classe DesktopWatcher, utilizzabile attivando i Componenti gb.desktop e gb.desktop.x11, osserva il desktop sullo schermo. Essa consente all'utente di essere in grado di rilevare l'attività dello schermo con i gestori di eventi:

variabileTipoDesktopWatcher_NomeEvento([parametro-eventuale])

DesktopWatcher solleva i seguenti Eventi:

  • "_ActiveWindow()": l'Evento è sollevato se si cambia desktop, ossia se si passa ad un altro desktop dello schermo; e se la finestra attiva è cambiata. Per sapere ora quale è, usare Desktop.ActiveWindow .
  • "_Change()": il desktop virtuale corrente è cambiato.
  • "_Count()": il numero dei desktop virtuali è cambiato.
  • "_Geometry()": la geometria del desktop è mutata.
  • "_WindowGeometry()": l'evento è sollevato, se una specifica finestra è stata spostata o ridimensionata.
  • "_WindowIcon()": l'evento è sollevato, se l'icona di una specifica finestra è cambiata.
  • "_WindowName()": l'evento è sollevato, se il nome o il nome visibile di una specifica finestra è cambiato.
  • "_WindowState()": l'evento è sollevato, se lo stato di una specifica finestra è cambiato.
  • "_Windows()": l'evento viene sollevato se l'elenco delle finestre è cambiato, cioè se una finestra è stata aperta, chiusa, o se l'ordine di sovrapposizione è cambiato. Per scorrere la lista e vedere quali finestre vi sono, usare Desktop.Windows .

Esempi pratici

Private dw As DesktopWatcher


Public Sub Form_Open()

 With dw = New DesktopWatcher(Me) As "dw"
' Restituisce o imposta se l'oggetto DesktopWatcher guarda solo la finestra principale:
   .RootWindow = True
 End With

End


' Se avvengono dei cambiamenti all'interno del desktop, ma anche:
' se si cambia desktop, ossia se si passa ad un altro desktop dello schermo;
' se viene spostato il focus da una finestra di un programma alla finestra di un altro programma;
' allora viene sollevato questo evento:
Public Sub dw_ActiveWindow()
 
 TextArea1.Text &= "Modifica all'interno del Desktop !\n"

End


' Se si cambia desktop, ossia se si passa ad un altro desktop dello schermo, allora viene sollevato questo evento:
Public Sub dw_Change()
 
 TextArea1.Text &= "Cambio Desktop !\n"
 
End


' Questo evento viene sollevato se l'elenco delle finestre è cambiato, cioè se una finestra è stata aperta, chiusa, o se l'ordine di sovrapposizione è cambiato:
Public Sub dw_Windows()
 
 TextArea1.Text &= "Evento _Windows !\n"
 
End


In quest'altro esempio verrà sollevato l'Evento "_WindowGeometry()" della Classe DesktopWatcher, qualora venga modificata una dimensione della finestra del programma:

Private dwt As DesktopWatcher


Public Sub Form_Open()
 
 dwt = New DesktopWatcher As "DesktopWatcher"
 
End


Public Sub DesktopWatcher_WindowGeometry(dwd As DesktopWindow)

 Print dwd.W, dwd.H
  
End


In quest'altro esempio si utilizzerà l'Evento "_Windows()" della Classe DesktopWatcher, per osservare l'apertura della finestra di Dialogo utile per caricare un file.
In tal caso il "Titolo" della finestra di Dialogo ".OpenFile" dovrà essere "certo" e "univoco".

Private wa As DesktopWatcher
Private dw As DesktopWindow


Public Sub Form_Open()
 
' Osserva tutte le finestre, presenti e quelle eventuali future, sulla Scrivania:
 wa = New DesktopWatcher As "DWatch"
  
End


Public Sub Button1_Click()
 
 With Dialog
' Il "Titolo" della finestra di Dialog deve essere certo e univoco.
' (In questo esempio è impostato il titolo: Abcde).
   .Title = "Abcde"
   If .OpenFile() Then Return 
 End With
 
End


Public Sub DWatch_Windows()  ' Se la l'elenco delle finestre aperte sulla Scrivania è cambiato...
 
' ...allora si verifica se si è aperta proprio la finestra "Abcde":
 If Desktop.FindWindow("Abcde", Null, Null).Count > 0 Then 
' Se è così, allora la finestra di Dialogo, avente Titolo "Abcde", viene ridimensionata:
   With dw = New DesktopWindow(Desktop.FindWindow("Abcde", Null, Null)[0])
     .Resize(Screen.AvailableWidth, Screen.AvailableHeight)
   End With
 Endif 
 
End