共用方式為


自訂工作窗格

工作窗格是使用者介面面板,通常停駐在 Microsoft Office 應用程式視窗的某一側。自訂工作窗格為您提供建立個人專屬工作窗格的方法,也為使用者提供了熟悉的介面,供他們用來存取您方案的功能。例如,介面中可以包含控制項,而這些控制項則會執行程式碼來修改文件或顯示資料來源中的資料。

**適用於:**本主題中的資訊適用於 Outlook 2013 和 Outlook 2010 的應用程式層級專案。如需詳細資訊,請參閱依 Office 應用程式和專案類型提供的功能

注意事項注意事項

自訂工作窗格與執行窗格不同;而執行窗格則屬於 Microsoft Office Word 和 Microsoft Office Excel 之文件層級自訂的一部分。如需詳細資訊,請參閱執行窗格概觀

自訂工作窗格的優點

自訂工作窗格可以讓您將功能整合成熟悉的使用者介面。您可以利用 Visual Studio 工具快速建立自訂工作窗格。

Aa942864.collapse_all(zh-tw,VS.110).gif熟悉的使用者介面

Microsoft Office System 應用程式的使用者已經十分熟悉工作窗格的用法,例如 Word 中的 [樣式與格式] 工作窗格。自訂工作窗格的行為與 Microsoft Office System 的其他工作窗格相同。使用者可以讓自訂工作窗格停駐在應用程式視窗的不同側,也可以將自訂工作窗格拖曳到視窗中的任何位置。您可以建立同時顯示多個自訂工作窗格的增益集,而且使用者可以個別控制每個工作窗格。

Aa942864.collapse_all(zh-tw,VS.110).gifWindows Form 支援

您以 Visual Studio 中的 Office 開發工具建立的自訂工作窗格使用者介面是以 Windows Forms 控制項為基礎。您可以使用熟悉的 Windows Form 設計工具設計自訂工作窗格的使用者介面,也可以使用 Windows Form 中的資料繫結 (Data Binding) 支援,將資料來源繫結至工作窗格上的控制項。

建立自訂工作窗格

您可以利用下列兩個步驟建立基本的自訂工作窗格:

  1. 將 Windows Form 控制項加入至 UserControl 物件,以建立自訂工作窗格的使用者介面。

  2. 將使用者控制項傳遞給增益集中的 CustomTaskPaneCollection 物件,以執行個體化自訂工作窗格。這個集合會傳回可以用來修改工作窗格外觀以及回應使用者事件的新 CustomTaskPane 物件。

如需詳細資訊,請參閱HOW TO:在應用程式中加入自訂工作窗格

Aa942864.collapse_all(zh-tw,VS.110).gif建立使用者介面

所有以 Visual Studio 中的 Office 開發工具建立的自訂工作窗格都會包含 UserControl 物件。這個使用者控制項提供了自訂工作窗格的使用者介面。您可以在設計階段或執行階段建立此使用者控制項。如果您在設計階段建立此使用者控制項,可以使用 Windows Form 設計工具建構工作窗格的使用者介面。

Aa942864.collapse_all(zh-tw,VS.110).gif具現化自訂工作窗格

建立包含自訂工作窗格使用者介面的使用者控制項之後,您必須具現化 CustomTaskPane。如果要進行具現化,請呼叫其中一個 Add 方法,以便將使用者控制項傳遞至增益集中的 CustomTaskPaneCollection。此集合會公開 (Expose) 為 ThisAddIn 類別的 CustomTaskPanes 欄位。下列程式碼範例適合從 ThisAddIn 類別執行。

myUserControl1 = New MyUserControl
myCustomTaskPane = Me.CustomTaskPanes.Add(myUserControl1, "My Task Pane")
myCustomTaskPane.Visible = True
myUserControl1 = new MyUserControl();
myCustomTaskPane = this.CustomTaskPanes.Add(myUserControl1, "My Task Pane");
myCustomTaskPane.Visible = true;

Add 方法會傳回新的 CustomTaskPane 物件。您可以使用這個物件修改工作窗格的外觀,並回應使用者事件。

Aa942864.collapse_all(zh-tw,VS.110).gif在多個視窗中控制工作窗格

自訂工作窗格會與文件框架視窗產生關聯,而該框架視窗會對使用者呈現文件或項目的檢視。看得見相關聯的視窗時才看得見工作窗格。

若要判斷顯示自訂工作窗格的視窗,當您建立工作窗格時,請使用適當的 Add 方法多載:

當有多個視窗開啟時,有些 Office 應用程式對於何時建立或顯示您的工作窗格需要獲得明確的指示。因此一定要考慮在何處具現化程式碼中的自訂工作窗格,以確保工作窗格會在應用程式中顯示適當的文件或項目。如需詳細資訊,請參閱 在應用程式視窗中管理自訂工作窗格。

