Udostępnij za pośrednictwem


Programowe używanie okien dialogowych programu Word w trybie ukrytym

Złożone operacje można wykonywać za pomocą jednego wywołania metody, wywołując wbudowane okna dialogowe w programie Microsoft Office Word bez wyświetlania ich użytkownikowi. Można to zrobić przy użyciu Execute metody Dialog obiektu bez wywoływania Display metody .

Dotyczy: informacje w tym temacie dotyczą projektów na poziomie dokumentu i projektów dodatków VSTO dla programu Word. Aby uzyskać więcej informacji, zobacz Funkcje dostępne przez aplikacja pakietu Office lication i typ projektu.

Przykłady

W poniższych przykładach kodu pokazano, jak używać okna dialogowego Ustawienia strony w trybie ukrytym, aby ustawić wiele właściwości konfiguracji strony bez danych wejściowych użytkownika. W przykładach użyto Dialog obiektu do skonfigurowania niestandardowego rozmiaru strony. Określone ustawienia konfiguracji strony, takie jak górny margines, dolny margines itd., są dostępne jako właściwości ostatnio powiązane obiektu Dialog . Te właściwości są tworzone dynamicznie przez program Word w czasie wykonywania.

W poniższym przykładzie pokazano, jak wykonać to zadanie w projektach Visual Basic, w których opcja Strict jest wyłączona i w projektach Visual C# przeznaczonych dla platformy .NET Framework 4. W tych projektach można używać funkcji późnego powiązania w kompilatorach Visual Basic i Visual C#. Aby użyć tego przykładu ThisDocument , uruchom go z klasy lub ThisAddIn w projekcie.

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();

W poniższym przykładzie pokazano, jak wykonać to zadanie w projektach Visual Basic, w których jest włączona opcja Strict . W tych projektach należy użyć odbicia, aby uzyskać dostęp do właściwości powiązanych z opóźnieniem. Aby użyć tego przykładu ThisDocument , uruchom go z klasy lub ThisAddIn w projekcie.

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