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