Escolhendo um método de menu de atalho estático ou dinâmico
Este tópico é organizado da seguinte maneira:
- Escolha um método de verbo
- Estender um menu de atalho
- Suporte para métodos verbais por sistema operacional
- Tópicos relacionados
Escolha um método de verbo
É altamente recomendável que você implemente um menu de atalho usando um dos métodos de verbos estáticos.
Métodos de verbos estáticos
Os verbos estáticos são os verbos mais simples de implementar, mas ainda fornecem uma funcionalidade rica. Escolha sempre o método de menu de atalho mais simples que atenda às suas necessidades.
Verbo estático | Descrição |
---|---|
CreateProcess com parâmetros de linha de comando | Este é o meio mais simples e familiar de implementar um verbo estático. Um processo é chamado por meio de uma chamada para a função CreateProcess com os arquivos selecionados e quaisquer parâmetros opcionais passados como a linha de comando. Isso abre o arquivo ou pasta. Este método tem as seguintes limitações:
|
IDropTarget DropTarget/ | Uma ativação verbal baseada em COM significa que suporta ativação in-proc ou out-of-proc. O DropTarget/IDropTarget também oferece suporte à reutilização de um manipulador já em execução quando a interface IDropTarget é implementada por um servidor local. Ele também expressa perfeitamente os itens por meio do objeto de dados empacotado e fornece uma referência à cadeia de site de invocação para que você possa interagir com o invocador por meio do QueryService. |
Windows 7 e posterior: IExecuteCommand | O método de implementação mais direto. Como esse é um método de chamada baseado em COM (como DropTarget), essa interface oferece suporte à ativação in-proc e out-of-proc. O verbo implementa IExecuteCommand e IObjectWithSelection e, opcionalmente, IInitializeCommand. Os itens são passados diretamente como uma matriz de itens do Shell e mais parâmetros do invocador estão disponíveis para a implementação do verbo, incluindo o ponto de invocação, o estado do teclado e assim por diante. |
Windows 7 e posterior:ExplorerCommand/ IExplorerCommand | Permite que fontes de dados que fornecem seus comandos de módulo de comando por meio de IExplorerCommandProvider usem esses comandos como verbos em um menu de atalho. Como essa interface oferece suporte apenas à ativação em processo, ela é recomendada para uso por fontes de dados do Shell que precisam compartilhar a implementação entre comandos e menus de atalho. |
Observação
IExplorerCommand é um híbrido entre um verbo estático e dinâmico. IExplorerCommand foi declarado no Windows Vista, mas sua capacidade de implementar um verbo em um menu de atalho é nova no Windows 7.
Para obter mais informações sobre IDropTarget e consultas Shell para atributos de associação de arquivo, consulte Tipos percebidos e registro de aplicativo.
Métodos verbais dinâmicos preferidos
Os seguintes métodos de verbos dinâmicos são preferidos:
Tipo de verbo | Descrição |
---|---|
Verbo estático (listado na tabela anterior) + Sintaxe de consulta avançada (AQS) | Essa escolha obtém visibilidade verbal dinâmica. |
Windows 7 e posterior: IExplorerCommand | Essa opção permite uma implementação comum de verbos e comandos do Explorer que são exibidos no módulo de comando no Windows Explorer. |
Windows 7 e posterior: IExplorerCommandState + verbo estático | Essa escolha também obtém visibilidade verbal dinâmica. É um modelo híbrido onde um manipulador simples em processo é usado para calcular se um determinado verbo estático deve ser exibido. Isso pode ser aplicado a todos os métodos de implementação de verbos estáticos para alcançar um comportamento dinâmico e minimizar a exposição da lógica em processo. IExplorerCommandState tem a vantagem de ser executado em um thread em segundo plano e, assim, evita travamentos da interface do usuário. É consideravelmente mais simples do que IContextMenu. |
Métodos verbais dinâmicos desencorajados
IContextMenu é o método mais poderoso, mas também o mais complicado de implementar. Ele é baseado em objetos COM em processo que são executados no thread do chamador, que geralmente o Windows Explorer, mas pode ser qualquer aplicativo que hospeda os itens. IContextMenu suporta visibilidade de verbos, ordenação e desenho personalizado. Alguns desses recursos foram adicionados aos recursos de verbo estático, como um ícone a ser associado a um comando e IExplorerCommand para lidar com a visibilidade.
Se você precisar estender o menu de atalho para um tipo de arquivo registrando um verbo dinâmico para o tipo de arquivo, siga as instruções fornecidas em Personalizando um menu de atalho usando verbos dinâmicos.
Estender um menu de atalho
Depois de escolher um método de verbo, você pode estender um menu de atalho para um tipo de arquivo registrando um verbo estático para o tipo de arquivo. Para obter mais informações, consulte Criando manipuladores de menu de contexto.
Suporte para métodos verbais por sistema operacional
O suporte para métodos de invocação de verbo pelo sistema operacional está listado na tabela a seguir.
Método Verb | Windows XP | Windows Vista | Windows 7 e posterior |
---|---|---|---|
CreateProcess | X | X | X |
DDE | X | X | X |
DropTarget | X | X | X |
ExecuteCommand | X | X | |
ExplorerCommand | X | ||
ExplorerCommandState | X |
Tópicos relacionados
-
Melhores Práticas para Manipuladores de Menu de Atalho e Vários Verbos de Seleção
-
Menus de Atalho (Contexto) e Manipuladores de Menu de Atalho