Torna indietro   Hardware Upgrade Forum > Software > Programmazione

WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 07-11-2008, 19:33   #1
immakx
Member
 
Iscritto dal: Feb 2005
Città: Ancona
Messaggi: 177
[Vb '08]Array PictureBox

Per prima cosa, dato che è venerdì sera, buon Weekend a tutti,
poi,
la domanda da novizio di Vb.Net è la seguente: devo realizzare una tabella di picturebox ( 5x5 ) ed eseguo:

Codice:
Dim MyBox(25) As PictureBox
Dim Cnt As Integer = 1
Dim Cnv As Integer = 1
For x As Integer = 1 To 25
   MyBox(x) = PictureBox1 ' picturebox di riferimento
   MyBox(x).Image = Image.FromFile(Application.StartupPath & "\Img\n" & x & ".mxp")
   MyBox(x).Left = ((Cnt - 1) * 70) + 12
   MyBox(x).Top = ((Cnv - 1) * 70) + 12
   MyBox(x).Refresh()
   Cnt = Cnt + 1
   If Cnt = 6 Then
     Cnt = 1
     Cnv = Cnv + 1
   End If
Next
Ma vedo che anche se le picturebox vengono generate giuste ognuna va a riscrivere tutti i valori delle precedenti e cosi alla fine mi trovo con tutte le picturebox uguali e sovrapposte all'ultima ...

cosa mi sto dimenticando ?

Su Msdn non sono riuscito a capirlo...

Grazie
immakx è offline   Rispondi citando il messaggio o parte di esso
Old 07-11-2008, 21:13   #2
||ElChE||88
Senior Member
 
Iscritto dal: Dec 2003
Messaggi: 4907
Questo codice
Codice:
MyBox(x) = PictureBox1 ' picturebox di riferimento
non crea una nuova PictureBox, ma soltanto una referenza a PictureBox1.
Prova:
Codice:
MyBox(x) = New PictureBox
||ElChE||88 è offline   Rispondi citando il messaggio o parte di esso
Old 07-11-2008, 21:56   #3
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
1. Dim MyBox(25) As PictureBox :
Questo array, a meno che tu non l'abbia creato espressamente per un motivo, è superfluo. Ad ogni ciclo aggiungi semplicemente una nuova PictureBox e il risultato non cambia...

2. Manca un esplicito riferimento al contenitore per questi controlli. Male. Io ti consiglio un Panel, che sposti dove vuoi sulla Form... Ne hai solo vantaggi.
Sennò rischi che controlli aggiunti a runtime vadano a sovrapporsi a quelli già presenti sulla Form.

3. Non si eredita MAI chiamando un controllo già presente sulla Form ( il tuo PictureBox1 ). Semplicemente ti fai una classe che eredita da PictureBox e nel costruttore specifichi tutte le proprietà di default che deve avere.

In soldoni :

-> La classe :
Codice:
Public Class MiaPictureBox

    Inherits Windows.Forms.PictureBox

    Public Sub New()

        Me.Width = 160
        Me.Height = 120
        Me.BackColor = Color.Black
        Me.BorderStyle = Windows.Forms.BorderStyle.FixedSingle
        '...
        '... 

    End Sub

End Class
-> Codice corretto ( senza stravolgere il tuo... ) :
Codice:
        Dim MyBox(25) As PictureBox
        Dim Cnt As Integer = 1
        Dim Cnv As Integer = 1
        For x As Integer = 1 To 25
            Dim PctBox As New MiaPictureBox
            MyBox(x) = PctBox            
            MyBox(x).Image = Image.FromFile(Application.StartupPath & "\Img\n" & x & ".mxp")
            Panel1.Controls.Add(MyBox(x))            
            MyBox(x).Left = ((Cnt - 1) * 70) + 12
            MyBox(x).Top = ((Cnv - 1) * 70) + 12
            MyBox(x).Refresh()
            Cnt = Cnt + 1
            If Cnt = 6 Then
                Cnt = 1
                Cnv = Cnv + 1
            End If
        Next

Ultima modifica di MarcoGG : 07-11-2008 alle 21:59.
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 08-11-2008, 09:31   #4
immakx
Member
 
Iscritto dal: Feb 2005
Città: Ancona
Messaggi: 177
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi

In soldoni :
[..]

-> Codice corretto ( senza stravolgere il tuo... ) :
Grazie 1000 !!!
__________________
Max.
AMX - CRESTRON
Junior System Engineer
immakx è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
WhatsApp si aggiorna con una nuova app c...
Windows 11 23H2, ricerca nel menu Start ...
Google Chrome introduce il layout vertic...
Artemis II: per la prima volta degli ast...
Battery swap e flotte smart: così nasce ...
Apple affronta un dilemma con il MacBook...
ECOVACS X11 OMNICYCLONE: 19.500 Pa, moci...
ll nuovo HONOR 600 Lite 5G arriva in Ita...
Kindle, addio allo store sui vecchi e-re...
DJI Flip Combo Fly More a 599€ invece di...
Addio cavi e adattatori multipli: Techly...
MOVA M50 Ultra: scopa elettrica con brac...
Amazon taglia i prezzi su GPU, CPU, alim...
Snapdragon 8 Elite Gen 6 Pro: migliorame...
Mythos di Anthropic trasforma il 72% del...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 10:49.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v