從工作窗格存取應用程式

如果您要從使用者控制項自動化應用程式,可以使用程式碼中的 Globals.ThisAddIn.Application 直接存取物件模型。靜態 Globals 類別會提供對 ThisAddIn 物件的存取。這個物件的 Application 欄位為應用程式之物件模型的進入點 (Entry Point)。

如需 ThisAddIn 物件之 Application 欄位的詳細資訊,請參閱應用程式層級增益集程式設計。如需示範如何從自訂工作窗格自動化應用程式的逐步解說,請參閱逐步解說:運用自訂工作窗格自動化應用程式。如需 Globals 類別的詳細資訊,請參閱全域存取 Office 專案中的物件

管理工作窗格的使用者介面

在您建立工作窗格之後,可以使用 CustomTaskPane 物件的屬性和事件來控制工作窗格的使用者介面,以及在使用者變更工作窗格時予以回應。

Aa942864.collapse_all(zh-tw,VS.110).gif顯示自訂工作窗格

根據預設,工作窗格為隱藏狀態。若要顯示工作窗格,您必須將 Visible 設定為 true。

使用者也可以按一下工作窗格角落的 [關閉] 按鈕 (X),隨時關閉工作窗格。但是,無法透過任何預設方法再次開啟自訂工作窗格。如果使用者關閉了自訂工作窗格,除非您提供顯示工作窗格的方法,否則使用者將無法再次檢視該自訂工作窗格。

如果在增益集中建立自訂工作窗格,則應同時建立 UI 項目,例如使用者可以按一下來顯示或隱藏自訂工作窗格的按鈕。如果您在支援自訂功能區的 Microsoft Office 應用程式中建立自訂工作窗格,可以將控制項群組加入至其按鈕可顯示或隱藏自訂工作窗格的功能區。如需示範如何這麼做的逐步解說,請參閱逐步解說:使用功能區按鈕同步處理自訂工作窗格

如果您在不支援自訂功能區的 Microsoft Office 應用程式中建立自訂工作窗格,則可加入用來顯示或隱藏自訂工作窗格的 CommandBarButton

Aa942864.collapse_all(zh-tw,VS.110).gif修改工作窗格的外觀

您可以使用 CustomTaskPane 物件的屬性,控制自訂工作窗格的大小和位置。您還可以使用包含在自訂工作窗格內之 UserControl 物件的屬性,對自訂工作窗格的外觀進行其他多項變更。例如,您可以使用使用者控制項的 BackgroundImage 屬性,指定自訂工作窗格的背景影像。

下表列出可以使用 CustomTaskPane 屬性進行的自訂工作窗格變更。

工作

屬性

若要變更工作窗格的大小

Height

Width

若要變更工作窗格的位置

DockPosition

若要隱藏或顯示工作窗格

Visible

若要避免使用者變更工作窗格的位置

DockPositionRestrict

Aa942864.collapse_all(zh-tw,VS.110).gif進行自訂工作窗格事件的程式設計

您可能希望增益集能夠在使用者修改自訂工作窗格時做出回應。例如,如果使用者將窗格從垂直方向改成水平方向,您可能會想要重新調整控制項的位置。

下表列出您可以處理的事件,以回應使用者對自訂工作窗格所進行的變更。

工作

事件

若要在使用者變更工作窗格的位置時回應。

DockPositionChanged

若要在使用者隱藏或顯示工作窗格時回應。

VisibleChanged

清除工作窗格所使用的資源

在您建立自訂工作窗格之後,只要增益集在執行中,CustomTaskPane 物件就會留在記憶體中。甚至在使用者按一下工作窗格角落的 [關閉] 按鈕 (X) 後,此物件仍會留在記憶體中。

若要在增益集仍執行時清除工作窗格使用的資源,請使用 RemoveRemoveAt 方法。這些方法會從 CustomTaskPanes 集合中移除指定的 CustomTaskPane 物件,並且呼叫該物件的 Dispose 方法。

當增益集卸載時,Visual Studio Tools for Office Runtime 會自動清除自訂工作窗格使用的資源。請不要在專案的 ThisAddIn_Shutdown 事件處理常式中呼叫 RemoveRemoveAt 方法。這些方法會擲回 ObjectDisposedException,因為 Visual Studio Tools for Office Runtime 會在呼叫 ThisAddIn_Shutdown 之前先清除 CustomTaskPane 物件使用的資源。如需 ThisAddIn_Shutdown 的詳細資訊,請參閱Office 專案中的事件

在多個應用程式視窗中管理自訂工作窗格

在使用多重視窗的應用程式中建立自訂工作窗格以顯示文件和其他項目時,需要採取額外步驟以確保工作窗格能夠在使用者需要時顯示。

