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

Windows Discussion :

Boite de dialogue non modale


Sujet :

Windows

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    214
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 214
    Points : 99
    Points
    99
    Par défaut Boite de dialogue non modale
    Bonjour,
    Je viens de lire dans un de vos tutoriels que lorsqu'on sortait sur IDCANCEL de l'exécution d'un dialogue non modal, sa fenêtre n'était jamais détruite elle était seulement rendue invisible. De ce fait la boite non modale était lancée dans le programme qui l'appelle par la séquence:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    if(Hdlgnonmodal) ShowWindow(Hdlgnonmodal,SW_SHOWNORMAL);
    else Hdlgnonmodal = CreateDialog(n0instance, MAKEINTRESOURCE(Diagnonmodal), winmainkey, (DLGPROC)AnalyseDiagnonmodal);
    et sur la détection de l'IDCANCEL dans l'exécution de la fenêtre non modale on sortait par un simple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    EndDialog(Diagnonmodal, 0);
    Or, il se trouve qu'avant de lire vos tutoriels j'avais déjà écrit deux ou trois programmes qui utilisaient des boites de dialogue non modales, je m'étais rendu compte que le HWND de la boite non modale n'était jamais détruit, aussi j'avais résolu ce problème en forçant la destruction de la boite de dialogue sur le IDCANCEL, c'est à dire que derrière le IDCANCEL, j'ai la séquence:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    EndDialog(Diagnonmodal, 0);
    DestroyWindow( Diagnonmodal );
    et jusqu'à présent ça marche très bien, ma boite non modale est détruite et dans le programme qui l'appelle je ne fais que la recréer à chaque appel.
    Question: y a-t-il une raison particulière que je n'aurais pas vue, pour laquelle il serait préférable que je revienne à une programmation plus conforme à vos tutoriels?
    Merci

  2. #2
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    Bonjour. Je ne sais pas de quel tutoriel s'agit-il mais EndDialog ne détruit pas une boîte de dialogue non modale. Pour détruire une boîte de dialogue non modale, c'est DestroyWindow qu'il faut appeler et cet appel suffit. Pas besoin d'EndDialog. En clair :

    - Modale : DialogBox / EndDialog.
    - Non modale : CreateDialog / DestroyWindow.

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    214
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 214
    Points : 99
    Points
    99
    Par défaut Suite
    Merci, mais si tu relis mon message, je n’ai pas dit que EndDialog détruisait la boîte de dialogue, au contraire je dis que dans le tutoriel il est écrit que lorsqu’on ferme une boîte de dialogue non modale celle-ci est simplement rendue invisible et que donc si on doit la relancer plusieurs fois, il faut à partir de la deuxième fois tout simplement la rendre visible.
    Sommaire du tutoriel :
    http://chgi.developpez.com/windows/
    dans le sommaire, rubrique "Divers", cliquer sur le lien :
    Les boîtes de dialogues non modales
    tu trouveras le commentaire suivant :
    La boîte de dialogue sera créée avec la fonction CreateDialog. Il faut savoir qu'une boîte de dialogue de ce type quand elle est fermée avec la croix, en réalité elle est rendue invisible. Donc si on veut la réafficher une seconde fois, il suffira de la rendre visible.
    puis le code complet de l’exemple suit.

    Pour ce qui me concerne, j’avais effectivement remarqué que le DestroyWindow était suffisant, cependant ne sachant pas trop ce qui se passait dans Windows j’avais préféré laisser le EndDialog avant pour rester cohérent avec la gestion des dialogues de Windows.
    Toutefois, ceci ne répond pas à ma question, prenons par exemple le cas de Word ou d’Excel, quand on clique sur Edition>Rechercher on obtient une boîte non modale qui reste sur l’écran tant qu’on n’a pas cliqué sur la croix ou sur le bouton Annul. Ma question est quand je clique sur la croix ou sur Annul : qu’est-ce qui se passe derrière ? Est-ce que c’est cohérent avec le tutoriel c'est-à-dire qu’elle est simplement rendue invisible (EndDialog seulement) ou est-ce qu’elle est détruite (rajout de DestroyWindow), car je suppose que dans Word ou Excel le problème est résolu de la manière la plus normative. Et mon souci est de gérer ce même problème correctement, or j’ai un petit doute sur la cohérence de l’utilisation d’un DestroyWindow dans les dialogues car jusqu’à que je m’aperçoive que ça marchait quand même, DestroyWindow était à mon sens réservé aux fenêtres ordinaires.

  4. #4
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    La boîte de dialogue sera créée avec la fonction CreateDialog. Il faut savoir qu'une boîte de dialogue de ce type quand elle est fermée avec la croix, en réalité elle est rendue invisible. Donc si on veut la réafficher une seconde fois, il suffira de la rendre visible.
    Très correct.

    prenons par exemple le cas de Word ou d’Excel, quand on clique sur Edition>Rechercher on obtient une boîte non modale qui reste sur l’écran tant qu’on n’a pas cliqué sur la croix ou sur le bouton Annul. Ma question est quand je clique sur la croix ou sur Annul : qu’est-ce qui se passe derrière ?
    La boîte de dialogue est rendue invisible, mais pas détruite. Tout ce passe très probablement comme ceci, car c'est généralement ce qui se fait :

    - La boîte de dialogue est créée (CreateDialog) au moment de sa première utilisation.
    - Chaque fois que l'utilisateur la ferme, elle est rendue invisible.
    - Pour la réafficher, il suffit de la rendre visible.
    - Quand l'application (Word ou Excel) doit se terminer, elle est détruite (DestroyWindow).

    DestroyWindow était à mon sens réservé aux fenêtres ordinaires.
    Une boîte de dialogue est une fenêtre ordinaire. Seulement, quand elle est modale, il faut appeler EndDialog qui se chargera de détruire la fenêtre (DestroyWindow) et de régler la valeur de retour de DialogBox à la valeur spécifiée (le deuxième argument de EndDialog). DestroyWindow suffit pour les boîtes non modales car CreateDialog n'est pas blocant.

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    214
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 214
    Points : 99
    Points
    99
    Par défaut Conclusion
    Merci pour ta réponse. Donc si j'ai bien compris, pour résumer, et pour ce qui concerne les boîtes de dialogue non modale, c'est plus correct et plus cohérent avec ce qui se fait habituellement de terminer par un EndDialog (donc de la rendre seulement invisible). Mais, il n'y a pas d'inconvénient non plus (sauf au niveau cohérence) à remplacer le EndDialog par un DestroyWindow si on préfère la détruire après chaque utilisation.

  6. #6
    Expert éminent
    Avatar de Melem
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2006
    Messages
    3 656
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Janvier 2006
    Messages : 3 656
    Points : 8 389
    Points
    8 389
    Par défaut
    Tu as tout compris.

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

Discussions similaires

  1. Réponses: 11
    Dernier message: 06/05/2008, 17h53
  2. Boite de dialogue non modale
    Par Orc_Fayeh dans le forum MFC
    Réponses: 4
    Dernier message: 19/02/2007, 22h25
  3. Afficher/Cacher Boite de dialogue non modale
    Par coco21 dans le forum MFC
    Réponses: 5
    Dernier message: 06/01/2007, 10h08
  4. Boite de dialogue non modale
    Par cjacquel dans le forum MFC
    Réponses: 1
    Dernier message: 25/12/2006, 21h46
  5. dimension boite de dialogue non modale
    Par afan dans le forum MFC
    Réponses: 25
    Dernier message: 21/10/2004, 13h35

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