MFC - Conceptos básicos de Windows
En este capítulo, cubriremos los fundamentos de Windows. Para crear un programa, también llamado aplicación, deriva una clase de CWinApp del MFC.CWinApp representa Class for a Windows Application.
Veamos un ejemplo simple creando un nuevo proyecto Win32.
Step 1 - Abra Visual Studio y haga clic en la opción de menú Archivo → Nuevo → Proyecto.
Step 2 - Ahora puede ver el cuadro de diálogo Nuevo proyecto.
Step 3 - Desde el panel izquierdo, seleccione Plantillas → Visual C ++ → Win32.
Step 4 - En el panel central, seleccione Proyecto Win32.
Step 5- Ingrese el nombre del proyecto 'MFCWindowDemo' en el campo Nombre y haga clic en Aceptar para continuar. Verá el siguiente cuadro de diálogo.
Step 6 - Haga clic en Siguiente.
Step 7 - Seleccione las opciones como se muestra en el cuadro de diálogo que se muestra arriba y haga clic en Finalizar.
Step 8 - Se crea un proyecto vacío.
Step 9 - Para convertirlo en un proyecto MFC, haga clic con el botón derecho en el proyecto y seleccione Propiedades.
Step 10 - En la sección izquierda, haga clic en Propiedades de configuración → General.
Step 11 - Seleccione la opción Usar MFC en DLL compartida en la sección Valores predeterminados del proyecto y haga clic en Aceptar.
Step 12 - Agregue un nuevo archivo fuente.
Step 13 - Haga clic derecho en su proyecto y seleccione Agregar → Nuevo elemento ...
Step 14 - En la sección Plantillas, haga clic en Archivo C ++ (.cpp).
Step 15 - Establezca el nombre como ejemplo y haga clic en Agregar.
Creación de ventanas
Cualquier aplicación tiene dos secciones principales:
- Class
- Marco o ventana
Creemos una ventana siguiendo los siguientes pasos:
Step 1 - Para crear una aplicación, necesitamos derivar una clase de la CWinApp de MFC.
#include
class CExample : public CWinApp {
BOOL InitInstance() {
return TRUE;
}
};
Step 2 - También necesitamos un marco / ventana para mostrar el contenido de nuestra aplicación.
Step 3 - Para esto, necesitamos agregar otra clase y derivarla de los MFC CFrameWnd class e implementar su constructor y llamar al método Create (), que creará un marco / ventana como se muestra en el siguiente código.
class CMyFrame : public CFrameWnd {
public:
CMyFrame() {
Create(NULL, _T("MFC Application Tutorial"));
}
};
Step 4 - Como puede ver, el método Create () necesita dos parámetros, el nombre de la clase, que debe pasarse como NULL, y el nombre de la ventana, que es la cadena que se mostrará en la barra de título.
Ventana principal
Después de crear una ventana, para permitir que la aplicación la use, puede usar un puntero para mostrar la clase utilizada para crear la ventana. En este caso, el puntero sería CFrameWnd. Para usar la ventana de marco, asigne su puntero a la variable miembro CWinThread :: m_pMainWnd. Esto se hace en la implementación InitInstance () de su aplicación.
Step 1 - Aquí está la implementación de InitInstance () en la clase CExample.
class CExample : public CWinApp {
BOOL InitInstance() {
CMyFrame *Frame = new CMyFrame(); m_pMainWnd = Frame;
Frame->ShowWindow(SW_NORMAL);
Frame->UpdateWindow();
return TRUE;
}
};
Step 2 - A continuación se muestra la implementación completa del archivo 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 - Cuando ejecutamos la aplicación anterior, se crea la siguiente ventana.
Estilos de Windows
Los estilos de Windows son características que controlan características como la apariencia de la ventana, los bordes, el estado minimizado o maximizado u otros estados de cambio de tamaño, etc.
No Señor. | Estilo y descripción |
---|---|
1 | WS_BORDER Crea una ventana que tiene un borde. |
2 | WS_CAPTION Crea una ventana que tiene una barra de título (implica el estilo WS_BORDER). No se puede utilizar con el estilo WS_DLGFRAME. |
3 | WS_CHILD Crea una ventana secundaria. No se puede utilizar con el estilo WS_POPUP. |
4 | WS_CHILDWINDOW Igual que el estilo WS_CHILD. |
5 | WS_CLIPCHILDREN Excluye el área ocupada por las ventanas secundarias cuando dibuja dentro de la ventana principal. Se utiliza al crear la ventana principal. |
6 | WS_CLIPSIBLINGS Recorta las ventanas secundarias entre sí; es decir, cuando una ventana secundaria en particular recibe un mensaje de pintura, el estilo WS_CLIPSIBLINGS recorta todas las demás ventanas secundarias superpuestas de la región de la ventana secundaria que se va a actualizar. (Si no se proporciona WS_CLIPSIBLINGS y las ventanas secundarias se superponen, cuando dibuja dentro del área cliente de una ventana secundaria, es posible dibujar dentro del área cliente de una ventana secundaria vecina). Para usar solo con el estilo WS_CHILD. |
7 | WS_DISABLED Crea una ventana que inicialmente está deshabilitada. |
8 | WS_DLGFRAME Crea una ventana con un borde doble pero sin título. |
9 | WS_GROUP Especifica el primer control de un grupo de controles en el que el usuario puede pasar de un control al siguiente con las teclas de flecha. Todos los controles definidos con el estilo WS_GROUP FALSE después del primer control pertenecen al mismo grupo. El siguiente control con el estilo WS_GROUP inicia el siguiente grupo (es decir, un grupo termina donde comienza el siguiente). |
10 | WS_HSCROLL Crea una ventana que tiene una barra de desplazamiento horizontal. |
11 | WS_ICONIC Crea una ventana que inicialmente está minimizada. Igual que el estilo WS_MINIMIZE. |
12 | WS_MAXIMIZE Crea una ventana de tamaño máximo. |
13 | WS_MAXIMIZEBOX Crea una ventana que tiene un botón Maximizar. |
14 | WS_MINIMIZE Crea una ventana que inicialmente está minimizada. Para usar solo con el estilo WS_OVERLAPPED. |
15 | WS_MINIMIZEBOX Crea una ventana que tiene un botón Minimizar. |
dieciséis | WS_OVERLAPPED Crea una ventana superpuesta. Una ventana superpuesta suele tener un título y un borde. |
17 | WS_OVERLAPPED WINDOW Crea una ventana superpuesta con los estilos WS_OVERLAPPED, WS_CAPTION, WS_SYSMENU, WS_THICKFRAME, WS_MINIMIZEBOX y WS_MAXIMIZEBOX. |
18 | WS_POPUP Crea una ventana emergente. No se puede utilizar con el estilo WS_CHILD. |
19 | WS_POPUPWINDOW Crea una ventana emergente con los estilos WS_BORDER, WS_POPUP y WS_SYSMENU. El estilo WS_CAPTION debe combinarse con el estilo WS_POPUPWINDOW para hacer visible el menú Control. |
20 | WS_SIZEBOX Crea una ventana que tiene un borde de tamaño. Igual que el estilo WS_THICKFRAME. |
21 | WS_SYSMENU Crea una ventana que tiene un cuadro de menú de Control en su barra de título. Se usa solo para ventanas con barras de título. |
22 | WS_TABSTOP Especifica uno de los controles a través de los cuales el usuario puede moverse usando la tecla TAB. La tecla TAB mueve al usuario al siguiente control especificado por el estilo WS_TABSTOP. |
23 | WS_THICKFRAME Crea una ventana con un marco grueso que se puede utilizar para dimensionar la ventana. |
24 | WS_TILED Crea una ventana superpuesta. Una ventana superpuesta tiene una barra de título y un borde. Igual que el estilo WS_OVERLAPPED. |
25 | WS_TILEDWINDOW Crea una ventana superpuesta con los estilos WS_OVERLAPPED, WS_CAPTION, WS_SYSMENU, WS_THICKFRAME, WS_MINIMIZEBOX y WS_MAXIMIZEBOX. Igual que el estilo WS_OVERLAPPEDWINDOW. |
26 | WS_VISIBLE Crea una ventana que es inicialmente visible. |
27 | WS_VSCROLL Crea una ventana que tiene una barra de desplazamiento vertical. |
Step 1- Veamos un ejemplo simple en el que agregaremos algo de estilo. Luego de crear una ventana, para mostrársela al usuario, podemos aplicarle el estilo WS_VISIBLE y adicionalmente, también agregaremos el estilo WS_OVERLAPPED. Aquí hay una implementación:
class CMyFrame : public CFrameWnd {
public:
CMyFrame() {
Create(NULL, _T("MFC Application Tutorial"), WS_VISIBLE | WS_OVERLAPPED);
}
};
Step 2 - Cuando ejecuta esta aplicación, se crea la siguiente ventana.
Ahora puede ver que las opciones de minimizar, maximizar y cerrar ya no aparecen.
Ubicación de Windows
Para ubicar las cosas que se muestran en el monitor, la computadora usa un sistema de coordenadas similar al cartesiano, pero el origen se encuentra en la esquina superior izquierda de la pantalla. Con este sistema de coordenadas, cualquier punto puede ubicarse por su distancia desde la esquina superior izquierda de la pantalla de los ejes horizontal y vertical.
los Win32 library proporciona una estructura llamada PUNTO definida de la siguiente manera:
typedef struct tagPOINT {
LONG x;
LONG y;
} POINT;
La variable miembro 'x' es la distancia desde el borde izquierdo de la pantalla hasta el punto.
La variable 'y' representa la distancia desde el borde superior de la pantalla hasta el punto.
Además de la estructura POINT de Win32, la biblioteca Microsoft Foundation Class (MFC) proporciona la clase CPoint.
Esto proporciona la misma funcionalidad que la estructura de PUNTO. Como clase C ++, agrega más funcionalidad necesaria para ubicar un punto. Proporciona dos constructores.
CPoint();
CPoint(int X, int Y);
Tamaño de Windows
Mientras que un punto se usa para ubicar un objeto en la pantalla, cada ventana tiene un tamaño. El tamaño proporciona dos medidas relacionadas con un objeto.
- El ancho de un objeto.
- La altura de un objeto.
La biblioteca Win32 usa la estructura SIZE definida de la siguiente manera:
typedef struct tagSIZE {
int cx;
int cy;
} SIZE;
Además de la estructura SIZE de Win32, el MFC proporciona la clase CSize. Esta clase tiene la misma funcionalidad que SIZE pero agrega características de una clase C ++. Proporciona cinco constructores que le permiten crear una variable de tamaño de la forma que desee.
CSize();
CSize(int initCX, int initCY);
CSize(SIZE initSize);
CSize(POINT initPt);
CSize(DWORD dwSize);
Dimensiones de Windows
Cuando se muestra una ventana, se puede identificar en la pantalla por su ubicación con respecto a los bordes del monitor. Una ventana también se puede identificar por su ancho y alto. Estas características están especificadas o controladas por el argumento correcto delCreate()método. Este argumento es un rectángulo que se puede crear mediante la estructura Win32 RECT.
typedef struct _RECT {
LONG left;
LONG top;
LONG right;
LONG bottom;
} RECT, *PRECT;
Además de los Win32 RECT estructura, el MFC proporciona la clase CRect que tiene los siguientes constructores:
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);
Veamos un ejemplo simple en el que especificaremos la ubicación y el tamaño de la ventana.
class CMyFrame : public CFrameWnd {
public:
CMyFrame() {
Create(NULL, _T("MFC Application Tutorial"), WS_SYSMENU, CRect(90, 120,
550, 480));
}
};
Cuando ejecuta esta aplicación, se crea la siguiente ventana en la esquina superior izquierda de su pantalla como se especifica en el constructor CRect en los primeros dos parámetros. Los dos últimos parámetros son el tamaño de la ventana.
Padres de Windows
En el mundo real, muchas aplicaciones están hechas de diferentes Windows. Cuando una aplicación usa varias ventanas, la mayoría de los objetos dependen de una en particular. Podría ser la primera ventana que se creó u otra ventana que haya designado. Esta ventana se conoce comoParent Window. Todas las demás ventanas dependen de él directa o indirectamente.
Si la ventana que está creando depende de otra, puede especificar que tenga un padre.
Esto se hace con el argumento pParentWnd del método CFrameWnd :: Create ().
Si la ventana no tiene un padre, pase el argumento con un valor NULL.
Veamos un ejemplo que tiene solo una ventana, y no hay una ventana principal disponible, por lo que pasaremos el argumento con el valor NULL como se muestra en el siguiente código:
class CMyFrame : public CFrameWnd {
public:
CMyFrame() {
Create(NULL, _T("MFC Application Tutorial"), WS_SYSMENU,
CRect(90, 120, 550, 480), NULL);
}
};
Cuando ejecuta la aplicación anterior, ve el mismo resultado.