Differenze tra le versioni di "Mostrare una parte di un'immagine"

Da Gambas-it.org - Wikipedia.
(Creata pagina con 'Per mostrare soltanto una <SPAN style="text-decoration:underline">parte</span> di un'immagine, è possibile utilizzare il metodo ''.Resize()'' della Classe ''Picture''. Facc...')
 
Riga 1: Riga 1:
Per mostrare soltanto una <SPAN style="text-decoration:underline">parte</span> di un'immagine, è possibile utilizzare il metodo ''.Resize()'' della Classe ''Picture''.
+
Mostrare una <SPAN style="text-decoration:underline">parte</span> di un'mmagine prevede due casi che possiamo definire:
 +
* a coordinate iniziali fisse;
 +
* a coordinate iniziali mobili.
  
 +
 +
===Caso "''a coordinate iniziali fisse''"===
 +
In questo caso le coordinate iniziali dell'immagine, sia in riferimento alla sua lunghezza che alla sua altezza, sono definite in modo statico dai valori ''x = 0'' e ''y = 0'', e viene utilizzato il metodo ''.Resize()'' della Classe ''Image'' o della Classe ''Picture''. L'effetto che si ottiene è semplicemente quello di un'immagine ''tagliata''.
  
 
Facciamo un esempio, nel quale mostreremo una parte di un'immagine avente dimensioni 720 x 1280 pixel.
 
Facciamo un esempio, nel quale mostreremo una parte di un'immagine avente dimensioni 720 x 1280 pixel.
 
  '''Public''' Sub Form_Open()   
 
  '''Public''' Sub Form_Open()   
 
    
 
    
   Dim p As Picture
+
   Dim im As Image
 
      
 
      
 
      
 
      
   With p = Picture.Load("''/percorso/della/immagine/da/caricare''")   
+
   With im = Image.Load("''/percorso/della/immagine/da/caricare''")   
 
  <FONT Color=gray>' ''Prendiamo soltanto una "parte" dell'immagine:''</font>
 
  <FONT Color=gray>' ''Prendiamo soltanto una "parte" dell'immagine:''</font>
 
     <FONT Color=#B22222>.Resize(PictureBox1.W, 300)</font>   
 
     <FONT Color=#B22222>.Resize(PictureBox1.W, 300)</font>   
 
   End With   
 
   End With   
 
      
 
      
  <FONT Color=gray>' ''Carichiamo la "Picture" nella "PictureBox", che provvederà a mostrarla:''</font>
+
  <FONT Color=gray>' ''Carichiamo l'immagine nella "PictureBox", che provvederà a mostrarla:''</font>
   PictureBox1.Picture =
+
  PictureBox1.Picture = im.Picture
 +
   
 +
'''End'''
 +
 
 +
 
 +
===Caso "''a coordinate iniziali mobili''"===
 +
In questo caso le coordinate iniziali dell'immagine, invece, ''slittano'' lungo l'immagine medesima; e pertanto potremo individuare un qualsiasi dettaglio dell'immagine. Si utilizzerà il metodo ''.Copy()'' della Classe ''Image''.
 +
 
 +
Esempio:
 +
'''Public''' Sub Form_Open() 
 +
 
 +
  Dim im As Image
 +
 +
  With im = Image.Load("''/percorso/della/immagine/da/caricare''") 
 +
<FONT Color=gray>' ''Prendiamo un dettaglio dell'immagine:''</font>
 +
    <FONT Color=#B22222>.Copy(100, 200, 200, 100)</font> 
 +
  End With 
 +
   
 +
<FONT Color=gray>' ''Carichiamo l'immagine nella "PictureBox", che provvederà a mostrarla:''</font>
 +
   PictureBox1.Picture = im.Picture
 
      
 
      
 
  '''End'''
 
  '''End'''
 +
In vero il metodo ''.Copy()'' può essere utilizzato anche nel caso precedente a coordinate iniziali fisse, ponendo i primi due argomenti (x e y) a zero.

Versione delle 13:08, 26 dic 2014

Mostrare una parte di un'mmagine prevede due casi che possiamo definire:

  • a coordinate iniziali fisse;
  • a coordinate iniziali mobili.


Caso "a coordinate iniziali fisse"

In questo caso le coordinate iniziali dell'immagine, sia in riferimento alla sua lunghezza che alla sua altezza, sono definite in modo statico dai valori x = 0 e y = 0, e viene utilizzato il metodo .Resize() della Classe Image o della Classe Picture. L'effetto che si ottiene è semplicemente quello di un'immagine tagliata.

Facciamo un esempio, nel quale mostreremo una parte di un'immagine avente dimensioni 720 x 1280 pixel.

Public Sub Form_Open()  
 
 Dim im As Image
    
    
  With im = Image.Load("/percorso/della/immagine/da/caricare")  
' Prendiamo soltanto una "parte" dell'immagine:
    .Resize(PictureBox1.W, 300)  
  End With  
    
' Carichiamo l'immagine nella "PictureBox", che provvederà a mostrarla:
  PictureBox1.Picture = im.Picture
    
End


Caso "a coordinate iniziali mobili"

In questo caso le coordinate iniziali dell'immagine, invece, slittano lungo l'immagine medesima; e pertanto potremo individuare un qualsiasi dettaglio dell'immagine. Si utilizzerà il metodo .Copy() della Classe Image.

Esempio:

Public Sub Form_Open()  
 
 Dim im As Image

  With im = Image.Load("/percorso/della/immagine/da/caricare")  
' Prendiamo un dettaglio dell'immagine:
    .Copy(100, 200, 200, 100)  
  End With  
    
' Carichiamo l'immagine nella "PictureBox", che provvederà a mostrarla:
  PictureBox1.Picture = im.Picture
    
End

In vero il metodo .Copy() può essere utilizzato anche nel caso precedente a coordinate iniziali fisse, ponendo i primi due argomenti (x e y) a zero.