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

Macros et VBA Excel Discussion :

Ajout automatique de contrôle dans un UserForm


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2013
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2013
    Messages : 11
    Par défaut Ajout automatique de contrôle dans un UserForm
    Bonjour le Forum,

    Je me dirige à nouveau vers vous pour un problème que je n'ai pas pu régler malgré les différents sujets discutés dans le forum.

    Je vous expose le problème : dans un formulaire que je crée, l'utilisateur doit pouvoir ajouter à une table des informations qu'il sélectionne via un menu déroulant.

    J'imaginais que la table se forme via un UserForm et donc, dès que l'utilisateur a fait son choix, il clique sur un bouton "Ajouter cette information" et un label supplémentaire s'ajoute aux labels précédemment créés. L'utilisateur doit pouvoir ajouter autant d'informations qu'il souhaite. J'avais donc imaginé un code du genre :

    - Si label 1 (première information choisie) n'existe pas, alors créer label 1 (pour le positionnement du label et autres propriétés, pas de problèmes)

    - Si label 1 existe, alors créer label 1 + 1 (label2) en dessous et ainsi de suite.

    Pour vérifier l'existence des labels j'utilise label.caption = "".

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub CommandButton4_Click()
    UserForm11.Show
    End Sub
    Dans l'UserForm11 :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Private Sub UserForm_Initialize()
    Dim MyLb As Control
    For I = 1 To 100
        Set MyLb = Me.Controls.Add("Forms.Label.1", "MyLb" & I)
        MyLb(I).Caption = "salut"
            If MyLb(I).Caption <> "" Then
                 Set MyLb= Me.Controls.Add("Forms.Label.1", "MyLb" & I + 1)
            End If
    Exit For
    Next i
    End Sub
    Autre petit problème : s'il y a un grand nombre d'informations ajoutées, la liste des informations sera certainement plus grande que l'UserForm. Comment peut-on ajouter un scroll bar dans un UserForm (je connais bien sûr la propriété "ScrollsBar" mais ça ne fonctionne spécialement?!?)

    Merci à vous!

    Guilty

  2. #2
    Membre expérimenté Avatar de Denis la Malice
    Homme Profil pro
    FabManager
    Inscrit en
    Février 2013
    Messages
    133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 66
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : FabManager
    Secteur : Services de proximité

    Informations forums :
    Inscription : Février 2013
    Messages : 133
    Par défaut Ascenseur dans un formulaire
    Bonjour,
    l'ascenseur dans le formulaire n'est à mon avis pas la bonne solution.

    Utilise plutôt une ListBox ou une ComboBox pour ajouter tes informations. Ces objets gèrent les ascenseurs (SrollBar).

  3. #3
    Membre habitué
    Homme Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2013
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2013
    Messages : 11
    Par défaut
    Merci pour votre réponse.

    Dans l'exemple donné ci-dessus, je ne parle que d'un label par ligne (ou par information) mais en réalité, il y en aura 4. Je ne pense pas que ce soit faisable avec une listbox (?).

    Il s'agit de créer en fait l'objet de l'UserForm avec implémentation via VBA. Pas toujours facile !

  4. #4
    Membre expérimenté Avatar de Denis la Malice
    Homme Profil pro
    FabManager
    Inscrit en
    Février 2013
    Messages
    133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 66
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : FabManager
    Secteur : Services de proximité

    Informations forums :
    Inscription : Février 2013
    Messages : 133
    Par défaut
    Les ListBox gèrent le multi-colonne. Il faut utiliser les propriétés :
    • ColumnCount (nombre de colonnes, par exemple 4)
    • BoundColumn (n° de la colonne pour la valeur renvoyée par défaut)
    • ColumnWidth (Largeur des colonnes, par exemple "100 pt;100 pt;150 pt;50 pt")


    Ton menu déroulant, est-ce une liste où tu voudrais que l'utilisateur choisisse 1 ou plusieurs éléments dans cette liste et qu'au final tu obtiennes l'ensemble des choix de l'utilisateur ?

    Si c'est ça, tu peux utiliser le même objet (ListBox par exemple) avec l'option de multi-sélection. Par exemple utilise :
    • MultiSelect = fmMultiSelectMulti
    • ListStyle=fmListStyleOption


    A la validation du formulaire, parcours les éléments de ta liste en testant la propriété "selected".

    Mais j'ai peut-être mal compris ton besoin.

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

Discussions similaires

  1. Intercepter un click sur un Contrôle dans une UserForm
    Par RedColibri dans le forum VBA Word
    Réponses: 2
    Dernier message: 11/07/2008, 12h35
  2. Réponses: 6
    Dernier message: 14/06/2008, 18h10
  3. Ajout automatique d'enregistrement dans une table.
    Par bestofbasile dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 17/01/2008, 15h01
  4. ajout dynamique de contrôle dans un formulaire
    Par celiaaa dans le forum IHM
    Réponses: 2
    Dernier message: 26/02/2007, 20h23
  5. Réponses: 2
    Dernier message: 28/03/2006, 12h45

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