|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Junior Member
Iscritto dal: Jul 2008
Messaggi: 2
|
[access] on-screen keyboard
Salve a tutti, spero di essere nella sezione giusta.
Avrei bisogno di un consiglio per Access 2003. Sto cercando di creare una tastiera virtuale (on-screen keyboard) su una form di Access. In pratica ho creato in una form tutti i pulsanti alfanumerici di una normale tastiera QWERTY. Tramite il comando Sendkeys vado a scrivere i caratteri dentro le mie textbox nella form. La scelta della textbox nella quale scrivere la faccio tramite il comando PreviousControl.SetFocus. In pratica seleziono la casella di testo, poi cliccando il pulsante della tastiera virtuale riporto il focus alla textbox e vado a scrivere il mio carattere. Codice:
Private Sub pulsante1_Click()
Screen.PreviousControl.SetFocus
If Screen.ActiveControl.Name = "casella_di_testo_x" Then
Sendkeys("1")
End If
End Sub
Il mio problema è che se digito successivamente un altro carattere, perdo momentaneamente il focus della casella di testo e questo mi causa inconvenienti. Faccio un esempio: Se ho, ad esempio, una casella di testo in formato DATA, con maschera di imput in formato DATA, e devo inserire una data (ad esempio 11/11/2000) faccio così: seleziono la casella e poi premo il pulsante 1 della mia tastierina a video, poi quando lo premo nuovamente per completare il numero 11, ho un messaggio di errore che mi dice (ovviamente) che il valore inserito non è corretto, in quanto sono momentaneamente uscito dalla casella di testo per digitare il pulsante lasciando la data incompleta. Avrei quindi bisogno di una funzione che non mi faccia perdere il focus quando premo i pulsanti del tastierino, esattamente come fa la tastiera su schermo di windows. Qualcuno ha mai provato a fare qualcosa del genere? E' fattibile secondo voi? |
|
|
|
|
|
#2 | |
|
Senior Member
Iscritto dal: Dec 2004
Messaggi: 3210
|
Quote:
La tastiera a schermo di Win usa sicuramente un sistema più raffinato per capire dove deve scrivere, e inoltre è su un'altra Form, esterna alla maschera di Access, infatti da tastiera Win si può compilare quel campo data senza incorrere nell'errore... E mettere un pulsante sulla tua maschera che apre la tastiera di Win ? Codice:
Private Sub cmd_osk_Click()
Shell "osk.exe"
End Sub
Cmq, anche in Access credo si possa fare, certo hai scelto l'implementazione di VBA più problematica come uso delle Forms e dei Focus... Potresti avere 2 Maschere aperte contemporaneamente, una solo per ospitare i tasti... Lo vedo cmq un lavoraccio... |
|
|
|
|
|
|
#3 |
|
Junior Member
Iscritto dal: Jul 2008
Messaggi: 2
|
Hai ragione.
Comunque ho applicato il tuo consiglio di utilizzare OSK.EXE. E' la cosa migliore. Cercavo di non utilizzarlo perchè la mia applicazione deve girare su touch screen e i tastini di OSK sono davvero piccolini da digitare con le dita... Tra l'altro OSK non si può nemmeno dimensionare (o almeno io non ci sono riuscito...) Grazie comunque del consiglio. |
|
|
|
|
|
#4 | |
|
Senior Member
Iscritto dal: Dec 2004
Messaggi: 3210
|
Quote:
Ci sono strumenti ben più efficaci, lo stesso VB6, o al meglio VB.NET. Certo questo ti mette nella posizione di dover cambiare tutto o quasi nella tua applicazione... |
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 19:55.




















