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

VBA Access Discussion :

Quel événement correspond au moment où le formulaire est prêt à être utilisé ?


Sujet :

VBA Access

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    681
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 681
    Points : 214
    Points
    214
    Par défaut Quel événement correspond au moment où le formulaire est prêt à être utilisé ?
    Bonjour,
    Access2000, XP
    Mon but : quand le formulaire est prêt à l'emploi, au lancement du programme, je souhaiterais afficher un message.

    Si possible, il ne faudrait pas que ce message réapparaisse lorsque par la suite le formulaire en question est réactivé.
    Je crois pouvoir réaliser cette deuxième condition en sautant l'affichage du message lors des ouvertures suivantes du formulaire.

    C'est sur la première condition que je butte. Je ne sais pas dans quel événement placer l'affichage du message. Mes essais avec sur ouverture, chargement, activation et current n'ont pas été concluants : le message s'affiche avant que le formulaire soit affiché.
    Sur got Focus : on ne voit pas le message même après l'affichage du form.

    Merci de l'aide
    Amitiés

  2. #2
    Expert éminent sénior
    Avatar de Domi2
    Homme Profil pro
    Gestionnaire
    Inscrit en
    Juin 2006
    Messages
    7 194
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : Suisse

    Informations professionnelles :
    Activité : Gestionnaire
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 194
    Points : 16 044
    Points
    16 044
    Par défaut
    Bonjour,

    C'est sur la première condition que je butte. Je ne sais pas dans quel événement placer l'affichage du message. Mes essais avec sur ouverture, chargement, activation et current n'ont pas été concluants : le message s'affiche avant que le formulaire soit affiché.
    Sur got Focus : on ne voit pas le message même après l'affichage du form.
    Je crois qu'il n'y a pas d'événement...

    De plus, selon l'aide, gotFocus du formulaire ne se produit que si celui-ci n'a pas de contrôle visible et activé. Et ça ne résoudrait pas le problème, j'avais fait des essais.

    La seule solution que j'ai trouvée, c'est de passer par une sub ou fonction, en exécutant les codes l'un après l'autre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Sub...
     
    DoCmd.Openform...
     
    MsgBox "Coucou"
     
    End Sub
    Et là, ton message est bien affiché devant la fenêtre...

    Bon, ça présente au moins l'avantage de pouvoir contrôler assez facilement si on est à la première ouverture du formulaire...

    Domi2

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    681
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 681
    Points : 214
    Points
    214
    Par défaut
    Merci de ta réponse, mais par quel événement sera déclanchée la sub que tu donnes ?

  4. #4
    Expert éminent sénior
    Avatar de Domi2
    Homme Profil pro
    Gestionnaire
    Inscrit en
    Juin 2006
    Messages
    7 194
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : Suisse

    Informations professionnelles :
    Activité : Gestionnaire
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 194
    Points : 16 044
    Points
    16 044
    Par défaut
    Re,

    Cela dépend... si c'est pour l'ouverture de l'application, je n'utilise pas les options de démarrage, mais une macro AutoExec, avec une seule action, l'exécution d'une fonction qui "initialise" toutes mes applications...

    J'exécute un certains nombre de sub ou fonction avant l'ouverture du 1er formulaire (en principe le menu général)...

    S'il s'agit d'un autre formulaire, tu peux mettre le code dans l'évènement sur clic d'un bouton, par exemple...

    Est-ce que cela répond à ta question ?

    Domi2

  5. #5
    Membre actif
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    681
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 681
    Points : 214
    Points
    214
    Par défaut
    Comme option de démarrage, c'est l'affichage du form en question, sur lequel je désirerais que s'affiche le msg.
    C'est donc le premier formulaire qui s'affiche.

    J'avais pensé mettre dans l'événement sur clic de tous les boutons actifs la sub contenant la commande d'affichage du message, mais c'est lourd et peu élégant !

    N'ayant pas d'autre solution, je vais m'y résoudre.
    Merci
    amitiés

  6. #6
    Expert éminent sénior
    Avatar de Domi2
    Homme Profil pro
    Gestionnaire
    Inscrit en
    Juin 2006
    Messages
    7 194
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : Suisse

    Informations professionnelles :
    Activité : Gestionnaire
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 194
    Points : 16 044
    Points
    16 044
    Par défaut
    Re,

    Alors utilise une macro AutoExec...

    Dans un module standard, tu crées une fonction (et non une sub, on ne peut pas les exécuter depuis une macro):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Function InitApplication()
     
    'Ici, tous les codes que tu veux avant l'ouverture de ton formulaire,
    'notamment ce que tu exécutes dans Form_Load ou dans Form_Open
     
    DoCmd.OpenForm "frmMenuGeneral", , , , , acNormal
     
    MsgBox "Bonjour"
     
    End Function
    Dans la macro, une seule ligne Action, ExécuterCode, et renseigner le champ Nom fonction avec InitApplication()

    Et évidemment, supprimer les infos des options de démarrages...

    Domi2

  7. #7
    Membre actif
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    681
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 681
    Points : 214
    Points
    214
    Par défaut
    J'ai essayé ta méthode, et bien entendu ça fonctionne correctement. Je vais l'utiliser
    Merci
    A+

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

Discussions similaires

  1. [AC-2010] Quel évènement pour déclencher un code dans un sous sous formulaire ?
    Par sardaucar dans le forum VBA Access
    Réponses: 6
    Dernier message: 29/10/2014, 09h20
  2. Réponses: 12
    Dernier message: 02/10/2014, 09h37
  3. quel événement utilisé pour lier un sous-formulaire
    Par MarLoZ dans le forum VBA Access
    Réponses: 1
    Dernier message: 05/09/2007, 13h51
  4. Quel SGBD correspond aux fichiers à extension .DAT
    Par jcpitaud dans le forum Autres SGBD
    Réponses: 4
    Dernier message: 12/04/2006, 20h11
  5. Quel évènement sur le redimensionnement ?
    Par Yoh dans le forum Agents de placement/Fenêtres
    Réponses: 2
    Dernier message: 01/07/2004, 13h05

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