Partilhar via


Como usar caixas de diálogo do Word no modo Oculto programaticamente

Você pode executar operações complexas com o uma chamada de método chamando as caixas de diálogo internas no Microsoft Office Word sem exibi-las para o usuário.Você pode fazer isso usando o método de Execute do objeto de Dialog sem chamar o método de Display .

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 2013 e Word 2010. Para obter mais informações, consulte Recursos disponíveis pelo aplicativo do Office e o tipo de projeto.

Exemplos

Os exemplos de código a seguir demonstram como usar a caixa de diálogo de Configurar página no modo oculto para definir várias propriedades de configuração de página sem a entrada do usuário.os exemplos usam um objeto de Dialog para configurar um tamanho de página personalizado.As configurações específicas para uma configuração de página, como a margem superior, margem inferior, e assim por diante, estão disponíveis como propriedades de associação tardia de Dialog objeto.Essas propriedades são criados dinamicamente por palavra em tempo de execução.

O exemplo a seguir demonstra como executar esta tarefa em projetos do Visual Basic Option Strict de onde está fora e visual C# se projetos que tem como alvo .NET Framework 4.Em esses projetos, você pode usar recursos de associação tardia no Visual Basic compiladores e visual C#.Para usar este exemplo, ele execução da classe de ThisDocument ou de ThisAddIn em seu projeto.

Dim dialog As Word.Dialog = Application.Dialogs.Item(Word.WdWordDialog.wdDialogFilePageSetup)

' Set the properties of the dialog box.
' ControlChars.Quote() is used to represent the symbol for inches.
With dialog
    .PageWidth = 3.3 & ControlChars.Quote
    .PageHeight = 6 & ControlChars.Quote
    .TopMargin = 0.71 & ControlChars.Quote
    .BottomMargin = 0.81 & ControlChars.Quote
    .LeftMargin = 0.66 & ControlChars.Quote
    .RightMargin = 0.66 & ControlChars.Quote
    .HeaderDistance = 0.28 & ControlChars.Quote
    .Orientation = Word.WdOrientation.wdOrientPortrait
    .DifferentFirstPage = False
    .FirstPage = 0
    .OtherPages = 0

    ' Apply these settings only to the current selection with this line of code:
    .ApplyPropsTo = 3

    ' Apply the settings.
    .Execute()
End With
dynamic dialog = Application.Dialogs[Word.WdWordDialog.wdDialogFilePageSetup];
dialog.PageWidth = "3.3\"";
dialog.PageHeight = "6\"";
dialog.TopMargin = "0.71\"";
dialog.BottomMargin = "0.81\"";
dialog.LeftMargin = "0.66\"";
dialog.RightMargin = "0.66\"";
dialog.HeaderDistance = "0.28\"";
dialog.Orientation = "0";
dialog.DifferentFirstPage = "0";
dialog.FirstPage = "0";
dialog.OtherPages = "0";

// Apply these settings only to the current selection with this line of code:
dialog.ApplyPropsTo = "3";

// Apply the settings.
dialog.Execute(); 

O exemplo a seguir demonstra como executar esta tarefa em projetos do Visual Basic Option Strict onde está ativado.Em esses projetos, você deve usar o reflexo para acessar as propriedades de associação tardia.Para usar este exemplo, ele execução da classe de ThisDocument ou de ThisAddIn em seu projeto.

Friend Sub PageSetupDialogHidden()
    Dim dialog As Word.Dialog = Application.Dialogs.Item(Word.WdWordDialog.wdDialogFilePageSetup)

    ' Set the properties of the dialog box.
    ' ControlChars.Quote() is used to represent the symbol for inches.
    InvokeHelper(dialog, "PageWidth", "3.3" & ControlChars.Quote)
    InvokeHelper(dialog, "PageHeight", "6" & ControlChars.Quote)
    InvokeHelper(dialog, "TopMargin", "0.71" & ControlChars.Quote)
    InvokeHelper(dialog, "BottomMargin", "0.81" & ControlChars.Quote)
    InvokeHelper(dialog, "LeftMargin", "0.66" & ControlChars.Quote)
    InvokeHelper(dialog, "RightMargin", "0.66" & ControlChars.Quote)
    InvokeHelper(dialog, "HeaderDistance", "0.28" & ControlChars.Quote)
    InvokeHelper(dialog, "Orientation", "0")
    InvokeHelper(dialog, "DifferentFirstPage", "0")
    InvokeHelper(dialog, "FirstPage", "0")
    InvokeHelper(dialog, "OtherPages", "0")

    ' Apply these settings only to the current selection with this line of code:
    InvokeHelper(dialog, "ApplyPropsTo", "3")

    ' Apply the settings.
    dialog.Execute()
End Sub

Private Shared Sub InvokeHelper(ByVal dialog As Word.Dialog, ByVal member As String, ByVal value As String)
    Dim dialogType As System.Type = GetType(Word.Dialog)

    ' Set the appropriate property of the dialog box.
    dialogType.InvokeMember(member,
        System.Reflection.BindingFlags.SetProperty Or
            System.Reflection.BindingFlags.Public Or
            System.Reflection.BindingFlags.Instance,
        Nothing, dialog, New Object() {value},
        System.Globalization.CultureInfo.InvariantCulture)
End Sub

Consulte também

Referência

Reflexão (C# e Visual Basic)

Conceitos

Como usar caixas de diálogo integradas no Word programaticamente

Ligação tardia em soluções do Office

Outros recursos

Visão geral do modelo de objeto do Word