MFC - Principes de base de Windows

Dans ce chapitre, nous couvrirons les principes de base de Windows. Pour créer un programme, également appelé une application, vous dérivez une classe de CWinApp du MFC.CWinApp signifie Class for a Windows Application.

Examinons un exemple simple en créant un nouveau projet Win32.

Step 1 - Ouvrez Visual studio et cliquez sur l'option de menu Fichier → Nouveau → Projet.

Step 2 - Vous pouvez maintenant voir la boîte de dialogue Nouveau projet.

Step 3 - Dans le volet gauche, sélectionnez Modèles → Visual C ++ → Win32.

Step 4 - Dans le volet central, sélectionnez Projet Win32.

Step 5- Entrez le nom du projet «MFCWindowDemo» dans le champ Nom et cliquez sur OK pour continuer. Vous verrez la boîte de dialogue suivante.

Step 6 - Cliquez sur Suivant.

Step 7 - Sélectionnez les options comme indiqué dans la boîte de dialogue ci-dessus et cliquez sur Terminer.

Step 8 - Un projet vide est créé.

Step 9 - Pour en faire un projet MFC, cliquez avec le bouton droit sur le projet et sélectionnez Propriétés.

Step 10 - Dans la section de gauche, cliquez sur Propriétés de configuration → Général.

Step 11 - Sélectionnez l'option Utiliser MFC dans la DLL partagée dans la section Paramètres par défaut du projet et cliquez sur OK.

Step 12 - Ajoutez un nouveau fichier source.

Step 13 - Faites un clic droit sur votre projet et sélectionnez Ajouter → Nouvel élément ...

Step 14 - Dans la section Modèles, cliquez sur Fichier C ++ (.cpp).

Step 15 - Définissez le nom comme exemple et cliquez sur Ajouter.

Création de fenêtre

Toute application comporte deux sections principales -

  • Class
  • Cadre ou fenêtre

Créons une fenêtre en suivant les étapes suivantes -

Step 1 - Pour créer une application, nous devons dériver une classe de CWinApp du MFC.

#include
class CExample : public CWinApp {
   BOOL InitInstance() {
      return TRUE;
   }
};

Step 2 - Nous avons également besoin d'un cadre / fenêtre pour afficher le contenu de notre application.

Step 3 - Pour cela, nous devons ajouter une autre classe et la dériver des MFC CFrameWnd classe et implémentez son constructeur et appelez la méthode Create (), qui créera un cadre / une fenêtre comme indiqué dans le code suivant.

class CMyFrame : public CFrameWnd {
   public:
      CMyFrame() {
         Create(NULL, _T("MFC Application Tutorial"));
      }
};

Step 4 - Comme vous pouvez le voir, la méthode Create () a besoin de deux paramètres, le nom de la classe, qui doit être passé comme NULL, et le nom de la fenêtre, qui est la chaîne qui sera affichée sur la barre de titre.

Fenêtre principale

Après avoir créé une fenêtre, pour permettre à l'application de l'utiliser, vous pouvez utiliser un pointeur pour afficher la classe utilisée pour créer la fenêtre. Dans ce cas, le pointeur serait CFrameWnd. Pour utiliser la fenêtre frame, affectez son pointeur à la variable membre CWinThread :: m_pMainWnd. Cela se fait dans l'implémentation InitInstance () de votre application.

Step 1 - Voici l'implémentation d'InitInstance () dans la classe CExample.

class CExample : public CWinApp {
   BOOL InitInstance() {
      CMyFrame *Frame = new CMyFrame();  m_pMainWnd = Frame;
      
      Frame->ShowWindow(SW_NORMAL);
      Frame->UpdateWindow();
      
      return TRUE;
   }
};

Step 2 - Voici l'implémentation complète du fichier Example.cpp.

#include <afxwin.h>

class CMyFrame : public CFrameWnd {
   public:
      CMyFrame() {
         Create(NULL, _T("MFC Application Tutorial"));
      }
};

class CExample : public CWinApp {
   BOOL InitInstance() {
      CMyFrame *Frame = new CMyFrame();
      m_pMainWnd = Frame;
      
      Frame->ShowWindow(SW_NORMAL);
      Frame->UpdateWindow();
      
      return TRUE;
   }
};

CExample theApp;

Step 3 - Lorsque nous exécutons l'application ci-dessus, la fenêtre suivante est créée.

Styles Windows

Les styles Windows sont des caractéristiques qui contrôlent des fonctionnalités telles que l'apparence de la fenêtre, les bordures, l'état réduit ou agrandi, ou d'autres états de redimensionnement, etc.

Sr.No. Style et description
1

WS_BORDER

Crée une fenêtre avec une bordure.

2

WS_CAPTION

Crée une fenêtre qui a une barre de titre (implique le style WS_BORDER). Ne peut pas être utilisé avec le style WS_DLGFRAME.

3

