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 :

clic sur treeview


Sujet :

VBA Access

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    166
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 166
    Points : 94
    Points
    94
    Par défaut clic sur treeview
    Bonjour,

    j'ai réussi à réaliser un treeview sur Access en vba mais je n'arrive pas à faire un clic sur une branche pour faire apparaître une nouvelle fenêtre

    Pouvez vous m'aider ? j'ai mis le fichier en pièce jointe

    merci d'avance
    Fichiers attachés Fichiers attachés

  2. #2
    Membre expert
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Octobre 2012
    Messages
    1 871
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2012
    Messages : 1 871
    Points : 3 451
    Points
    3 451
    Par défaut
    Bonjour grimgrim,

    Tu peux faire cela sur l'événement "MouseDown" de l'object treeview.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Private Sub TVEquipItas_MouseDown(ByVal Button As Integer, ByVal Shift As Integer, ByVal x As Long, ByVal y As Long)
    On Error GoTo err_tvw_MouseDown
     
        MsgBox "Voici la clé de ce noeud:  " & TVEquipItas.HitTest(x, y).Key  
     
    err_tvw_MouseDown:
        If Err.Number = 91 Then
            Resume Next
        ElseIf Err.Number = 0 Then
            Exit Sub
        Else
            MsgBox Err.Number & Err.Description
        End If
    End Sub
    Il y a ici un bon tutoriel http://jacma.developpez.com/treeview/ qui explique les principes du Tv.

    Bonne journée
    Ce qui se conçoit bien s’énonce clairement et les mots pour le dire arrivent aisément. Nicolas Boileau
    Si tout est OK, n'oubliez pas de cliquer sur

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    166
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 166
    Points : 94
    Points
    94
    Par défaut
    bonsoir,

    merci pour votre réponse

    Cependant, avant quand je clique, j'avais les fils du noeud qui s'affichaient

    maintenant, j'ai bien le message qui s'affiche

    je souhaiterais avoir le message soit sur le noeud soit en cliquant un fils du noeud en sachant que pour ouvrir un fil noeud je double clique sur le noeud

    merci d'avance

  4. #4
    Expert confirmé

    Homme Profil pro
    consultant développeur
    Inscrit en
    Mai 2005
    Messages
    2 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : consultant développeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2005
    Messages : 2 878
    Points : 4 754
    Points
    4 754
    Par défaut
    Bonjour,
    bien que non documentés les evts Click et Dblclick existent bien pour les treeview.
    Exemple : avec un treeview nommé TV1 :
    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
     
    Private Sub TV1_Click()
     
        Dim sMsg As String
        Dim strSql As String, strFrmName As String
        Dim pos As Integer, i As Integer
        Dim oNode As Object, strNodeKey As String, strCleUnique As String, lngNodekey As Long
     
        Set oNode = Me.TV1.SelectedItem
     
        i = oNode.Index
        strNodeKey = oNode.Key
        sMsg = "TV1_Click - index: " & i & "    Key: " & strNodeKey & "   Checked: " & oNode.Checked
        Debug.Print sMsg
        ' ...
     
    Exit_0:
        Exit Sub
     
    End Sub
     
    Private Sub TV1_DblClick()
     
        Dim sMsg As String
        Dim strSql As String, strFrmName As String
        Dim pos As Integer, i As Integer
        Dim oNode As Object, strNodeKey As String, strCleUnique As String, lngNodekey As Long
     
        Set oNode = Me.TV1.SelectedItem
     
        i = oNode.Index
        strNodeKey = oNode.Key
        sMsg = "TV1_DblClick - index: " & i & "    Key: " & strNodeKey & "   Checked: " & oNode.Checked
        Debug.Print sMsg
        If Not oNode.Parent Is Nothing Then
            strCleUnique = Nz(DLookup("Evt_cle", "T_Ecriture", "Ecr_id=" & clng(strNodeKey )
            Debug.Print strCleUnique
            If Len(strCleUnique) > 0 Then
               ' ...
            End If
     
        Else
            ' C'est la ligne d'un lot, aucun traitement
        End If
     
    Exit_0:
        Exit Sub
     
    End Sub
    CDLT
    "Always look at the bright side of life." Monty Python.

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    166
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 166
    Points : 94
    Points
    94
    Par défaut
    merci pour les informations

    mais j'ai une erreur de syntaxe sur le double click sur la ligne suivante

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    strCleUnique = Nz(DLookup("Evt_cle", "T_Ecriture", "Ecr_id=" & clng(strNodeKey )

  6. #6
    Expert confirmé

    Homme Profil pro
    consultant développeur
    Inscrit en
    Mai 2005
    Messages
    2 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : consultant développeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2005
    Messages : 2 878
    Points : 4 754
    Points
    4 754
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Nz(DLookup("Evt_cle", "T_Ecriture", "Ecr_id=" & clng(strNodeKey ) ...
    L'exemple que je t'ai proposé plus haut est à adapter à ton programme.
    Je suppose que tu n'as pas de table T_ecriture , nest-ce pas ?

    Cdlt
    "Always look at the bright side of life." Monty Python.

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    166
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 166
    Points : 94
    Points
    94
    Par défaut
    non désolé

    j'ai mis mon programme vba et mes tables au début de la conversation dont tu pourras voir les pbres

  8. #8
    Expert confirmé

    Homme Profil pro
    consultant développeur
    Inscrit en
    Mai 2005
    Messages
    2 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : consultant développeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2005
    Messages : 2 878
    Points : 4 754
    Points
    4 754
    Par défaut
    Voici le code du double click adapté à ton cas.
    Cependant il te faut choisir si tu veux actionner le click ou le double-click mais certainement pas les 2 à la fois !

    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
     
    Private Sub TVEquipItas_DblClick()
     
        Dim sMsg As String
        Dim strSql As String, strFrmName As String
        Dim pos As Integer, i As Integer
        Dim oNode As Object, strNodeKey As String, lngNodekey As Long
     
        Set oNode = Me.TVEquipItas.SelectedItem
     
        i = oNode.Index
        strNodeKey = oNode.Key
        sMsg = "TV1_DblClick - index: " & i & "    Key: " & strNodeKey & "   Checked: " & oNode.Checked
        Debug.Print sMsg
        MsgBox sMsg
    '    If Not oNode.Parent Is Nothing Then
    '            ...
    '    Else
    '        ' C'est la ligne d'un lot, aucun traitement
    '    End If
     
    Exit_0:
        Exit Sub
     
    End Sub
    CDLT
    "Always look at the bright side of life." Monty Python.

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

Discussions similaires

  1. [Débutant] TreeView clic sur item
    Par Vorens dans le forum VB.NET
    Réponses: 12
    Dernier message: 12/04/2012, 15h54
  2. Suppression double-clic sur TreeView
    Par tolliv dans le forum C++Builder
    Réponses: 3
    Dernier message: 07/12/2006, 08h27
  3. Demande d'info sur treeview
    Par Anaxagore dans le forum IHM
    Réponses: 6
    Dernier message: 28/08/2003, 18h27
  4. capter l'evenement clic sur une cellule d'un string grid
    Par lasconic dans le forum Composants VCL
    Réponses: 3
    Dernier message: 25/06/2003, 10h51

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