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 :

masquer ou rendre visible plusieurs textbox


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Homme Profil pro
    technicien logistique
    Inscrit en
    Juillet 2016
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gers (Midi Pyrénées)

    Informations professionnelles :
    Activité : technicien logistique
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2016
    Messages : 19
    Points : 17
    Points
    17
    Par défaut masquer ou rendre visible plusieurs textbox
    Bonjour
    j'aimerais savoir si il est possible d'écrire plus simplement les lignes ci dessous; c'est à dire masquer ou rendre visible des textbox sans avoir a répéter la commande à chaque 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
    Label_id_airbus.Visible = True
        id_airbus.Visible = True
        bt_photos_chariots.Visible = True
        Label_type_materiel.Visible = True
        type_materiel.Visible = True
        Label_num_serie.Visible = False
        num_serie.Visible = False
        zone_de_stockage.Visible = False
        label_zone_de_stockage.Visible = False
        Option_sortie.Visible = False
        Option_entree.Visible = False
        label_destination.Visible = False
        destination.Visible = False
        avertissement.Visible = False
        dernier_mouv_enr.Visible = False
        mouv_possible.Visible = False
        bt_eff_obs.Visible = False
    peut-être les grouper sur deux lignes "true" et "false" ??

    Merci pour votre aide

    Alain

  2. #2
    Membre extrêmement actif
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 82
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Points : 12 422
    Points
    12 422
    Par défaut
    Bonjour
    Je suppose que :
    - ce ne sont pas toujours les mêmes, que tu veux montrer
    - ceux à cacher sont plus nombreux que ceux à montrer

    Je te suggère alors une méthode simple :
    - un array de tous les contrôles concernés
    - un array des seuls à montrer
    et ---->>

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Private Sub onrecommence(mescontroles, mesvisibles)
      For k = 0 To UBound(mescontroles)
        mescontroles(k).Visible = False
      Next
      For k = 0 To UBound(mesvisibles)
        mesvisibles(k).Visible = True
      Next
    End Sub
    procédure à appeler ainsi (exemple cachant textbox2 et montrant les deux autres:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    mescontroles = Array(TextBox1, CommandButton1, TextBox2)
     
     
     mesvisibles = Array(CommandButton1, TextBox1)
     onrecommence mescontroles, mesvisibles
    Je n'accepte pas de demande d' "amitié" individuelle. Tout développeur est pour moi un ami.
    Je n'ouvre AUCUN classeur tiers (avec ou sans macro ******). Ne m'en proposez donc pas .

    ****** : Non, non ... un classeur .xlsx ne "peut" par exemple et entre autres pas contenir un activex (de surcroît invisible) , "bien sûr" ...

    Il est illusoire de penser que l'on saurait exprimer valablement et précisément en un langage (rigide) de développement ce que l'on peine à exprimer dans le langage naturel, bien plus souple.

  3. #3
    Membre expert
    Profil pro
    Inscrit en
    Février 2007
    Messages
    2 267
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 2 267
    Points : 3 663
    Points
    3 663
    Par défaut
    Bonjour à tous,

    si ce sont leurs valeurs par défaut (tu fixes leur propriété .visible dans l'éditeur vbe) tu peux faire .unload au lieu du .hide., qu'ils les reprennent avant le .show

    Ou bien utiliser la propriété .Tag à ta disposition. Et tu t'en sers dans une boucle générale sur tous les objets concernés.
    eric

  4. #4
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 379
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 379
    Points : 12 075
    Points
    12 075
    Billets dans le blog
    8
    Par défaut re
    re
    Bonjour oui une boucle sur array de control semble etre la meilleur solution
    cependant on peu simplifier la procedure et la transformer (en bascule 3 posiition) visible/invisible/allvisiblecomme l'exemple de unparia mais dans une seule boucle

    exemple
    pour commencer je me sert non pas d'un array mais d'un string

    la sub bascule
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Private Sub visible_YES_NO(invisible)
    For Each ctrl In Me.Controls
    If invisible Like "*," & ctrl.Name & ",*" Then ctrl.Visible = False Else ctrl.Visible = True
    Next
    End Sub
    l'appel de la sub qui va basculer ceux qui sont dans le string en invisible et ceux qui n'y sont pas en visible
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Private Sub vvvv_Click()
    invisible = ",CommandButton1,TextBox1,TextBox2,CheckBox1,"
    visible_YES_NO invisible
    End Sub
    et la position 3 donc tous visible on appelle la sub en injectant un string vide tout simplement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub CommandButton3_Click()
    visible_YES_NO vbNullString
    End Sub
    petite remarque a la quelle il faut préter attention
    commencer et terminer toujours la chaine par une virgule car pour eviter le meprise du genre textbox2,textbox22 ou textbox2,aaatextbox2 la virgule est prise en compte dans le test like

    on a ainsi un effet de bascule visible/invisible en un et la possibilité de tout réafficher avec vbnullstring

    on pourrait meme ajouter une bascule(4) avec un simple argument en plus c'est le cumul des invisible avec la meme sub

    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

  5. #5
    Membre à l'essai
    Homme Profil pro
    technicien logistique
    Inscrit en
    Juillet 2016
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gers (Midi Pyrénées)

    Informations professionnelles :
    Activité : technicien logistique
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2016
    Messages : 19
    Points : 17
    Points
    17
    Par défaut
    Bonjour

    Je vais essayer la solution de Patricktoulon.

    Merci à tous .

    Bonne journée

    Alain

  6. #6
    Expert éminent
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Points : 6 871
    Points
    6 871
    Par défaut
    Bonjour,

    Ou encore, utiliser la propriété Tag des contrôles et y stocker l'état voulu :
    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
     
    Private Sub UserForm_Initialize()
     
        TextBox1.Tag = True
        TextBox2.Tag = False
        TextBox3.Tag = True
        TextBox4.Tag = False
     
    End Sub
     
    Private Sub CommandButton1_Click()
     
        Dim Ctrl As Control
     
        For Each Ctrl In Me.Controls
     
            If TypeName(Ctrl) = "TextBox" Then
     
                Ctrl.Visible = CBool(Ctrl.Tag)
                Ctrl.Tag = Not CBool(Ctrl.Tag) 'si invisible, alors visible la fois d'après
     
            End If
     
        Next Ctrl
     
    End Sub

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

Discussions similaires

  1. Réponses: 9
    Dernier message: 14/06/2015, 16h17
  2. [AC-2010] Rendre visible un textbox dans un etat selon condition
    Par dodo28 dans le forum IHM
    Réponses: 4
    Dernier message: 31/01/2013, 09h06
  3. [XL-2007] Rendre visible une textbox avec variable
    Par Fred246 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 21/12/2009, 09h37
  4. Masquer ou rendre visible ?
    Par BRUNO71 dans le forum VBA Access
    Réponses: 2
    Dernier message: 16/06/2008, 17h48
  5. Rendre visible / invisible plusieurs éléments en même temps
    Par Bluespike62 dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 23/01/2006, 17h43

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