所有應用程式中的自訂工作窗格會與文件框架視窗產生關聯,而該框架視窗會對使用者呈現文件或項目的檢視。看得見相關聯的視窗時才看得見工作窗格。但是,並非所有使用應用程式都以相同方式來使用文件框架視窗。

下列應用程式群組具有不同的開發需求:

  • Outlook

  • Word、InfoPath 和 PowerPoint

視訊的連結 如需觀看相關示範影片,請參閱如何:管理 Word 增益集中的工作窗格?(英文)。

Outlook

當您建立 Outlook 的自訂工作窗格時,自訂工作窗格將與特定檔案總管或偵測器視窗相關聯。檔案總管視窗可顯示資料夾內容,而偵測器視窗則會顯示電子郵件訊息或工作之類的項目。

如果要在多個檔案總管或偵測器視窗中顯示自訂工作窗格,您需要在檔案總管或偵測器視窗開啟時,建立自訂工作窗格的新執行個體。若要這麼做,請在建立檔案總管或偵測器視窗時處理引發的事件,然後在事件處理常式中建立工作窗格。您也可以處理檔案總管與偵測器事件,以依據可見的視窗來隱藏或顯示工作窗格。

若要將工作窗格與特定檔案總管或偵測器產生關聯,請使用 CustomTaskPaneCollection.Add(UserControl, String, Object)方法來建立工作窗格,並將 ExplorerInspector 物件傳遞給 window 參數。如需建立自訂工作窗格的詳細資訊,請參閱自訂工作窗格

如需如何為每個開啟的電子郵件訊息建立工作窗格的逐步示範,請參閱逐步解說:在 Outlook 中的電子郵件訊息顯示自訂工作窗格

Aa942864.collapse_all(zh-tw,VS.110).gifOutlook 事件

若要監視 [檔案總管] 視窗的狀態,可以處理下列與 [檔案總管] 相關的事件:

若要監視 [偵測器] 視窗的狀態,可以處理下列與 [偵測器] 相關的事件:

Aa942864.collapse_all(zh-tw,VS.110).gif避免在 Outlook 中顯示自訂工作窗格的多個執行個體

若要避免 Outlook 視窗顯示自訂工作窗格的多個執行個體,請在關閉每個視窗時,從 ThisAddIn 類別的 CustomTaskPanes 集合中明確移除自訂工作窗格。請在視窗關閉時所引發的事件 (例如 ExplorerEvents_10_Event.CloseInspectorEvents_10_Event.Close) 中呼叫 Remove 方法。

如果您沒有明確移除自訂工作窗格,Outlook 視窗可能會顯示自訂工作窗格的多個執行個體。Outlook 有時會回收視窗,而回收的視窗會保留對其附加之任何自訂工作窗格的參考。

Word、InfoPath 和 PowerPoint

Word、InfoPath 和 PowerPoint 中顯示不同的文件框架視窗中每個文件。當您建立這些應用程式的自訂工作窗格時,自訂工作窗格只會與特定文件相關聯。如果使用者開啟不同的文件,則自訂工作窗格會等到先前的文件重新顯示之後才會取消隱藏。

如果要在多份文件中顯示自訂工作窗格,可以在使用者建立新文件或開啟現有文件時,建立自訂工作窗格的新執行個體。若要這麼做,請在建立或開啟文件時處理引發的事件,然後在事件處理常式中建立工作窗格。您也可以處理文件事件,依據可見的文件來隱藏或顯示工作窗格。

若要使工作窗格與特定文件視窗產生關聯,請使用 CustomTaskPaneCollection.Add(UserControl, String, Object) 方法來建立工作窗格和傳遞 Microsoft.Office.Interop.Word.Window (適用於 Word), Microsoft.Office.Interop.InfoPath.WindowObject (適用於 InfoPath),或者 Microsoft.Office.Interop.PowerPoint.DocumentWindow (適用於 PowerPoint) 到 window 參數。

Aa942864.collapse_all(zh-tw,VS.110).gifWord 事件

若要在 Word 中監視文件視窗的狀態,可以處理下列事件:

Aa942864.collapse_all(zh-tw,VS.110).gifInfoPath 事件

若要在 InfoPath 中監視文件視窗的狀態,可以處理下列事件:

Aa942864.collapse_all(zh-tw,VS.110).gifPowerPoint 事件

若要監視文件視窗的狀態在 PowerPoint,可以處理下列事件:

請參閱

工作

HOW TO:在應用程式中加入自訂工作窗格

逐步解說:運用自訂工作窗格自動化應用程式

逐步解說:使用功能區按鈕同步處理自訂工作窗格

逐步解說:在 Outlook 中的電子郵件訊息顯示自訂工作窗格