WS_CHILD

Crée une fenêtre enfant. Ne peut pas être utilisé avec le style WS_POPUP.

4

WS_CHILDWINDOW

Identique au style WS_CHILD.

5

WS_CLIPCHILDREN

Exclut la zone occupée par les fenêtres enfants lorsque vous dessinez dans la fenêtre parent. Utilisé lorsque vous créez la fenêtre parent.

6

WS_CLIPSIBLINGS

Clips les fenêtres enfants les unes par rapport aux autres; autrement dit, lorsqu'une fenêtre enfant particulière reçoit un message de peinture, le style WS_CLIPSIBLINGS coupe toutes les autres fenêtres enfants superposées hors de la région de la fenêtre enfant à mettre à jour. (Si WS_CLIPSIBLINGS n'est pas donné et que les fenêtres enfants se chevauchent, lorsque vous dessinez dans la zone cliente d'une fenêtre enfant, il est possible de dessiner dans la zone cliente d'une fenêtre enfant voisine.) A utiliser uniquement avec le style WS_CHILD.

sept

WS_DISABLED

Crée une fenêtre initialement désactivée.

8

WS_DLGFRAME

Crée une fenêtre avec une double bordure mais sans titre.

9

WS_GROUP

Spécifie le premier contrôle d'un groupe de contrôles dans lequel l'utilisateur peut passer d'un contrôle au suivant à l'aide des touches fléchées. Tous les contrôles définis avec le style WS_GROUP FALSE après le premier contrôle appartiennent au même groupe. Le contrôle suivant avec le style WS_GROUP démarre le groupe suivant (c'est-à-dire qu'un groupe se termine là où le suivant commence).

dix

WS_HSCROLL

Crée une fenêtre avec une barre de défilement horizontale.

11

WS_ICONIC

Crée une fenêtre initialement réduite. Identique au style WS_MINIMIZE.

12

WS_MAXIMIZE

Crée une fenêtre de taille maximale.

13

WS_MAXIMIZEBOX

Crée une fenêtre avec un bouton Agrandir.

14

WS_MINIMIZE

Crée une fenêtre initialement réduite. À utiliser uniquement avec le style WS_OVERLAPPED.

15

WS_MINIMIZEBOX

Crée une fenêtre avec un bouton Réduire.

16

WS_OVERLAPPED

Crée une fenêtre superposée. Une fenêtre superposée a généralement une légende et une bordure.

17

WS_OVERLAPPED WINDOW

Crée une fenêtre superposée avec les styles WS_OVERLAPPED, WS_CAPTION, WS_SYSMENU, WS_THICKFRAME, WS_MINIMIZEBOX et WS_MAXIMIZEBOX.

18

WS_POPUP

Crée une fenêtre contextuelle. Ne peut pas être utilisé avec le style WS_CHILD.

19

WS_POPUPWINDOW

Crée une fenêtre contextuelle avec les styles WS_BORDER, WS_POPUP et WS_SYSMENU. Le style WS_CAPTION doit être combiné avec le style WS_POPUPWINDOW pour rendre le menu Contrôle visible.

20

WS_SIZEBOX

Crée une fenêtre avec une bordure de dimensionnement. Identique au style WS_THICKFRAME.

21

WS_SYSMENU

Crée une fenêtre contenant une zone de menu Contrôle dans sa barre de titre. Utilisé uniquement pour les fenêtres avec des barres de titre.

22

WS_TABSTOP

Spécifie l'un des nombreux contrôles à travers lesquels l'utilisateur peut se déplacer à l'aide de la touche TAB. La touche TAB déplace l'utilisateur vers le contrôle suivant spécifié par le style WS_TABSTOP.

23

WS_THICKFRAME

Crée une fenêtre avec un cadre épais qui peut être utilisé pour dimensionner la fenêtre.

24

WS_TILED

Crée une fenêtre superposée. Une fenêtre superposée a une barre de titre et une bordure. Identique au style WS_OVERLAPPED.

25

WS_TILEDWINDOW

Crée une fenêtre superposée avec les styles WS_OVERLAPPED, WS_CAPTION, WS_SYSMENU, WS_THICKFRAME, WS_MINIMIZEBOX et WS_MAXIMIZEBOX. Identique au style WS_OVERLAPPEDWINDOW.

26

WS_VISIBLE

Crée une fenêtre initialement visible.

27

WS_VSCROLL

Crée une fenêtre dotée d'une barre de défilement verticale.

Step 1- Regardons un exemple simple dans lequel nous ajouterons du style. Après avoir créé une fenêtre, pour l'afficher à l'utilisateur, nous pouvons lui appliquer le style WS_VISIBLE et en plus, nous ajouterons également le style WS_OVERLAPPED. Voici une implémentation -

class CMyFrame : public CFrameWnd {
   public:
      CMyFrame() {
         Create(NULL, _T("MFC Application Tutorial"), WS_VISIBLE | WS_OVERLAPPED);
      }
};

