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 :

Utilisation d'événements avec l'objet Application


Sujet :

Macros et VBA Excel

Vue hybride

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

    Informations forums :
    Inscription : Janvier 2008
    Messages : 8
    Par défaut Utilisation d'événements avec l'objet Application
    Bonjour,

    Je programme en VBA-Excel 2003
    Je veux créer 2 procédures d'événements qui font une action lorsque je change de classeur et lorsque je reviens dans le classeur.

    J'ai créé une module de classe nommé "Classe1" et un module standard.
    Dans le module de classe j'ai le code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Public WithEvents App As Application
     
    Private Sub Workbook_Activate()
      MsgBox "Classeur ACTIVÉ"
    End Sub
     
    Private Sub Workbook_Deactivate()
      MsgBox "Classeur DÉSACTIVÉ"
    End Sub
    Dans le module standard j'ai le code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Dim X As New Classe1
     
    Sub InitializeApp()
      Set X.App = Application
    End Sub
    J'exécute la procédure "InitializeApp" puis je change de classeur et reviens à ce classeur mais rien ne se passe.

    Merci pour votre aide.

  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
    Essaies ceci (à mettre dans le module Thisworkbook)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Private WithEvents App As Application
     
    Private Sub InitializeApp()
    Set App = Application
    End Sub
     
    Private Sub App_WorkbookActivate(ByVal Wb As Workbook)
    MsgBox Wb.Name & " Activé"
    End Sub
     
    Private Sub App_WorkbookDeactivate(ByVal Wb As Workbook)
    MsgBox Wb.Name & " Desactivé"
    End Sub

  3. #3
    pgz
    pgz est déconnecté
    Expert confirmé Avatar de pgz
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Août 2005
    Messages
    3 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 72
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Office VBA
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Par défaut
    Bonsoir.

    Je ne comprends pas bien : tu parles d'évènement de l'aplication (cela existe) et finalement tu montres 2 évènements du classeur.
    Pour ces 2 évènement tu n'as pas besoin de faire de déclaration, ils sont directement disponibles dans le module du classeur (ThisWorkbook).

    Ceci dit, ce que t'as donné Mercatog devrait parfaitement convenir.

    Cordialement,

    PGZ

Discussions similaires

  1. Utilisation du borderLayout avec un objet dans un JscrollPane
    Par tupac25 dans le forum Agents de placement/Fenêtres
    Réponses: 2
    Dernier message: 01/06/2010, 11h51
  2. Réponses: 1
    Dernier message: 07/05/2006, 00h26
  3. Réponses: 1
    Dernier message: 05/05/2006, 22h34
  4. Réponses: 1
    Dernier message: 21/10/2005, 13h08

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