Como: Criar marcas inteligentes com reconhecedores de personalizado no Word e.NET Framework 4

No Word projetos destinados a .NET Framework 4, você pode controlar como o Word reconhece as marcas inteligentes em documentos, Implementando o ISmartTagExtension interface.

Para executar uma marca inteligente, os usuários finais devem ter marcas inteligentes ativadas no Word ou Excel. For more information, see Como: Ativar marcas inteligentes no Word e Excel.

Aplicável a: As informações neste tópico se aplicam a projetos de nível de documento e projetos de nível de aplicativo para Word 2007. Para obter mais informações, consulte Recursos disponíveis pelo aplicativo do Office e o tipo de projeto.

Para adicionar uma marca inteligente com um reconhecedor personalizado para um documento do Word

  1. Crie um projeto de nível de documento ou no nível do aplicativo para o Word 2007. For more information, see Como: Criar projetos do Office em Visual Studio.

  2. Adicione uma referência ao assembly Microsoft.Office.Interop.SmartTag (versão 12.0.0.0) (em inglês) da .NET guia de Add Reference caixa de diálogo.

  3. Adicionar um arquivo de classe ao projeto e criar uma classe que implementa o ISmartTagExtension interface.

  4. Na nova classe, criar uma SmartTag objeto que representa a marca inteligente e criar uma ou mais Action objetos que representam as ações de marca inteligente. Use o Globals.Factory.CreateSmartTag e Globals.Factory.CreateAction métodos para criar esses objetos.

  5. Implementar a Recognize método e escrever seu próprio personalizado reconhecendo comportamento.

    Sua implementação deve chamar o PersistTag método de context parâmetro para o Word reconhece a marca inteligente.

  6. Implementar a ExtensionBase propriedade para retornar o SmartTag objeto.

  7. Criar manipuladores de eventos para responder ao Click evento e opcionalmente a BeforeCaptionShow o evento, as ações que você criou.

  8. No arquivo de código para o documento de projeto, adicione a instância de marca inteligente VstoSmartTags propriedade da ThisDocument classe (para um projeto de nível de documento) ou o VstoSmartTags propriedade da ThisAddIn classe (para um projeto de nível de aplicativo).

Exemplo

O exemplo de código a seguir mostra como criar uma marca inteligente personalizada em um documento do Word. O exemplo implementa o Recognize método para reconhecer os termos sales e organization. O Recognize método adiciona um par de chave e valor para a coleção de propriedades com chave para a marca inteligente. O método chama o PersistTag método para reconhecer a marca inteligente e salvar a nova propriedade de marca inteligente.

Para testar o exemplo, digite as palavras vendas e organização em diferentes coloca no documento e, em seguida, tente as ações de marca inteligente. Uma ação exibe o valor da propriedade correspondente para o termo reconhecido e a outra ação exibe o namespace de marca inteligente e a legenda.

Imports System
Imports System.Windows.Forms
Imports Microsoft.Office.Interop.SmartTag
Imports Microsoft.Office.Tools.Word

Public Class CustomSmartTag
    Implements ISmartTagExtension
    ' Declare the smart tag.
    Private smartTagDemo As Microsoft.Office.Tools.Word.SmartTag

    ' Declare actions for this smart tag.
    WithEvents Action1 As Microsoft.Office.Tools.Word.Action
    WithEvents Action2 As Microsoft.Office.Tools.Word.Action

    Public Sub New()
        Me.smartTagDemo = Globals.Factory.CreateSmartTag(
            "https://www.contoso.com/Demo#DemoSmartTag", "Custom Smart Tag", Me)

        Action1 = Globals.Factory.CreateAction("Display property value")
        Action2 = Globals.Factory.CreateAction("Display smart tag details")

        smartTagDemo.Terms.AddRange(New String() {"sales", "organization"})
        smartTagDemo.Actions = New Microsoft.Office.Tools.Word.Action() {Action1, Action2}

    End Sub

    Private Sub Recognize(ByVal text As String,
        ByVal site As ISmartTagRecognizerSite,
        ByVal tokenList As ISmartTagTokenList,
        ByVal context As SmartTagRecognizeContext) Implements ISmartTagExtension.Recognize

        For Each term As String In smartTagDemo.Terms
            ' Search the text for the current smart tag term.
            Dim index As Integer = text.IndexOf(term, 0)

            While (index >= 0)
                ' Create a smart tag token and a property bag for the recognized term.
                Dim propertyBag As ISmartTagProperties = site.GetNewPropertyBag()

                ' Write a new property value.
                Dim key As String = "Key1"
                propertyBag.Write(key, DateTime.Now.ToString())

                ' Attach the smart tag to the term in the document
                context.PersistTag(index, term.Length, propertyBag)

                ' Increment the index and then find the next instance of the smart tag term.
                index += term.Length
                index = text.IndexOf(term, index)
            End While
        Next
    End Sub

    ' This action displays the property value for the term.
    Private Sub Action1_Click(ByVal sender As Object,
        ByVal e As Microsoft.Office.Tools.Word.ActionEventArgs) Handles Action1.Click
        Dim propertyBag As ISmartTagProperties = e.Properties
        Dim key As String = "Key1"
        MessageBox.Show(("The corresponding value of " & key & " is: ") + propertyBag.Read(key))
    End Sub

    ' This action displays smart tag details.
    Private Sub Action2_Click(ByVal sender As Object,
        ByVal e As Microsoft.Office.Tools.Word.ActionEventArgs) Handles Action2.Click
        MessageBox.Show(("The current smart tag caption is '" &
            smartTagDemo.Caption & "'. The current smart tag type is '") &
            smartTagDemo.SmartTagType & "'.")
    End Sub

    Public ReadOnly Property Base() As Microsoft.Office.Tools.Word.SmartTag
        Get
            Return (smartTagDemo)
        End Get
    End Property

    Public ReadOnly Property ExtensionBase() As Object Implements ISmartTagExtension.ExtensionBase
        Get
            Return (smartTagDemo)
        End Get
    End Property
