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 :

Userform qui disparaît automatiquement après X secondes mais dont on peut annuler la disparition [XL-2010]


Sujet :

Macros et VBA Excel

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    278
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 278
    Points : 132
    Points
    132
    Par défaut Userform qui disparaît automatiquement après X secondes mais dont on peut annuler la disparition
    Bonjour!

    L'intitulé est un peu long, je vais essayer d'être clair.
    J'ai une macro qui se lance automatiquement à l'ouverture d'un classeur. J'aimerai offrir la possibilité à l'utilisateur d'annuler ce lancement automatiquement.
    Pour ce faire, je pensais utiliser un userform qui disparaîtrait au bout de 10 secondes puis le traitement se lance sauf si l'utilisateur clique sur un bouton d'annulation situé sur le userform permettant d'annuler le lancement automatique.
    Pour faire disparaître automatiquement mon userform, j'utilise Application.Wait mais elle rend inopérant le bouton d'annulation.

    Des idées?

    D'avance merci.

  2. #2
    Expert confirmé Avatar de BENNASR
    Homme Profil pro
    Responsable comptable & financier
    Inscrit en
    Décembre 2013
    Messages
    2 914
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Responsable comptable & financier
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2013
    Messages : 2 914
    Points : 5 121
    Points
    5 121
    Par défaut
    Bonjour
    je sais pas si c'est ce que tu cherches mais je propose un message à l'ouverture de ton classeur demandant la confirmation de la commande si la réponse et OK si non il démarre pas la procédure
    si ça t'arrange :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Private Sub Workbook_Open()
    If MsgBox("Etes-vous certain de vouloir exécuter la commande !!?", vbYesNo, "Demande de confirmation") = vbYes Then
    '' TON CODE
    end if
    end sub
    BONNE CONTINUATION
    --------------------------------------------------------------*****----------------------------------------------------------------------------
    Bonne Continuation & Plein Succès
    Notre seul pouvoir véritable consiste à aider autrui avec modestie
    ______________________________________________________
    Pour dire merci, cliquer sur et quand la discussion est résolue, penser à cliquer sur le bouton

  3. #3
    Expert éminent
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 66
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Points : 7 149
    Points
    7 149
    Billets dans le blog
    7
    Par défaut
    Bonjour,

    Utiliser plutôt la méthode OnTime

    Code affecté au formulaire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Option Explicit
     
    Private Sub UserForm_activate()
     
    Application.OnTime EarliestTime:=Now + TimeValue("00:00:15"), Procedure:="laprocédure"
     
    End Sub
     
    Private Sub Btn_Annulation_Click()
    Unload Me
    End
    End Sub
    Dans un module standard

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Option Explicit
     
    Sub laprocédure()
    Unload Usf_Alerte
    MsgBox Prompt:="Coucou", Buttons:=vbOKOnly, Title:="Activation du traitement"
    End Sub

    Bien Cordialement.

    Marcel

    Dernier billet:
    Suppression des doublons d'un tableau structuré, gestion d'un array

    Pas de messagerie personnelle pour vos questions, s'il vous plaît. La réponse peut servir aux autres membres. Merci.


  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
    bonjour
    un petit exemple de msgbox temporaire perso avec un UserForm
    1. sans api settimer
    2. sans application.ontime
    3. sans application.wait


    lancer la sub dans le module
    Fichiers attachés Fichiers attachés
    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
    Expert éminent
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 66
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Points : 7 149
    Points
    7 149
    Billets dans le blog
    7
    Par défaut
    Patrick,

    Petite précision.
    La variable affectée au Timer se déclare en Single.

    D'autre part.
    Je viens de trouver sur la toile Internet un code qui retourne les codes de barres de commande.
    Il semblerait, sauf erreur, que la commande 2040, mentionnée dans ton code, soit celle correspondant au menu
    Outils\Partager le classeur
    Je n'en comprends pas l'usage.

    Bien Cordialement.

    Marcel

    Dernier billet:
    Suppression des doublons d'un tableau structuré, gestion d'un array

    Pas de messagerie personnelle pour vos questions, s'il vous plaît. La réponse peut servir aux autres membres. Merci.


  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    278
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 278
    Points : 132
    Points
    132
    Par défaut
    J'ai utilisé la méthode de MarcelG qui fonctionne parfaitement!
    Je n'ai pas testé les autres solutions.

    En tout cas, merci à tous pour vos réponses et bon après-midi.

  7. #7
    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
    c'est pour gérer l'évènement onupdate

    on change quelque chose dans le bar et cet évènement est déclenché
    c'est juste pour éviter un timer de quelque sorte que ce soit
    la variable single je sais pas je vais voir
    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

  8. #8
    Expert éminent
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 66
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Points : 7 149
    Points
    7 149
    Billets dans le blog
    7
    Par défaut
    Salut,

    Merci pour l'information.

    Tu peux consulter l'aide Microsoft à propos de la fonction Timer.

    Bien Cordialement.

    Marcel

    Dernier billet:
    Suppression des doublons d'un tableau structuré, gestion d'un array

    Pas de messagerie personnelle pour vos questions, s'il vous plaît. La réponse peut servir aux autres membres. Merci.


  9. #9
    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
    ca va timer je connais

    si tu veux une explication complète
    c'est simple
    en gros je map la commandbars comme on le fait dans une classe pour des controls ou autre
    sauf que tout est dans le UserForm (le module UserForm est une classe aussi)

    en gros j'intègre le pilotage de la commandbars dans le UserForm exactement comme dans une classe

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Private WithEvents Cmbrs As Commandbars

    a partir de la je peux gérer l'évènement OnUpdate da la commandbars

    et comme dans cet évènement je la met enabled true/false l'évènement se répète

    il ne reste plus a mettre une condition dans l'évènement pour l'arrêter avec timer +Delay par exemple

    et la bascule true/false répétitive n'est pas bloquante pour le reste car il n'est pas prioritaire

    j'ai une horloge avec ce principe si tu veux
    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

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

Discussions similaires

  1. Userform qui disparaît sur un PC mais pas un autre
    Par falsuss dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 14/06/2018, 23h39
  2. Userform se fermant automatiquement après X secondes
    Par hbc87 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 30/06/2010, 16h40
  3. Thread qui se termine aprés quelque secondes ?
    Par jackm dans le forum Concurrence et multi-thread
    Réponses: 9
    Dernier message: 21/03/2008, 09h31
  4. le PC s'éteint automatiquement après 10 secondes
    Par sidahmed dans le forum Windows XP
    Réponses: 4
    Dernier message: 09/12/2007, 00h16
  5. Redirection automatique apres quelques secondes
    Par theotaki dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 11/05/2007, 12h25

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