title | ms.custom | ms.date | ms.reviewer | ms.suite | ms.technology | ms.tgt_pltfrm | ms.topic | helpviewer_keywords | ms.assetid | caps.latest.revision | ms.author | manager | translation.priority.mt | |||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Options and Options Pages | Microsoft Docs |
11/04/2016 |
|
article |
|
e6c0e636-5ec3-450e-b395-fc4bb9d75918 |
34 |
gregvanl |
ghogen |
|
Clicking Options on the Tools menu opens the Options dialog box. The options in this dialog box are collectively referred to as options pages. The tree control in the navigation pane includes options categories, and every category has options pages. When you select a page, its options appear in the right pane. These pages let you change the values of the options that determine the state of a VSPackage.
The xref:Microsoft.VisualStudio.Shell.Package class provides support for creating options pages and options categories. The xref:Microsoft.VisualStudio.Shell.DialogPage class implements an options page.
The default implementation of xref:Microsoft.VisualStudio.Shell.DialogPage offers its public properties to a user in a generic grid of properties. You can customize this behavior by overriding various methods on the page to create a custom options page that has its own user interface (UI). For more information, see Creating an Options Page.
The xref:Microsoft.VisualStudio.Shell.DialogPage class implements xref:Microsoft.VisualStudio.Shell.IProfileManager, which provides persistence for options pages and also for user settings. The default implementations of the xref:Microsoft.VisualStudio.Shell.IProfileManager.LoadSettingsFromStorage%2A and xref:Microsoft.VisualStudio.Shell.IProfileManager.SaveSettingsToStorage%2A methods persist property changes into a user section of the registry if the property can be converted to and from a string.
By default, the registry path of the properties managed by an options page is determined by combining xref:Microsoft.VisualStudio.Shell.Package.UserRegistryRoot%2A, the word DialogPage, and the type name of the options page class. For example, an options page class might be defined as follows.
[!code-csVSSDKSupportForOptionsPages#1] [!code-vbVSSDKSupportForOptionsPages#1]
If the xref:Microsoft.VisualStudio.Shell.Package.UserRegistryRoot%2A is HKEY_CURRENT_USER\Software\Microsoft\VisualStudio\8.0Exp, then the property name and value pairs are subkeys of HKEY_CURRENT_USER\Software\Microsoft\VisualStudio\8.0Exp\DialogPage\Company.OptionsPage.OptionsPageGeneral.
The registry path of the options page itself is determined by combining xref:Microsoft.VisualStudio.Shell.Package.ApplicationRegistryRoot%2A, the word, ToolsOptionsPages, and the options page category and name. For example, if the Custom options page has the category, My Option Pages, and the xref:Microsoft.VisualStudio.Shell.Package.ApplicationRegistryRoot%2A is HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\VisualStudio\8.0Exp, then the options page has the registry key, HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\VisualStudio\8.0Exp\ToolsOptionsPages\My Option Pages\Custom.
The xref:Microsoft.VisualStudio.Shell.ProvideOptionPageAttribute attribute determines the grouping of custom options pages into categories in the navigation tree of the Options dialog box. The xref:Microsoft.VisualStudio.Shell.ProvideOptionPageAttribute attribute associates an options page with the VSPackage that provides the interface. Consider the following code fragment:
[!code-csVSSDKSupportForOptionsPages#2] [!code-vbVSSDKSupportForOptionsPages#2]
This declares that MyPackage provides two options pages, OptionsPageGeneral and OptionsPageCustom. In the Options dialog box, both options pages appear in the My Option Pages category as General and Custom, respectively.
The user interface (UI) that the page provides determines the appearance of options in a custom options page. The layout, labeling, and description of options in a generic options page are determined by the following attributes:
-
xref:System.ComponentModel.CategoryAttribute determines the category of the option.
-
xref:System.ComponentModel.DisplayNameAttribute determines the display name of the option.
-
xref:System.ComponentModel.DescriptionAttribute determines the description of the option.
[!NOTE] Equivalent attributes, SRCategory, LocDisplayName, and SRDescription, use string resources for localization and are defined in the managed project sample.
Consider the following code fragment:
[!code-csVSSDKSupportForOptionsPages#3] [!code-vbVSSDKSupportForOptionsPages#3]
The OptionInteger option appears on the options page as Integer Option in the My Options category. If the option is selected, the description, My integer option, appears in the description box.
A VSPackage that hosts and manages an options page can be programmatically accessed from another VSPackage by using the automation model. For example, in the following code a VSPackage is registered as hosting an option page.
[!code-csVSSDKSupportForOptionsPages#4] [!code-vbVSSDKSupportForOptionsPages#4]
The following code fragment gets the value of OptionInteger from MyOptionPage:
[!code-csVSSDKSupportForOptionsPages#5] [!code-vbVSSDKSupportForOptionsPages#5]
When the xref:Microsoft.VisualStudio.Shell.ProvideOptionPageAttribute attribute registers an options page, the page is registered under the AutomationProperties key if the SupportsAutomation
argument of the attribute is true
. Automation examines this registry entry to find the associated VSPackage, and automation then accesses the property through the hosted options page, in this case, My Grid Page.
The registry path of the automation property is determined by combining xref:Microsoft.VisualStudio.Shell.Package.ApplicationRegistryRoot%2A, the word, AutomationProperties, and the options page category and name. For example, if the options page has the My Category category, the My Grid Page name, and the xref:Microsoft.VisualStudio.Shell.Package.ApplicationRegistryRoot%2A, HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\VisualStudio\8.0Exp, then the automation property has the registry key, HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\VisualStudio\8.0Exp\AutomationProperties\My Category\My Grid Page.
Note
The canonical name, My Category.My Grid Page, is the value of the Name subkey of this key.