Come creare un controllo calendario mensile
In questo argomento viene illustrato come creare dinamicamente un controllo del calendario mensile usando la funzione CreateWindowEx.
Informazioni importanti
Tecnologie
Prerequisiti
- C/C++
- Programmazione dell'interfaccia utente di Windows
Istruzioni
Per creare un controllo calendario mensile, usare la funzione CreateWindowEx, specificando MONTHCAL_CLASS come classe finestra. È prima necessario registrare la classe window chiamando la funzione InitCommonControlsEx, specificando il bit ICC_DATE_CLASedizione Standard S nella struttura INITCOMMONCONTROL edizione Standard X associata.
Nell'esempio seguente viene illustrato come creare un controllo calendario mensile in una finestra di dialogo senza modalità esistente. Si noti che i valori delle dimensioni passati a CreateWindowEx sono tutti zeri. Poiché la dimensione minima richiesta dipende dal tipo di carattere utilizzato dal controllo, nell'esempio viene utilizzata la macro MonthCal_GetMinReqRect per richiedere informazioni sulle dimensioni e quindi ridimensiona il controllo chiamando SetWindowPos. Se successivamente si modifica il tipo di carattere con WM_edizione Standard TFONT, le dimensioni del controllo non verranno modificate. È necessario chiamare di nuovo MonthCal_GetMinReqRect e ridimensionare il controllo per adattarlo al nuovo tipo di carattere.
// Child window identifier of the month calendar.
#define IDC_MONTHCAL 101
// Symbols used by SetWindowPos function (arbitrary values).
#define LEFT 35
#define TOP 40
// Description:
// Creates a month calendar control in a dialog box.
// Parameters:
// hwndOwner - handle of the owner window.
// Nonlocal variables:
// MonthCalDlgProc - window procedure of the dialog box that
// contains the month calendar.
// g_hInst - global instance handle.
//
HRESULT CreateMonthCalDialog(HWND hwndOwner)
{
RECT rc;
INITCOMMONCONTROLSEX icex;
HWND hwndDlg = NULL;
HWND hwndMonthCal = NULL;
// Return an error code if the owner handle is invalid.
if (hwndOwner == NULL)
return E_INVALIDARG;
// Load the window class.
icex.dwSize = sizeof(icex);
icex.dwICC = ICC_DATE_CLASSES;
InitCommonControlsEx(&icex);
// Create a modeless dialog box to hold the control.
hwndDlg = CreateDialog(g_hInst,
MAKEINTRESOURCE(IDD_DATE_PICKER),
hwndOwner,
MonthCalDlgProc);
// Return if creating the dialog box failed.
if (hwndDlg == NULL)
return HRESULT_FROM_WIN32(GetLastError());
// Create the month calendar.
hwndMonthCal = CreateWindowEx(0,
MONTHCAL_CLASS,
L"",
WS_BORDER | WS_CHILD | WS_VISIBLE | MCS_DAYSTATE,
0,0,0,0, // resize it later
hwndDlg,
(HMENU) IDC_MONTHCAL,
g_hInst,
NULL);
// Return if creating the month calendar failed.
if (hwndMonthCal == NULL)
return HRESULT_FROM_WIN32(GetLastError());
// Get the size required to show an entire month.
MonthCal_GetMinReqRect(hwndMonthCal, &rc);
// Resize the control now that the size values have been obtained.
SetWindowPos(hwndMonthCal, NULL, LEFT, TOP,
rc.right, rc.bottom, SWP_NOZORDER);
// Set the calendar to the annual view.
MonthCal_SetCurrentView(hwndMonthCal, MCMV_YEAR);
// Make the window visible.
ShowWindow(hwndDlg, SW_SHOW);
return S_OK;
}
Argomenti correlati