Partilhar via


CMonthCalCtrl::GetRange

Recupera o mínimo atual e datas máximo definidos em um controle de calendário mensal.

DWORD GetRange( 
   COleDateTime* pMinRange, 
   COleDateTime* pMaxRange  
) const; 
DWORD GetRange( 
   CTime* pMinRange, 
   CTime* pMaxRange  
) const; 
DWORD GetRange( 
   LPSYSTEMTIME pMinRange, 
   LPSYSTEMTIME pMaxRange  
) const;

Parâmetros

  • pMinRange
    Um ponteiro para um objeto de COleDateTime , a um objeto de CTime , ou a estrutura de SYSTEMTIME que contém a data no menor de gama do intervalo.

  • pMaxRange
    Um ponteiro para um objeto de COleDateTime , a um objeto de CTime , ou a estrutura de SYSTEMTIME que contém a data final na maior do intervalo.

Valor de retorno

DWORD que pode ser zero (nenhum limite é definido como) ou uma combinação dos seguintes valores especificando informações de associação.

Valor

Significado

GDTR_MAX

Um limite máximo é definido para o controle; pMaxRange é válido e contém informações de data aplicável.

GDTR_MIN

Um limite mínimo é definido para o controle; pMinRange é válido e contém informações de data aplicável.

Comentários

Essa função de membro implementa o comportamento de mensagem MCM_GETRANGEWin32, como descrito em Windows SDK. Em a implementação de GetRangeMFC, você pode especificar um uso de COleDateTime , um uso de CTime , ou um uso da estrutura de SYSTEMTIME .

Exemplo

// This code fragment sets a variety of ranges in the 
// control, and calls a separate function to show the 
// set range to the user. 

void CMonthCalDlg::OnBnClickedRangebutton()
{
   // set minimum of January 1st, 1995 with no maximum
   COleDateTime dtMin;
   COleDateTime dtMax;

   dtMin = COleDateTime(1995, 1, 1, 0, 0, 0);
   dtMax.SetStatus(COleDateTime::null);
   m_calCtrl1.SetRange(&dtMin, &dtMax);
   ShowRange(&m_calCtrl1);

   // set no minimum and a maximum of September 30th, 1997
   dtMin.SetStatus(COleDateTime::null);
   dtMax = COleDateTime(1997, 9, 30, 0, 0, 0);
   m_calCtrl1.SetRange(&dtMin, &dtMax);
   ShowRange(&m_calCtrl1);

   // set minimum of April 15, 1992 and maximum of June 5, 2002
   dtMin = COleDateTime(1992, 4, 15, 0, 0, 0);
   dtMax = COleDateTime(2002, 6, 5, 0, 0, 0);
   m_calCtrl1.SetRange(&dtMin, &dtMax);
   ShowRange(&m_calCtrl1);
}

void CMonthCalDlg::ShowRange(CMonthCalCtrl* pMoCalCtrl)
{
   ASSERT(pMoCalCtrl != NULL);
   CString strMessage;
   COleDateTime dtMinimum;
   COleDateTime dtMaximum;

   // Get the range
   DWORD dwResult = pMoCalCtrl->GetRange(&dtMinimum, &dtMaximum);

   // If a minimum was specified, format it 
   // otherwise, indicate that there is no lower bound 
   if (dwResult & GDTR_MIN)
      strMessage += dtMinimum.Format(_T("Minimum range is %x %X.\r\n"));
   else
      strMessage += _T("No minimum range.\r\n");

   // Treat maximum similarly 
   if (dwResult & GDTR_MAX)
      strMessage += dtMaximum.Format(_T("Maximum range is %x %X.\r\n"));
   else
      strMessage += _T("No maximum range.\r\n");

   // Show the user
   AfxMessageBox(strMessage);
}

Requisitos

Cabeçalho: afxdtctl.h

Consulte também

Referência

Classe CMonthCalCtrl

Gráfico da hierarquia

CMonthCalCtrl::SetRange