Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-11-2008, 14:43   #1
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
[VB.NET]Caricamento dati una sola volta

Ciao a tutti

Il mio problema è questo:

Ho degli oggetti che vengono caricati a runtime su di un form.

Alcuni di questi oggetti sono legati ad una fonte dati e da essa traggono determinati valori.

Ora mi succede questo:

Sul form c'è un oggetto di tipo TabControl.

In corrispondenza del TabPage 1, devo caricare determinati dati.

Mi sembrava semplice utilizzando l'evento selected index changed...

...ma, ovviamente il codice che ho scritto viene eseguito ogni volta che questo tab viene selezionato e, di conseguenza, se l'utente aveva variato dei valori dal form, si ritrova con i valori precedenti al cambio tab.

Mi sono detto quindi, vabbè, la funzione la eseguo durante il caricamento del form....

Ovviamente, non funziona, cioè, se lo stesso codice scritto nell'evento selectedIndexChanged lo metto nel Form_Load non ha alcun effetto.

il codice incriminato è:

Codice:
Sub BindColors(ByVal panel As Panel, ByVal idColor As Integer)

      Try
         Dim ds As New IndexColorTableAdapter.GetDescription
         
         For Each gp As GroupBox in panel.Controls
 
             For Each txt As TextBox in gp.Controls

                Dim tblIndexColors As New DataSet

                  tblIndexColors.Tables.Add(ds.GetDataById(idColor, g.Text.SubString(0, 2))

                  txt.DataBindings.Add("Text", tblIndexColors.Tables(0), "Descrizione")
                  txt.DataBindings.Remove(txt.DataBindings("Text"))
              Next
          Next

        Catch ex As Exception
        'blabla
      End Try
Grazie mille

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2008, 09:59   #2
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
Mi sembrava semplice utilizzando l'evento selected index changed...

...ma, ovviamente il codice che ho scritto viene eseguito ogni volta che questo tab viene selezionato e, di conseguenza, se l'utente aveva variato dei valori dal form, si ritrova con i valori precedenti al cambio tab.
Se l'utente varia dei valori puoi eseguirne il commit a DB prima del caricamento dati sul Tab Change... O no ?

Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
il codice incriminato è:

Codice:
Sub BindColors(ByVal panel As Panel, ByVal idColor As Integer)

      Try
         Dim ds As New IndexColorTableAdapter.GetDescription
         
         For Each gp As GroupBox in panel.Controls
 
             For Each txt As TextBox in gp.Controls

                Dim tblIndexColors As New DataSet

                  tblIndexColors.Tables.Add(ds.GetDataById(idColor, g.Text.SubString(0, 2))

                  txt.DataBindings.Add("Text", tblIndexColors.Tables(0), "Descrizione")
                  txt.DataBindings.Remove(txt.DataBindings("Text"))
              Next
          Next

        Catch ex As Exception
        'blabla
      End Try
Grazie mille

RaouL.
Già provato ad escludere il blocco Try/Catch per vedere se e dove va in errore ?
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2008, 10:37   #3
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
Se l'utente varia dei valori puoi eseguirne il commit a DB prima del caricamento dati sul Tab Change... O no ?
Eh no, non sarebbe conveniente perchè l'utente potrebbe decidere di variare ennemila volte quei valori; avrei quindi per ciascun utente una serie di connessioni al db abbastanza allarmante

Quote:

Già provato ad escludere il blocco Try/Catch per vedere se e dove va in errore ?
Il problema è che l'avevo messo proprio perchè non mi sollevava nessuna eccezione
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 01-12-2008, 09:17   #4
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da RaouL_BennetH Guarda i messaggi
Eh no, non sarebbe conveniente perchè l'utente potrebbe decidere di variare ennemila volte quei valori; avrei quindi per ciascun utente una serie di connessioni al db abbastanza allarmante
Beh, questa non era una domanda scontata, dato che non avevi specificato si trattasse di n applicazioni client che vanno a scrivere sullo stesso DB.
Inoltre non hai considerato l'ipotesi di avere un DataSet in locale, che prenda ogni modifica utente e poi una volta sola aggiorni in blocco le modifiche a DB...
Comunque se quel codice dici che funziona sul TabChange, una soluzione "furbetta" ce l'hai già a portata di mano : all'avvio del Form forzi la selezione del Tab via codice, una volta sola ( definendo e poi controllando un'apposita variabile Boolean a livello di Form... ).
Allora :

Codice:
    Private Sub Form_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

        TabControl1.SelectTab("TabPage2")
        TabControl1.SelectTab("TabPage1")

    End Sub
produrrà lo stesso effetto di :

Codice:
   Private Sub TabControl1_SelectedIndexChanged(ByVal sender As Object, ByVal e As System.EventArgs) Handles TabControl1.SelectedIndexChanged

        If TabControl1.SelectedTab.Name = "TabPage1" Then
            MsgBox("Hai selezionato TabPage1")
        End If

    End Sub
Non sarà il massimo, ma meglio che niente...
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 01-12-2008, 09:31   #5
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Ciao

Ho risolto in un altro modo credo abbastanza semplice.

Ho impostato una variabile di tipo intero alla selezione del tab.

Una volta che il tab è stato selezionato, la variabile assume valore '1'.

Ogni volta che l'utente rientra in quel tab, se la variabile è uno allora i dati non vengono più caricati.

Ho fatto diverse prove e sembra reggere.

Grazie ancora.

RaouL.
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 01-12-2008, 09:34   #6
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Già.
Più o meno siamo arrivati alla stessa soluzione "furba"...
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Netflix diventa la casa globale dei film...
Monitor gaming in forte sconto su Amazon...
500 miliardi di dollari e meno dazi: l'a...
Da Detroit scopriamo le livree di Red Bu...
Microsoft, Meta e Amazon aderiscono al p...
Microsoft integrerà Copilot in Es...
Samsung Internet for Windows: il browser...
Logitech fa sul serio: mouse PRO, tastie...
Spotify aumenta ancora il prezzo del ser...
Bose QuietComfort Ultra (2ª Gen) scendon...
ASUS annuncia l'arrivo in Italia di due ...
Apple prepara l'addio al notch su smartp...
Linux cresce grazie all'addio a Windows ...
Forza un ufficio, smonta le memorie dal ...
Bentornati nel 2007: le memorie DDR3 rin...
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: 09:52.


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