PDA

View Full Version : [access] on-screen keyboard


Bugu
03-06-2009, 10:00
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.

Private Sub pulsante1_Click()
Screen.PreviousControl.SetFocus
If Screen.ActiveControl.Name = "casella_di_testo_x" Then
Sendkeys("1")
End If
End Sub

Fino a qui funziona tutto.

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?

MarcoGG
03-06-2009, 14:40
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?

Non puoi avere il Focus contemporaneamente su 2 controlli della stessa Form.
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 ?
Private Sub cmd_osk_Click()

Shell "osk.exe"

End Sub
Una riga di codice, e hai tutto quel che serve.
;)

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...

Bugu
08-06-2009, 12:07
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.

MarcoGG
08-06-2009, 14:26
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.

Il mio consiglio non è stato un granchè, lo so, ma personalmente non sceglierei certo Access per implementare una tastiera su schermo ( diciamo che mi ci metterei sul serio solo dietro compenso o... sotto tortura :D ).
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...