Partilhar via


CPropertyPage::OnWizardFinish

Essa função de membro é chamada pela estrutura quando o usuário clica no botão de suporte em um assistente.

virtual BOOL OnWizardFinish( );

Valor de retorno

Diferente de zero se a folha de propriedades é destruída quando concluir o assistente; se não zero.

Comentários

Quando um usuário clica no botão de Concluir em um assistente, a estrutura chama essa função; quando OnWizardFinish retornar Verdadeiro (um valor diferente de zero), a folha de propriedades pode ser destruído (mas não é destruído realmente). Chamada para DestroyWindow destruir a folha de propriedades. Não chamar DestroyWindow de OnWizardFinish; isso irá fazer danos da heap ou outros erros.

Você pode substituir essa função de membro para especificar qualquer ação que o usuário deve executar quando o botão de suporte é pressionada. A o substituir essa função, Falso de retorno para impedir que a folha de propriedade seja destruída.

Para obter mais informações sobre as notificações enviadas quando o usuário pressiona o botão de suporte em uma folha de propriedades do assistente, consulte PSN_WIZFINISH em Windows SDK.

Para obter mais informações sobre como tornar um folha de propriedades de uma tipo CPropertySheet::SetWizardMode, consulte.

Exemplo

// Inform users regarding the selections they have made by  
// navigating the pages in propertysheet.
BOOL CShapePage::OnWizardFinish()
{
   CString report = _T("You have selected the following options:\n");

   // Get the number of property pages from CPropertySheet.
   CPropertySheet* sheet = (CPropertySheet*) GetParent();
   int count = sheet->GetPageCount();   

   // Get the formatted string from each page. This formatted string  
   // will be shown in a message box. Each page knows about the  
   // string to be displayed. For simplicity, we derive a class  
   // from CPropertyPage called CMyPropertyPage. CMyPropertyPage  
   // has a pure virtual member function called GetPageSelections(). 
   // All pages in the property sheet must be derived from  
   // CMyPropertyPage so we loop through each page to get the  
   // formatted string by calling the GetPageSelections() function. 
   for (int i = 0; i < count; i++)
   {
      CMyPropertyPage* page = (CMyPropertyPage*) sheet->GetPage(i);

      CString str;
      page->GetPageSelections(str);
      report += _T("\n") + str;
   }

   AfxMessageBox(report);

   return CPropertyPage::OnWizardFinish();
}
// An example of implementing the GetPageSelections() for CStylePage. 
// CStylePage is a CMyPropertyPage-derived class, which in turn is a  
// CPropertyPage-derived class. 
void CStylePage::GetPageSelections(CString &str)
{
   str.Format(_T("Number of objects to be created = %d"), m_NumObjects);
}
// An example of implementing the GetPageSelections() for CColorPage. 
// CColorPage is a CMyPropertyPage-derived class, which in turn is a  
// CPropertyPage-derived class. 
void CColorPage::GetPageSelections(CString &str)
{
   str = _T("Color selected is ");   
   switch (m_Color)
   {
   case RGB(0, 0, 0):
      str += _T("Black");
      break;

   case RGB(255, 0, 0):
      str += _T("Red");
      break;

   case RGB(0, 255, 0):
      str += _T("Green");
      break;

   case RGB(0, 0, 255):
      str += _T("Blue");
      break;

   default:
      str += _T("Custom");
      break;
   }
}
// An example of implementing the GetPageSelections() for CShapePage. 
// CShapePage is a CMyPropertyPage-derived class, which in turn is a  
// CPropertyPage-derived class. 
void CShapePage::GetPageSelections(CString &str)
{
   CString shapename;
   switch (m_Selection)
   {
   case IDC_RECTANGLE:
      shapename = _T("Rectangle");
      break;

   case IDC_ROUND_RECTANGLE:
      shapename = _T("Round Rectangle");
      break;

   case IDC_ELLIPSE:
      shapename = _T("Ellipse");
      break;
   }

   str.Format(_T("Shape to be created is %s"), shapename);
}

Requisitos

Cabeçalho: afxdlgs.h

Consulte também

Referência

Classe CPropertyPage

Gráfico da hierarquia

CPropertySheet::SetWizardMode