End Class
using System;
using System.Windows.Forms;
using Microsoft.Office.Interop.SmartTag;
using Microsoft.Office.Tools.Word;

namespace CustomSmartTagExample
{
    public class CustomSmartTag : ISmartTagExtension
    {
        // Declare the smart tag.
        Microsoft.Office.Tools.Word.SmartTag smartTagDemo;

        // Declare actions for this smart tag.
        private Microsoft.Office.Tools.Word.Action Action1;
        private Microsoft.Office.Tools.Word.Action Action2;

        public CustomSmartTag()
        {
            this.smartTagDemo = Globals.Factory.CreateSmartTag(
                "https://www.contoso.com/Demo#DemoSmartTag", "Custom Smart Tag", this);

            Action1 = Globals.Factory.CreateAction("Display property value");
            Action2 = Globals.Factory.CreateAction("Display smart tag details");

            smartTagDemo.Terms.AddRange(new string[] { "sales", "organization" });
            smartTagDemo.Actions = new Microsoft.Office.Tools.Word.Action[] { Action1, Action2 };

            Action1.Click += new ActionClickEventHandler(Action1_Click);
            Action2.Click += new ActionClickEventHandler(Action2_Click);
        }

        void ISmartTagExtension.Recognize(string text, ISmartTagRecognizerSite site, ISmartTagTokenList tokenList, 
            SmartTagRecognizeContext context)
        {

            foreach (string term in smartTagDemo.Terms)
            {
                // Search the text for the current smart tag term.
                int index = text.IndexOf(term, 0);

                while (index >= 0)
                {
                    // Create a smart tag token and a property bag for the recognized term.
                    ISmartTagProperties propertyBag = site.GetNewPropertyBag();

                    // Write a new property value.
                    string key = "Key1";
                    propertyBag.Write(key, DateTime.Now.ToString());

                    // Attach the smart tag to the term in the document
                    context.PersistTag(index, term.Length, propertyBag);

                    // Increment the index and then find the next instance of the smart tag term.
                    index += term.Length;
                    index = text.IndexOf(term, index);
                }
            }
        }

        // This action displays the property value for the term.
        private void Action1_Click(object sender,
            Microsoft.Office.Tools.Word.ActionEventArgs e)
        {
            ISmartTagProperties propertyBag = e.Properties;
            string key = "Key1";
            MessageBox.Show("The corresponding value of " + key + " is: " + propertyBag.get_Read(key));
        }

        // This action displays smart tag details.
        private void Action2_Click(object sender,
            Microsoft.Office.Tools.Word.ActionEventArgs e)
        {
            MessageBox.Show("The current smart tag caption is '" +
                smartTagDemo.Caption + "'. The current smart tag type is '" + smartTagDemo.SmartTagType + "'.");
        }


        public Microsoft.Office.Tools.Word.SmartTag Base
        {
            get { return smartTagDemo; }
        }

        public object ExtensionBase
        {
            get { return smartTagDemo; }
        }

    }
}

Compilando o código

  • Adicionar uma referência do projeto Biblioteca de tipos do Microsoft Smart Tags 2.0 da COM guia da Add Reference caixa de diálogo. Certifique-se de que o Copy Local é de propriedade da referência da false. Se for true, a referência não é o assembly de interoperabilidade primário correto e você deve instalar o assembly da mídia de instalação Microsoft Office. For more information, see Como: Instalar Assemblies de interoperabilidade primária do Office.

  • Coloque o código de exemplo em um novo arquivo de classe é nomeado CustomSmartTag.

  • No C#, altere o namespace para coincidir com o nome do projeto.

  • Adicionar Imports (em Visual Basic) ou using (em C#) instruções para a Microsoft.Office.Tools.Word e Microsoft.Office.Interop.SmartTag namespaces no topo do arquivo de classe.

  • Adicione o seguinte código para o ThisDocument_Startup ou ThisAddIn_Startup o manipulador de eventos em seu projeto. Este código adiciona a marca inteligente personalizada ao documento.

    Me.VstoSmartTags.Add(New CustomSmartTag().Base)
    
    this.VstoSmartTags.Add(new CustomSmartTag().Base);
    

Segurança

Para executar a marca inteligente, as marcas inteligentes devem ser habilitadas no Word. For more information, see Como: Ativar marcas inteligentes no Word e Excel.

Consulte também

Tarefas

Como: Ativar marcas inteligentes no Word e Excel

Como: Adicionar marcas inteligentes em documentos do Word

Como: Adicionar marcas inteligentes para pastas de trabalho do Excel

Como: Criar marcas inteligentes com reconhecedores de personalizadas no Excel e.NET Framework 3.5

Demonstra Passo a passo: A criação de uma marca inteligente usando uma personalização em nível de documento

Demonstra Passo a passo: A criação de uma marca inteligente usando-se um suplemento em nível de aplicativo

Conceitos

Arquitetura de marcas inteligentes

Outros recursos

Visão geral sobre marcas inteligentes