venerdì 2 maggio 2008

Creare un calendario per Microsoft Access 2007 tramite VBA.

Pubblicato sul sito iprogrammatori http://www.iprogrammatori.it/articoli/programmazione/creare_calendario_microsoft_access.asp un mio articolo riguardante la programazione Access tramite vba.
In questo articolo, vedremo come creare un calendario da utilizzare nelle maschere di Microsoft Access 2007, tramite codice Visual Basic Application. Il calendario verrà visualizzato al click di un pulsante e visualizzare in una casella di testo, la data selezionata.







Figura 1


Creazione del database.

Prima di vedere il codice Visual Basic Application, occorre creare il database, si crea un nuovo database vuoto, fatto ciò dobbiamo creare delle maschere nella quali tramite un pulsante richiama la maschera del calendario, la maschera calendario avrà il compito di inserire la data selezionata in una casella di testo della maschera che ha aperto il calendario.

Si crea un nuova maschera, selezionare la voce di menu crea e poi nella barra degli strumenti, la voce struttura maschera. Questa maschera avrà il compito di visualizzare il calendario.

Come mostrato in figura 2







Figura 2


Tramite il pulsante inserisci controllo ActiveX, nella finestra che viene aperta (figura 2) selezioniamo la voce “Controllo Calendario 12.0” selezioniamo tale voce e confermiamo tramite il pulsante ok.

Fatto ciò inseriamo due pulsanti, uno per la conferma della data selezionata il quale avrà come testo la dicitura “Conferma”, e l’altro per la chiusura della finestra con la dicitura “Chiudi”, senza che venga riportata la data selezionata. La finestra dev’essere simile come riportata in figura 2.

Terminata la fase per l’impostazione della finestra, scriviamo il codice VBA, che avrà il compito di riportare la data selezionata.

Selezioniamo il pulsante quello per la chiusura della finestra, e nell’evento click di tale pulsante, inseriamo il seguente codice che permette la chiusura della maschera.

Codice Vba per il pulsante della chiusura:


Private Sub Chiudi_Click()


On Error GoTo Errore


DoCmd.Close


Exit Sub


Errore:


MsgBox "Si è verificato il seguente errore: " & Err.Description, vbCritical, "Calendario"


End Sub



Sempre nell’editor VBA, inseriamo due variabili pubbliche, che avranno il compito di riportare il nome della maschera e del controllo che andrà aggiornato.

Il codice va messo in alto, come mostrato qui di seguito.


Option Compare Database


Public NomeControllo As String


Public NomeMaschera As String





Per l’evento click del pulsante conferma, andrà inserito il codice che avrà il compito di riportare nel controllo della maschera che ha avviato il calendario la data selezionata.

Di seguito si riporta il codice per l’evento click del pulsante di conferma.


Private Sub Conferma_Click()


On Error GoTo Errore


Dim Data As String


'Rilevo la data


Data = Calendario.Value


Dim intConta As Integer


'ciclo per tutte le machere e poi per tutti i controlli


Dim IntContaMaschere As Integer


For IntContaMaschere = 0 To CurrentProject.AllForms.Count - 1


If Application.Forms(IntContaMaschere).Name = NomeMaschera Then


Dim intContaControlli As Integer


For intContaControlli = 0 To Application.Forms(IntContaMaschere).Controls.Count - 1


If Application.Forms(IntContaMaschere).Controls.Item(intContaControlli).Name = NomeControllo Then


'Trova la mashcera e controllo, imposto la data


Forms(Application.Forms(IntContaMaschere).Name).Controls(Application.Forms(IntContaMaschere).Controls.Item(intContaControlli).Name).SetFocus


Forms(Application.Forms(IntContaMaschere).Name).Controls(Application.Forms(IntContaMaschere).Controls.Item(intContaControlli).Name).Text = Data


'chiudo la finestra


DoCmd.Close


Exit Sub


End If


Next intContaControlli



End If


Next IntContaMaschere


'chiudo la finestra


DoCmd.Close


Exit Sub



Errore:


MsgBox "Si è verificato il seguente errore: " & Err.Description, vbCritical, "Calendario"


End Sub





Creazione della maschera di esempio.

Terminata la creazione della maschera per la visualizzazione del calendario, non ci resta che creare una maschera di esempio.






Figura 3

La maschera dovrà avere tre caselle di testo, tre etichette ed un pulsante il quale avrà il compito di richiamare la maschera per la selezione della data. L’aspetto della maschera dev’essere simile a quella illustrata in figura 3.

Di seguito si riporta il codice per l’evento click del pulsante.


Private Sub calendario_Click()


On Error GoTo Errore



'apro la maschera calendario


DoCmd.OpenForm "Calendario"


'imposto le variabili pubbliche con il nome del controllo e della maschera


Form_Calendario.NomeControllo = Me.txtdata.Name


Form_Calendario.NomeMaschera = Me.Name


Exit Sub



Errore:


MsgBox "Si è verificato il seguente errore: " & Err.Description, vbCritical, "Calendario"



End Sub






Conclusioni:

In questo articolo, abbiamo visto come migliorare l’interfaccia grafica delle maschera con un calendario, il tutto tramite il codice Visual Basic Application. Tramite la parola Download è possibile scaricare il file Microsoft Access 2007 di esempio, completo del codice VBA.

Download esempio




Nessun commento: