Partilhar via


Como implementar páginas de propriedades

O assistente de Página de Propriedades da ATL não está disponível no Visual Studio 2019 e versões posteriores.

As páginas de propriedades são objetos COM que implementam a interface IPropertyPage ou IPropertyPage2. A ATL é compatível com a implementação de páginas de propriedades por meio do Assistente de Página de Propriedades da ATL na caixa de diálogo Adicionar Classe.

Criação de uma página de propriedades usando a ATL:

  • Crie ou abra um projeto de servidor DLL (Biblioteca de Vínculo Dinâmico) da ATL.

  • Abra a caixa de diálogo Adicionar Classe e selecione Página de Propriedades da ATL.

  • Verifique se sua página de propriedades é do modelo Apartment Threading (desde que tenha uma interface do usuário).

  • Defina o título, a descrição (Doc String) e o arquivo de ajuda a ser associado à sua página.

  • Adicione controles ao recurso de caixa de diálogo gerado para atuar como a interface do usuário de sua página de propriedades.

  • Responda às alterações na interface do usuário da sua página para executar a validação, atualizar o site de página ou atualizar os objetos associados à sua página. Especificamente, chame IPropertyPageImpl::SetDirty quando o usuário alterar a página de propriedades.

  • Se desejar, substitua os métodos IPropertyPageImpl usando as diretrizes abaixo.

    Método IPropertyPageImpl Substitua quando desejar... Observações
    SetObjects Execute as verificações de integridade básicas no número de objetos que estão sendo passados para sua página e as interfaces com as quais eles são compatíveis. Execute o seu próprio código antes de chamar a implementação da classe base. Se os objetos que estão sendo definidos não estiverem em conformidade com as suas expectativas, você deverá interromper a chamada assim que possível.
    Ativar Inicialize a interface do usuário da sua página (por exemplo, defina os controles da caixa de diálogo com valores da propriedade atuais de objetos, crie controles dinamicamente ou execute outras inicializações). Chame a implementação da classe base antes do código para que a classe base tenha a oportunidade de criar a janela de diálogo e todos os controles antes de você tentar atualizá-los.
    Aplicar Valide as configurações de propriedade e atualize os objetos. Não é necessário chamar a implementação da classe base, uma vez que ela não tem função nenhuma além de rastrear a chamada.
    Deactivate Limpe os itens relacionados à janela. A implementação da classe base destrói a caixa de diálogo que representa a página de propriedades. Se você precisar limpar antes que a caixa de diálogo seja destruída, será preciso adicionar seu código antes de chamar a classe base.

Para obter um exemplo de implementação de página de propriedades, confira Exemplo: implementando uma página de propriedades.

Observação

Se quiser hospedar controles ActiveX em sua página de propriedades, você precisará alterar a derivação da sua classe gerada pelo assistente. Substitua CDialogImpl<CYourClass> por CAxDialogImpl<CYourClass> na lista de classes base.

Confira também

Páginas de propriedades
Exemplo de páginas ATL