Step 2 - Lorsque vous exécutez cette application, la fenêtre suivante est créée.

Vous pouvez maintenant voir que les options de réduction, d'agrandissement et de fermeture n'apparaissent plus.

Emplacement Windows

Pour localiser les éléments affichés sur le moniteur, l'ordinateur utilise un système de coordonnées similaire à celui cartésien, mais l'origine est située dans le coin supérieur gauche de l'écran. En utilisant ce système de coordonnées, tout point peut être localisé par sa distance par rapport au coin supérieur gauche de l'écran des axes horizontal et vertical.

le Win32 library fournit une structure appelée POINT définie comme suit -

typedef struct tagPOINT {
   LONG x;
   LONG y;
} POINT;
  • La variable membre 'x' est la distance entre la bordure gauche de l'écran et le point.

  • La variable «y» représente la distance entre le bord supérieur de l'écran et le point.

  • Outre la structure POINT de Win32, la bibliothèque Microsoft Foundation Class (MFC) fournit la classe CPoint.

  • Cela fournit la même fonctionnalité que la structure POINT. En tant que classe C ++, elle ajoute plus de fonctionnalités nécessaires pour localiser un point. Il fournit deux constructeurs.

CPoint();
CPoint(int X, int Y);

Taille de Windows

Alors qu'un point est utilisé pour localiser un objet sur l'écran, chaque fenêtre a une taille. La taille fournit deux mesures liées à un objet.

  • La largeur d'un objet.
  • La hauteur d'un objet.

La bibliothèque Win32 utilise la structure SIZE définie comme suit -

typedef struct tagSIZE {
   int cx;
   int cy;
} SIZE;

Outre la structure SIZE de Win32, le MFC fournit la classe CSize. Cette classe a les mêmes fonctionnalités que SIZE mais ajoute des fonctionnalités d'une classe C ++. Il fournit cinq constructeurs qui vous permettent de créer une variable de taille de n'importe quelle manière de votre choix.

CSize();
CSize(int initCX, int initCY);
CSize(SIZE initSize);
CSize(POINT initPt);
CSize(DWORD dwSize);

Dimensions Windows

Lorsqu'une fenêtre s'affiche, elle peut être identifiée à l'écran par son emplacement par rapport aux bordures du moniteur. Une fenêtre peut également être identifiée par sa largeur et sa hauteur. Ces caractéristiques sont spécifiées ou contrôlées par l' argument rect duCreate()méthode. Cet argument est un rectangle qui peut être créé via la structure Win32 RECT.

typedef struct _RECT {
   LONG left;
   LONG top;
   LONG right;
   LONG bottom;
} RECT, *PRECT;

Outre les Win32 RECT structure, le MFC fournit la classe CRect qui a les constructeurs suivants -

CRect();
CRect(int l, int t, int r, int b);
CRect(const RECT& srcRect);
CRect(LPCRECT lpSrcRect);
CRect(POINT point, SIZE size);
CRect(POINT topLeft, POINT bottomRight);

Regardons un exemple simple dans lequel nous préciserons l'emplacement et la taille de la fenêtre

class CMyFrame : public CFrameWnd {
   public:
      CMyFrame() {
         Create(NULL, _T("MFC Application Tutorial"), WS_SYSMENU, CRect(90, 120, 
            550, 480));
      }
};

Lorsque vous exécutez cette application, la fenêtre suivante est créée dans le coin supérieur gauche de votre écran comme spécifié dans le constructeur CRect dans les deux premiers paramètres. Les deux derniers paramètres sont la taille de la fenêtre.

Parents Windows

Dans le monde réel, de nombreuses applications sont constituées de Windows différents. Lorsqu'une application utilise plusieurs Windows, la plupart des objets dépendent d'un objet particulier. Il peut s'agir de la première fenêtre créée ou d'une autre fenêtre que vous avez désignée. Une telle fenêtre est appeléeParent Window. Toutes les autres fenêtres en dépendent directement ou indirectement.

  • Si la fenêtre que vous créez dépend d'une autre, vous pouvez spécifier qu'elle a un parent.

  • Ceci est fait avec l'argument pParentWnd de la méthode CFrameWnd :: Create ().

  • Si la fenêtre n'a pas de parent, transmettez l'argument avec une valeur NULL.

Examinons un exemple qui n'a qu'une seule fenêtre, et il n'y a pas de fenêtre parent disponible, nous allons donc passer l'argument avec la valeur NULL comme indiqué dans le code suivant -

class CMyFrame : public CFrameWnd {
   public:
      CMyFrame() {
         Create(NULL, _T("MFC Application Tutorial"), WS_SYSMENU, 
            CRect(90, 120, 550, 480), NULL);
      }
};

Lorsque vous exécutez l'application ci-dessus, vous voyez la même sortie.