Condividi tramite


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;
}

Riferimento al controllo Calendario mensile

Informazioni sui controlli del calendario mensile

Uso dei controlli Calendario mese