Definindo o estado de dia de um controle de calendário mensal
Um dos atributos de um controle de calendário de mês é a capacidade de armazenar informações, conhecidas como o estado de dia de controle, para cada dia do mês.Essa informação é usada para enfatizar determinadas datas para o mês exibido no momento.
Observação |
---|
O CMonthCalCtrl o objeto deve ter a MCS_DAYSTATE estilo para exibir informações de estado do dia. |
Informações de estado do dia é expresso como um tipo de dados de 32 bits, MONTHDAYSTATE.Cada bit em um MONTHDAYSTATE campo de bits (1 a 31) representa o estado de um dia de um mês.Se um bit estiver ativada, o dia correspondente será exibido em negrito; Caso contrário, ele será exibido com nenhuma ênfase.
Há dois métodos para definir o estado de dia de controle de calendário mensal: explicitamente com uma chamada para CMonthCalCtrl::SetDayState ou pelo tratamento de MCN_GETDAYSTATE mensagem de notificação.
Manipulação de mensagem de notificação MCN_GETDAYSTATE
O MCN_GETDAYSTATE mensagem é enviada pelo controle para determinar como os dias nos meses visíveis devem ser exibidos.
Observação |
---|
Porque o controle armazena em cache os meses anteriores e seguintes, em relação ao mês visível, você receberá essa notificação sempre que um novo mês é escolhido. |
Para manipular adequadamente essa mensagem, você deve determinar quantos meses as informações de estado do dia está sendo solicitada para, inicializar uma matriz de MONTHDAYSTATE estruturas com valores apropriados e inicializar o membro estrutura relacionadas com as novas informações.O procedimento a seguir detalha as etapas necessárias, presume que você tenha um CMonthCalCtrl objeto chamado m_monthcal e uma matriz de MONTHDAYSTATE objetos, mdState.
Para manipular a mensagem de notificação MCN_GETDAYSTATE
Usando a janela Propriedades, adicionar um manipulador de notificação para o MCN_GETDAYSTATE mensagem para o m_monthcal objeto (consulte Mapeamento mensagens para funções).
No corpo do manipulador, adicione o seguinte código:
LPNMDAYSTATE pDayState = reinterpret_cast<LPNMDAYSTATE>(pNMHDR); int iMax = pDayState->cDayState; for(int i = 0; i < iMax; i++) { pDayState->prgDayState[i] = (MONTHDAYSTATE)0; // init to 0 pDayState->prgDayState[i] |= 0x01 << 14; // set 15th bit to 1 }
O exemplo converte o pNMHDR ponteiro para o tipo apropriado, em seguida, determina quantos meses de informações estão sendo solicitados (pDayState->cDayState).Para cada mês, junte atual (pDayState->prgDayState[i]) é inicializado para zero e, em seguida, o necessário conjunto de datas (no caso, dia 15 de cada mês).