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 barre de Titre [XL-2010]


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
    Mai 2012
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2012
    Messages : 44
    Par défaut Masquer barre de Titre
    Bonjour,
    Je souhaiterai finaliser mon programme en VBA en masquant la barre de titre de EXCEL. Celle ou c'est écrit : "nom du fichier" - Microsoft Excel avec les trois boutons réduire, agrandir et fermer.
    Y a-t-il un code simple pour cela ?

    Merci de votre retour,

  2. #2
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 208
    Par défaut
    Bonjour,

    Mets le code suivant dans un module standard (en tête). Ça fonctionne mais ne me demande pas de t'expliquer pourquoi. Il faut exécuter la macro "Title_Hide" pour masquer la ligne de titre (et aussi le ruban) et la macro "Title_Show" pour rétablir les lieux...

    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
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" _
      (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
     
    Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" _
      (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
     
    Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" _
      (ByVal hwnd As Long, ByVal nIndex As Long) As Long
     
    Private Const GWL_STYLE = (-16)
    Private Const WS_CAPTION = &HC00000
    Private Const WS_MAXIMIZEBOX = &H10000
    Private Const WS_MINIMIZEBOX = &H20000
    Private Const WS_SYSMENU = &H80000
     
    Private Declare Function SetWindowPos Lib "user32" _
      (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, _
      ByVal x As Long, ByVal y As Long, ByVal cx As Long, _
      ByVal cy As Long, ByVal wFlags As Long) As Long
     
    Private Enum ESetWindowPosStyles
      SWP_SHOWWINDOW = &H40
      SWP_HIDEWINDOW = &H80
      SWP_FRAMECHANGED = &H20
      SWP_NOACTIVATE = &H10
      SWP_NOCOPYBITS = &H100
      SWP_NOMOVE = &H2
      SWP_NOOWNERZORDER = &H200
      SWP_NOREDRAW = &H8
      SWP_NOREPOSITION = SWP_NOOWNERZORDER
      SWP_NOSIZE = &H1
      SWP_NOZORDER = &H4
      SWP_DRAWFRAME = SWP_FRAMECHANGED
      HWND_NOTOPMOST = -2
    End Enum
     
    Private Declare Function GetWindowRect Lib "user32" _
      (ByVal hwnd As Long, lpRect As RECT) As Long
     
    Private Type RECT
      Left As Long
      Top As Long
      Right As Long
      Bottom As Long
    End Type
     
    Sub Title_Show()
      ShowTitleBar True
    End Sub
     
    Sub Title_Hide()
      ShowTitleBar False
    End Sub
     
    Sub ShowTitleBar(bShow As Boolean)
      Dim lStyle As Long
      Dim tRect As RECT
      Dim xlHnd As Long
     
      xlHnd = Application.hwnd
     
      '// Get the window's position:
      GetWindowRect xlHnd, tRect
     
      '// Show the Title bar ?
      If Not bShow Then
        lStyle = GetWindowLong(xlHnd, GWL_STYLE)
        lStyle = lStyle And Not WS_SYSMENU
        lStyle = lStyle And Not WS_MAXIMIZEBOX
        lStyle = lStyle And Not WS_MINIMIZEBOX
        lStyle = lStyle And Not WS_CAPTION
      Else
        lStyle = GetWindowLong(xlHnd, GWL_STYLE)
        lStyle = lStyle Or WS_SYSMENU
        lStyle = lStyle Or WS_MAXIMIZEBOX
        lStyle = lStyle Or WS_MINIMIZEBOX
        lStyle = lStyle Or WS_CAPTION
      End If
     
      SetWindowLong xlHnd, GWL_STYLE, lStyle
     
      Application.DisplayFullScreen = Not bShow
     
      '// Ensure the style is set and makes the xlwindow the
      '// same size, regardless of the title bar.
      SetWindowPos xlHnd, 0, tRect.Left, tRect.Top, tRect.Right - tRect.Left, _
        tRect.Bottom - tRect.Top, SWP_NOREPOSITION Or SWP_NOZORDER Or SWP_FRAMECHANGED
    End Sub

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Mai 2012
    Messages
    44
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2012
    Messages : 44
    Par défaut
    Super merci,
    ca fonctionne dans un Excel Vierge, je vais maintenant l'adapter à mon classeur !
    et surtout essayer de comprendre le fonctionnement

    Dommage qu'en appuyant sur la touche "échap" cela supprime l'effet

  4. #4
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Septembre 2011
    Messages
    8 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Septembre 2011
    Messages : 8 208
    Par défaut
    Pour neutraliser la touche échap :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.OnKey "{ESC}", ""
    Pour la réactiver :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.OnKey "{ESC}"

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

Discussions similaires

  1. [XL-2010] Masquer barre de titre application
    Par 2lester dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 20/01/2013, 15h16
  2. [AC-2003] Masquer barre de titre fenetre mère
    Par vlksoft dans le forum IHM
    Réponses: 0
    Dernier message: 21/09/2009, 16h57
  3. [XL-2003] masquer la barre de titre
    Par chuspyto dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 10/08/2009, 14h57
  4. Jtoolbar : masquer la barre de titre
    Par danyboy85 dans le forum AWT/Swing
    Réponses: 3
    Dernier message: 06/09/2007, 08h41
  5. [VB6] masquer la barre de titre d'une form
    Par tiboleo dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 09/12/2002, 17h54

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