Contêineres de controle ActiveX: manipulando eventos a partir de um controle ActiveX
Este artigo descreve usando a janela Propriedades para instalar manipuladores de eventos para controles ActiveX em um contêiner do controle ActiveX. Os manipuladores de eventos são usados para receber notificações () do controle de certos eventos e executar qualquer ação na resposta. Essa notificação é chamada “” acionamento do evento.
Dica
Este artigo usa um contêiner diálogo- baseado Contêiner denominado projeto do controle ActiveX e um controle inserido denominado Circ como exemplos nos procedimentos e em código.
Usando os eventos botão na janela Propriedades, você pode criar um mapa dos eventos que podem ocorrer em seu aplicativo de contêiner do controle ActiveX. Esse mapa, chamado de “um mapa coletor de eventos,” é criado e mantido pelo Visual C++ quando você adicionar manipuladores de eventos à classe do contêiner do controle. Cada manipulador de eventos, implementado com uma entrada do mapa de evento, mapeia um evento específico a uma função de membro do manipulador de eventos do contêiner. Essa função do manipulador de eventos é chamada quando o evento especificado é acionado pelo objeto do controle ActiveX.
Para obter mais informações sobre mapas de coletor de eventos, consulte Mapas de coletor de eventosna referência da biblioteca da classe.
Alterações de manipulador de eventos ao projeto
Quando você usa a janela Propriedades para adicionar manipuladores de eventos, um mapa de coletor de eventos é declarado e definido em seu projeto. As instruções a seguir são adicionadas ao arquivo de controle .CPP a primeira vez que um manipulador de eventos é adicionado. Esse código a seguir declara um mapa de coletor de eventos para a classe da caixa de diálogo (nesse caso, CContainerDlg):
BEGIN_EVENTSINK_MAP(CContainerDlg, CDialog)
...
END_EVENTSINK_MAP()
Como você usa a janela Propriedades para adicionar eventos, uma entrada de mapa do evento (ON_EVENT) é adicionada ao mapa do coletor de eventos e um manipulador de eventos que a função é adicionada ao arquivo de implementação do contêiner (.CPP).
O exemplo a seguir declara um manipulador de eventos, OnClickInCircCtrlchamado, para o evento de ClickIn de controle de Circ:
BEGIN_EVENTSINK_MAP(CContainerDlg, CDialog)
ON_EVENT(CContainerDlg, IDC_CIRCCTRL1, 1 /* ClickIn */, OnClickInCircctrl1,
VTS_I4 VTS_I4)
END_EVENTSINK_MAP()
Além disso, o seguinte modelo é adicionado ao arquivo de implementação da classe de CContainerDlg (.CPP) para a função de membro do manipulador de eventos:
BOOL CContainerDlg::OnClickInCircctrl1(OLE_XPOS_PIXELS nX, OLE_YPOS_PIXELS nY)
{
// use nX and nY here
TRACE(_T("nX = %d, nY = %d\n"), nX, nY);
return TRUE;
}
Para obter mais informações sobre macros de coletor de eventos, consulte Mapas de coletor de eventosna referência da biblioteca da classe.
Para criar uma função de manipulador de eventos
Em vez da classe, selecione a classe da caixa de diálogo que contém o controle ActiveX. Para esse exemplo, use CContainerDlg.
Na janela Propriedades, clique no botão Eventos.
Na janela Propriedades, selecione a ID do controle ActiveX inserido. Para esse exemplo, use IDC_CIRCCTRL1.
A janela Propriedades exibe uma lista de eventos que podem ser acionados pelo controle ActiveX inserido. Qualquer função de membro mostrada em negrito já tem as funções do manipulador atribuídas a eles.
Selecione o evento que você deseja a classe da caixa de diálogo para tratar. Para este exemplo, Clicarselecione.
Na caixa de listagem suspensa à direita, selecione <Add> ClickCircctrl1.
Clique duas vezes na nova função do manipulador de exibição da classe para saltar para o código do manipulador de eventos no arquivo de implementação) (.CPP de CContainerDlg.