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 :

Je voudrais cacher un bouton


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 24
    Par défaut Je voudrais cacher un bouton
    Bonjour,

    Dans une barre de menu que j'ai créé, je voudrais cacher un bouton
    qui serai en .Controls(13) qui se nommerai .Controls("Imprimer") .
    Ce bouton ne serai vue que par les différentes feuilles à imprimer
    qui sont au nombre de 6 (Devi1page, Devis2pages, Facture1page, ect...)
    exemple: si feuille active "Devis1page", bouton visible, j'imprime sinon bouton caché, si feuille active "Facture1page" bouton visible, j'imprime sinon bouton
    caché...
    J'ai déjà un bouton de cacher mais je ne sai pas adapter le code à d'autre boutons.
    voici le code qu'a créé Michdenis pour cacher un bouton en .Controls(2).Controls"Menu"

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Private Sub Workbook_SheetActivate(ByVal Sh As Object)
    On Error Resume Next
    With Application.CommandBars("Denis").Controls(2).Controls("Menu")
        If UCase(Sh.Name) = "MENU" Then
            '.Enabled = True
            .Visible = False
        Else
            '.Enabled = False
            .Visible = True
        End If
    End With
    End Sub
    si quelqu'un pouvait m'aider, ce serai avec grand plaisir.
    Peponne31

  2. #2
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Private Sub Workbook_SheetActivate(ByVal Sh As Object)
    On Error Resume Next
    With Application.CommandBars("XXXX").Controls(13).Controls("Imprimer") 'A la place de XXXX mettre le nom de ta CommandBar
        If UCase(Right(Sh.Name, 4)) = "PAGE" Then
            .Visible = True
        Else
            .Visible = False
        End If
    End With
    End Sub

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 24
    Par défaut Chacher bouton dans barre de menu
    Bonjour mercatoq

    Merci pour ton aide, le code que tu ma envoyé ne fonctionne pas
    deplus il faudrai que ce code soit incorporé au 1er code,
    de manière à pouvoir cacher 1 ou plusieurs boutons dans la mème barre.
    Merci encore
    Peponne31

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 24
    Par défaut Cacher bouton dans barre de menu

    J'ai résolu en partie mon problème, voici ce que j'ai fais:

    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 Workbook_SheetActivate(ByVal Sh As Object)
       On Error Resume Next
       With Application.CommandBars("Denis").Controls(1).Controls("Imprimer")
          If UCase(Sh.Name) = "DEVIS1PAGE" Then
          .Visible = True
          ElseIf UCase(Sh.Name) = "DEVIS2PAGES" Then
          ElseIf UCase(Sh.Name) = "DEVIS" Then
          ElseIf UCase(Sh.Name) = "DEMANDEDEVISFOURNISSEURS" Then
             .Visible = True
          Else
             .Visible = False
          End If
       End With
    End Sub
    mais dans ma barre de menu, j'ai plusieurs boutons et je ne sais pas
    adapter la ligne:
    With Application.CommandBars("Denis").Controls(1).Controls("Imprimer") pour
    prendre en compte d'autres boutons dans la mème ligne,
    Exemple, en .Controls(3) j'ai Facture, en .Control(4) j'ai courrier...
    Comment ajouter 1 ou plusieurs Controls dans la ligne que je veux adapter !!!

    Merci pour tout aide.
    Peponne31

  5. #5
    Expert éminent Avatar de mercatog
    Homme Profil pro
    Inscrit en
    Juillet 2008
    Messages
    9 435
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations forums :
    Inscription : Juillet 2008
    Messages : 9 435
    Par défaut
    Une suggestion
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    With Application.CommandBars("Denis")
        If InStr(UCase(Sh.Name), "DEVIS") > 0 Then
            .Controls(1).Controls("Imprimer").Visible = True
            .Controls(3).Controls("Facture").Visible = True
            .Controls(4).Controls("Courier").Visible = True
        Else
            .Controls(1).Controls("Imprimer").Visible = False
            .Controls(3).Controls("Facture").Visible = False
            .Controls(4).Controls("Courier").Visible = False
        End If
    End With
    PS. n'oublie pas les balises code (#) sur le forum pour une meilleure lisibilité

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 24
    Par défaut
    Re,

    Pour .Controls(1), ça fonctionne mais Facture et Courrier ne doivent pas ètre cachés, se sont des boutons au mème titre que DEVIS lorsque je clique sur Facture, j'ai en sous menu: Facture1page et facture2pages, si j'ouvre une
    de ses 2 pages le bouton imprimer doit ètre visible.
    Je pensai qu'il était possible de mètre dans la mème procédure le nom des boutons concernés et ensuite définir une action pour chaque bouton.
    Ex. si je clique sur le bouton Tools qui est en .Control(7),en sous menu j'ai: Paramètres Société, Débug Programme et Fermer Débug, ce que je voudrai c'est que Fermer Débug n'apparraisse que si j'ai cliquer sur Débug Programme pour pouvoir le refermer.
    Merci encore et bonne soirée à tous.
    Peponne31

  7. #7
    Rédacteur/Modérateur


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 125
    Billets dans le blog
    131
    Par défaut
    Bonjour

    C'est, comme souvent, un problème de conception avant d'être un problème de code.

    A ce stade, il me parait utile que tu découpes d'abord ce que tu souhaites faire, que tu regroupes les actions identiques en petite procédures faciles à gérer, puis que tu les articules dans ton code, en faisant un minimum d'effort pour comprendre les codes qui te sont donnés en réponse à tes messages.

    Je t'invite donc, avant de continuer le jeu un peu stérile des questions/réponses, à schématiser sur papier le fonctionnement souhaité de ton application, puis de venir nous retrouver pour les points qui posent problème.
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

Discussions similaires

  1. Réponses: 18
    Dernier message: 08/03/2024, 14h44
  2. [VBA-E]Cacher le bouton fermer
    Par boux2 dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 24/07/2006, 18h31
  3. [ASP3] Cacher un bouton
    Par beegees dans le forum ASP
    Réponses: 10
    Dernier message: 20/06/2006, 18h57
  4. [VBA ACCESS]cacher des boutons
    Par kikilevrai dans le forum Access
    Réponses: 3
    Dernier message: 20/06/2006, 17h13
  5. Comment cacher des boutons de la barre de titre ?
    Par programaniac dans le forum Composants VCL
    Réponses: 7
    Dernier message: 16/11/2005, 10h04

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