Partager via


Pages de propriétés

Les utilisateurs peuvent afficher et modifier le projet selon la configuration et - les propriétés indépendantes l'aide de pages de propriétés. Un bouton de Pages de propriétés est activé dans la fenêtre de Propriétés ou dans la barre d'outils de l'explorateur de solutions pour les objets qui fournissent une vue de la page de propriétés de l'objet sélectionné. Les pages de propriétés sont créées par l'environnement et sont disponibles pour des solutions et des projets. Ils peuvent, toutefois, également être rendu disponible pour les éléments de projet qui utilisent des propriétés de configuration. Cette fonction peut être utilisée lorsque les fichiers dans un projet requièrent plusieurs paramètres de commutateur de compilation pour générer correctement.

Utilisation des pages de propriétés

Si une page de propriétés est déjà affichée et les modifications de sélection (par exemple, d'une solution à un projet), les informations affichées dans les pages sont modifiés pour afficher les propriétés de la nouvelle sélection. S'il n'y a aucune propriété de l'objet qui prennent en charge les pages de propriétés, la page de propriétés est vide.

Si plusieurs objets sont sélectionnés, la page de propriétés affiche l'intersection des propriétés pour toutes les options sélectionnées. Si l'élément sélectionné ne contient pas les propriétés de configuration et le bouton de Pages de propriétés dans la barre d'outils de l'explorateur de solutions est activé, le focus est modifié dans la fenêtre Propriétés. Pour plus d'informations sur la fenêtre Propriétés et la sélection, consultez fenêtre Propriétés et pages de propriétés.

Si les propriétés sont affichées pour plusieurs objets et vous modifiez une valeur dans une page de propriétés, toutes les valeurs pour les objets sont définis avec la nouvelle valeur même si elles étaient initialement différentes et la page était l'espace lorsque différentes propriétés de l'objet était restitué.

Il existe deux types généraux de boîtes de dialogue de ProjetPages de propriétés disponibles dans Visual Studio. Dans le premier, pour les projets Visual Basic, par exemple, les pages de propriétés sont affichées en utilisant un format de champ, comme indiqué dans la capture d'écran suivante. Dans la deuxième, indiqué plus loin dans cette section, la page de propriétés héberge une grille de propriétés similaire à celle située dans la fenêtre Propriétés.

Boîte de dialogue pages de propriétés du projet au format et l'arborescence de champ

Pages de propriétés Visual Basic

L'arborescence dans la boîte de dialogue pages de propriétés n'est pas générée à IVsHierarchy. L'environnement, selon le nom de niveau passé par ISpecifyPropertyPages et les interfaces d' IVsPropertyPage , le génère l'erreur.

Il n'existe que deux catégories de niveau supérieur disponibles sur les pages de propriétés de Visual Studio :

  • Propriétés communes, qui affiche des informations pas liées de l'objet ou les objets sélectionnés. En conséquence, lorsque l'un des sous-catégories des propriétés communes est sélectionné, les options de configuration, de plateforme, et du gestionnaire de configurations entre le haut de la boîte de dialogue sont pas disponibles.

  • Propriétés de configuration, qui contient les informations dépendantes de la configuration concernant les paramètres de débogage, d'optimisation, et de génération de la solution ou le projet.

Vous ne pouvez créer des catégories de niveau supérieur supplémentaires, mais vous pouvez choisir de ne pas afficher un ou l'autre dans votre implémentation d' IVsPropertyPage. Si, par exemple, vous n'avez aucune propriété configuration-indépendante à afficher pour un objet, vous pouvez choisir de ne pas afficher la catégorie de propriétés communes. Vous affichez les propriétés communes si ISpecifyPropertyPages est implémenté de l'élément parcourent l'objet et les propriétés de configuration lorsque vous implémentez ISpecifyPropertyPages dans l'objet de configuration (objet qui implémente IVsCfg, IVsProjectCfg, et les interfaces connexes).

chaque catégorie affichée sous une catégorie de niveau supérieur représente une page de propriétés distincte. Les entrées de catégorie et de sous-catégorie disponibles dans la boîte de dialogue sont déterminées par votre implémentation d' ISpecifyPropertyPages et d' IVsPropertyPage.

les objets d'IDispatch pour les éléments du conteneur de sélection qui ont des propriétés à afficher dans les pages de propriétés implémentent ISpecifyPropertyPages pour énumérer une liste des ID de classe. Les ID de classe sont passés en tant que variables à ISpecifyPropertyPages et sont utilisés pour instancier les pages de propriétés. La liste des ID de classe est également passé à IVsPropertyPage pour créer l'arborescence le à gauche de la boîte de dialogue. Les pages de propriétés passent ensuite les informations vers l'objet d' IDispatch qui implémente ISpecifyPropertyPages et fournit les informations pour chaque page.

Les propriétés de l'objet de parcourir sont récupérées à l'aide de IDispatch pour chaque objet dans le conteneur de sélection.

Implémenter Help::DisplayTopicFromF1Keyword dans votre VSPackage fournit les fonctionnalités pour le bouton d'aide.

Pour plus d'informations, consultez IDispatch et l' ISpecifyPropertyPagesdans MSDN Library.

Le second type de pages de propriétés affichées dans les exemples héberge un formulaire de la grille des propriétés, comme indiqué dans la capture d'écran suivante.

Boîte de dialogue pages de propriétés avec la grille des propriétés

Pages de propriétés VC

les interfaces IVSMDPropertyBrowser et IVSMDPropertyGrid (déclarés dans vsmanaged.h) sont utilisées pour créer et remplir la grille des propriétés dans une boîte de dialogue ou une fenêtre.

L'architecture des projets a changé considérablement les versions précédentes de Visual Studio. En particulier, la notion dont le projet est actif a changé. Dans Visual Studio, aucun concept d'un projet actif. Dans les environnements de développement précédents, le projet actif était le projet qui génère et de déployer des commandes auraient par défaut indépendamment du contexte. Maintenant, la solution contrôle et arbitre qui génèrent et de déployer des commandes s'appliquent à quels projets.

Ce qui était précédemment un projet actif est maintenant capturé de trois façons différentes :

  • Le projet de démarrage

    Vous pouvez spécifier un projet ou des projets de la page de propriétés de la solution qui sera lancée lorsque l'utilisateur appuie sur F5 ou sélectionne le passage du menu de génération. Cela fonctionne de manière semblable au projet actif ancien dans le sens que son nom est affiché dans l'explorateur de solutions avec la police de caractère grasse.

    Vous pouvez extraire le projet de démarrage en tant que propriété dans le modèle Automation en appelant DTE.Solution.SolutionBuild.StartupProjects. dans un VSPackage, vous appelez l' get_StartupProject ou les méthodes d' get_StartupProject . IVsSolutionBuildManager est disponible en tant que service par QueryService sur SID_SVsSolutionBuildManager. Pour plus d'informations, consultez objet de configuration de projet et configuration de solution.

  • Configuration de build de solution active

    Visual Studio possède une configuration de solution active, disponible dans le modèle Automation en implémentant DTE.Solution.SolutionBuild.ActiveConfiguration. Une configuration de solution est une collection qui contient une configuration de projet pour chaque projet dans la solution (chaque projet peut avoir plusieurs configurations, sur plusieurs plateformes, avec des noms différents). Pour plus d'informations sur les pages de propriétés de la solution, consultez configuration de solution.

  • projet actuellement sélectionné

    Implémentez la méthode d' GetCurrentSelection pour récupérer la hiérarchie de projet et l'élément de projet ou les éléments sélectionnés. DTE, vous devez utiliser les méthodes d' SelectedItems.SelectedItem.Project et d' SelectedItems.SelectedItem.ProjectItem . Il existe exemple de code dans ces titres dans des documents de Visual Studio .

Voir aussi

Référence

IVsPropertyPage

Concepts

objet de configuration de projet

configuration de solution

Autres ressources

gérer des options de configuration