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

IHM Discussion :

ComboBox multicolonnes dans un ruban [AC-2007]


Sujet :

IHM

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 46
    Points : 19
    Points
    19
    Par défaut ComboBox multicolonnes dans un ruban
    Bonjour,

    J'utilise Access 2007 et j'ai un petit souci mais je n'ai rien trouvé dans les forums qui puisse me donner une solution.

    Ma question est simple (la réponse aussi j'espère). J'ai créé un nouveau ruban dans lequel il y a différents contrôles et notamment un combobox qui pointe sur un champ NumClient d'une table TblClient. Vous vous doutez qu'un numéro du type 6789DPT101109 n'est pas très parlant. Je souhaiterais que cette liste affiche plusieurs colonnes de façons à faire apparaître également le nom du client (Ex 6789DPT101109 Albert Basque).
    Seulement, apparemment il ne semble pas possible dans un ruban qu'une combobox affiche plusieurs colonnes, en tous cas je n'ai pas trouvé la solution.
    Savez-vous comment peut-on contourner ce problème ou simplement le résoudre, à savoir afficher plusieurs colonnes dans une liste déroulante d'un ruban personnalisé?

    Merci d'avance
    Cdt
    Alain92110

  2. #2
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    Les zones de listes du ruban sont à colonne simple mais rien ne vous empêche de concatener les différents libellés.

  3. #3
    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,

    Peut-être en remplaçant le comboBox par un dropDown.
    Tous les deux se remplissent avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sub GetItemLabel(control As IRibbonControl, index As Integer, ByRef label)
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sub GetItemID(control As IRibbonControl, index As Integer, ByRef id)
    Sur changement de sélection :

    Avec le dropDown on récupère id, tandis qu'avec le comboBox on récupère label.

    Avec un dropDown, si tu alimentes id avec NumClient et label avec le nom du client, tu devrais obtenir ce que tu souhaites.

    A+

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 46
    Points : 19
    Points
    19
    Par défaut Combobox multicolonnes
    Bonjour,

    Merci pour vos conseils.

    En fait la solution de concaténer semble fonctionner. Cependant, elle génére une autre erreur.

    Je m'explique: Pour que cela fonctionne il faut modifier d'abord la requête ainsi dans

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub getNBNum(control As IRibbonControl, ByRef count)
        Set oRst = CurrentDb.OpenRecordset("SELECT NumClient, NomClient , PrenomClient FROM tblClient ORDER BY NumClient")
        'Récupère le nombre d'enregistrements
    With oRst
            .MoveLast
            count = .RecordCount
            .MoveFirst
        End With
    End Sub
    Ensuite, on peut concaténer dans :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Sub getNumLabel(control As IRibbonControl, index As Integer, ByRef label)
    On Error GoTo err
        With oRst
     
            label = .Fields("NumClient")
            label = label & "  " & .Fields("NomClient")
            label = label & "  " & .Fields("PrenomClient")
            .MoveNext
        End With
     
    Exit Sub
    err:
    MsgBox err.Description
    End Sub
    Ainsi la combobox affiche bien :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     NumClient & " " & NomClient & " " & PrenomClient
    Jusque là c'est parfait c'est ce que je voulais.

    Sauf que maintenant, ma variable est devenue
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     NumClient & " " & NomClient & " " & PrenomClient
    et quand je veux l'utiliser dans un call back pour un filtre dans un formulaire et ben ça ne marche pas.

    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
    'Callback for comboBox1 onChange
    'Récupère le contenu du contrôle comboBox dans la variable 'RechClient'
    Sub recup_var1(control As IRibbonControl, text As String)
    Dim RechClient As String
     
        RechClient = text
     
    On Error GoTo Err_lst_Rechercher_Client
     
        Dim stDocName As String
        Dim stLinkCriteria As String
     
        stDocName = "Fiche_Client_frm"
        DoCmd.OpenForm stDocName, , , stLinkCriteria
     
    Forms!Fiche_Client_frm.Filter = "[NumClient]=" & [RechClient]
    Forms!Fiche_Client_frm.FilterOn = True
     
    Exit_lst_Rechercher_Client:
        Exit Sub
     
    Err_lst_Rechercher_Client:
        MsgBox err.Description
        Resume Exit_lst_Rechercher_Client
     
    End Sub
    Mon problème maintenant est de pouvoir récupérer la "bonne" variable dans le callback car la variable RechClient est devenue égale à
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    NumClient & " " & NomClient & " " & PrenomClient
    alors qu'elle devrait contenir seulement NumClient pour pourvoir filtrer.

    Mon problème n'est donc pas encore totalement résolu.


    Merci pour votre aide.

    Cordialement
    Alain 92110

  5. #5
    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
    Bonsoir,

    NumClient se trouve avant le 1er espace.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    RechClient = Left(text, Instr(1, text, " ")-1)
    A+

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    46
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 46
    Points : 19
    Points
    19
    Par défaut Combobox Multicolonnes Résolu
    Merci pour votre aide.

    C'est ce qui s'appelle avoir le nez dans le guidon. Je n'ai absolument pas pensé à cette fonction.
    En tous cas, maintenant ça marche super.

    Avec mes remerciements
    Alain92110

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

Discussions similaires

  1. Problème d'Utilisation d'un combobox dans le Ruban
    Par broch002 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 04/02/2013, 18h44
  2. [Débutant] afficher une table d'une BDD MySql dans un combobox multicolonnes
    Par vbcasio dans le forum VB.NET
    Réponses: 4
    Dernier message: 24/06/2011, 11h32
  3. [Excel2007] Gérer un Combobox dans un ruban personnalisé
    Par SilkyRoad dans le forum Contribuez
    Réponses: 3
    Dernier message: 01/12/2007, 11h50
  4. Comment faire un ComboBox multicolonne lié à une table ?
    Par Khalid.bounouader dans le forum Accès aux données
    Réponses: 1
    Dernier message: 18/09/2006, 09h29
  5. [VS2005 VBNET] Combobox multicolonne
    Par PoZZyX dans le forum Visual Studio
    Réponses: 11
    Dernier message: 03/05/2006, 14h35

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