Partilhar via


CWnd::SendMessage

Envia a mensagem especificada em essa janela.

LRESULT SendMessage(
   UINT message,
   WPARAM wParam = 0,
   LPARAM lParam = 0 
);

Parâmetros

  • message
    Especifica a mensagem a ser enviada.

  • wParam
    Especifica a informações adicionais de mensagem- dependente.

  • lParam
    Especifica a informações adicionais de mensagem- dependente.

Valor de retorno

O resultado de processamento de mensagens; o valor depende de mensagem enviada.

Comentários

A função de membro de SendMessage chama o procedimento da janela diretamente e não retorna até que o procedimento de janela processa a mensagem.Isso está em contraste com a função de membro de PostMessage , que coloca a mensagem na fila de mensagens de janela e retorna imediatamente.

Exemplo

void CAboutDlg::OnPaint()
{
   // This code, normally emitted by the Application Wizard for a dialog-
   // based project for the dialog's WM_PAINT handler, runs only if the 
   // window is iconic. The window erases the icon's area, then
   // paints the icon referenced by m_hIcon.
   if (IsIconic())
   {
      CPaintDC dc(this); // device context for painting

      SendMessage(WM_ICONERASEBKGND, (WPARAM)dc.GetSafeHdc(), 0);

      // Center icon in client rectangle
      int cxIcon = GetSystemMetrics(SM_CXICON);
      int cyIcon = GetSystemMetrics(SM_CYICON);
      CRect rect;
      GetClientRect(&rect);
      int x = (rect.Width() - cxIcon + 1) / 2;
      int y = (rect.Height() - cyIcon + 1) / 2;

      // Draw the icon
      dc.DrawIcon(x, y, m_hIcon);
   }
   else
   {
      CDialog::OnPaint();   
   }
}

Requisitos

Cabeçalho: afxwin.h

Consulte também

Referência

CWnd Class

Gráfico de hierarquia

InSendMessage

CWnd::PostMessage

CWnd::SendDlgItemMessage

SendMessage