IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

VBA Access Discussion :

fermer le clavier vituel avec le VB


Sujet :

VBA Access

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2012
    Messages : 10
    Points : 6
    Points
    6
    Par défaut fermer le clavier vituel avec le VB
    Bonjour j'utilise les codes suivants pour ouvrir le clavier virtuel:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Private Declare Function ShellExecute Lib "shell32.dll" Alias "ShellExecuteA" _
        (ByVal hwnd As Long, ByVal lpOperation As String, ByVal lpFile As String, _
        ByVal lpParameters As String, ByVal lpDirectory As String, ByVal nShowCmd As Long) As Long
     
    Private Sub cmdclavier_Click()
     
            ShellExecute Me.hwnd, "open", "osk.exe", "", "", 1
     
    End Sub
    Ce code fonctionne parfaitement. Mais je voudrais aussi fermer le clavier en cliquant sur un bouton. J'ai cherché les options de ShellExecute mais il n'esxiste apparement pas une option du type close ou quit.
    Quelqu'un aurait une solution? Merci d'avance

  2. #2
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 759
    Points
    7 759
    Par défaut
    Bonjour,

    Essaie avec ce code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    Sub FermerOsk()
    Dim oSvc As Object
    Dim sQuery As String
    Dim oProc As Object, oProcs As Object
     
    Set oSvc = GetObject("winmgmts:root\cimv2")
    sQuery = "select * from win32_process where name='osk.exe'"
    Set oProcs = oSvc.ExecQuery(sQuery)
    If oProcs.Count = 1 Then
       For Each oProc In oProcs
           oProc.Terminate 0
       Next
    End If
    Set oProcs = Nothing
    Set oSvc = Nothing
    End Sub
    Tu peux aussi essayer Comment tuer un processus en connaissant le nom de sa fenêtre ?

    A+

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Juillet 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2012
    Messages : 10
    Points : 6
    Points
    6
    Par défaut
    le code fonctionne nickel!
    Merci beaucoup

  4. #4
    Nouveau Candidat au Club
    Homme Profil pro
    Technicien Méthodes
    Inscrit en
    Octobre 2018
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Technicien Méthodes
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2018
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Cela ne fonctionne pas pour moi
    Citation Envoyé par LedZeppII Voir le message
    Bonjour,

    Essaie avec ce code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    Sub FermerOsk()
    Dim oSvc As Object
    Dim sQuery As String
    Dim oProc As Object, oProcs As Object
     
    Set oSvc = GetObject("winmgmts:root\cimv2")
    sQuery = "select * from win32_process where name='osk.exe'"
    Set oProcs = oSvc.ExecQuery(sQuery)
    If oProcs.Count = 1 Then
       For Each oProc In oProcs
           oProc.Terminate 0
       Next
    End If
    Set oProcs = Nothing
    Set oSvc = Nothing
    End Sub
    Tu peux aussi essayer Comment tuer un processus en connaissant le nom de sa fenêtre ?

    A+
    J'ai essayé différentes méthodes, en utilisant les fonction taskkill, killprocess, ta méthode également... Je doit louper quelque chose

    En testant directement taskkill dans cmd, je pense avoir l'explication :
    Erreur*: le processus "osk.exe" de PID 34636 n’a pas pu être arrêté.
    Raison*: Accès refusé.


    (Note : j'ai essayé en précisant /U / P, mais il faut renseigner /S ... Où puis-je trouver ce nom ? )

    Je suis en entreprise, donc pas administrateur complet du poste de travail...

    Je peux lancer osk.exe via VBA mais pas le fermer ??
    Qui à une idée pour me dépanner ?

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Swing] fermer une fenetre enfant avec un bouton.
    Par TheSeb dans le forum AWT/Swing
    Réponses: 3
    Dernier message: 23/11/2013, 12h42
  2. Réponses: 9
    Dernier message: 17/11/2008, 17h18
  3. Réponses: 2
    Dernier message: 10/07/2006, 18h19
  4. Classe clavier problème avec char
    Par benjiprog dans le forum Langage
    Réponses: 30
    Dernier message: 30/06/2006, 16h04
  5. Comment fermer une Fenetre Modal avec Code ?
    Par Soulama dans le forum Langage
    Réponses: 19
    Dernier message: 13/07/2005, 11h17

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo