Partilhar via


CColorDialog::OnColorOK

Substituição para validar a cor inserida na caixa de diálogo.

virtual BOOL OnColorOK( );

Valor de retorno

Diferente de zero se a caixa de diálogo é demitida; se não 0 para aceitar a cor que foi inserida.

Comentários

Substituir essa função somente se você desejar fornecer validação de cores personalizado que o usuário seleciona na caixa de diálogo de cor.

O usuário pode selecionar uma cor por um dos dois seguintes métodos:

  • Clicando em uma cor em paleta de cores. Os valores de cor RGB selecionado são refletidos em caixas de edição apropriadas de RGB.

  • Inserindo valores nas caixas de edição de RGB

Substitua OnColorOK permite que você rejeitar uma cor que o usuário insere em uma caixa de diálogo comuns de cor para qualquer motivo específico do aplicativo.

Normalmente, você não precisa usar essa função porque a estrutura fornece validação padrão cores e exibe uma caixa de mensagem se uma cor inválido é inserida.

Você pode chamar SetCurrentColor de dentro de OnColorOK para forçar uma seleção de cor. Uma vez que OnColorOK foi acionado (ou seja, os cliques OK do usuário para aceitar a alteração de cor), você pode chamar GetColor para obter o valor de cor RGB novo.

Exemplo

// Override OnColorOK to validate the color entered to the 
// Red, Green, and Blue edit controls. If the color 
// is BLACK (i.e. RGB(0, 0,0)), then force the current color 
// selection to be the color initially selected when the 
// dialog box is created. The color dialog won't close so 
// user can enter a new color.
BOOL CMyColorDlg::OnColorOK()
{
   // Value in Red edit control.
   COLORREF clrref = GetColor();
   if (RGB(0, 0, 0) == clrref)
   {
      AfxMessageBox(_T("BLACK is not an acceptable color. ")
         _T("Please enter a color again"));

      // GetColor() returns initially selected color.
      SetCurrentColor(GetColor());        

      // Won't dismiss color dialog. 
      return TRUE;                        
   }

   // OK to dismiss color dialog. 
   return FALSE;                          
}

Requisitos

Cabeçalho: afxdlgs.h

Consulte também

Referência

Classe CColorDialog

Gráfico da hierarquia