Réponses:
En effet, il y a :
System.ComponentModel.DesignerProperties.GetIsInDesignMode
Exemple:
using System.ComponentModel;
using System.Windows;
using System.Windows.Controls;
public class MyUserControl : UserControl
{
public MyUserControl()
{
if (DesignerProperties.GetIsInDesignMode(this))
{
// Design-mode specific functionality
}
}
}
Enable project code
doit être activé (ou Menu-> Design-> 🗹 Run Project Code).
Dans certains cas, j'ai besoin de savoir si un appel à ma classe non-UI est lancé par le concepteur (comme si je crée une classe DataContext à partir de XAML). Ensuite, l'approche de cet article MSDN est utile:
// Check for design mode.
if ((bool)(DesignerProperties.IsInDesignModeProperty.GetMetadata(typeof(DependencyObject)).DefaultValue))
{
//in Design mode
}
Pour tous les contrôles WPF hébergés dans WinForms , DesignerProperties.GetIsInDesignMode(this)
ne fonctionne pas.
J'ai donc créé un bogue dans Microsoft Connect et ajouté une solution de contournement:
public static bool IsInDesignMode()
{
if ( System.Reflection.Assembly.GetExecutingAssembly().Location.Contains( "VisualStudio" ) )
{
return true;
}
return false;
}
GetEntryAssembly()
place de GetExecutingAssembly()
? Ce dernier devrait renvoyer l'assemblage où cette propriété est définie
Réponse tardive, je sais - mais pour tous ceux qui souhaitent utiliser ceci dans un DataTrigger
, ou n'importe où dans XAML en général:
xmlns:componentModel="clr-namespace:System.ComponentModel;assembly=PresentationFramework"
<Style.Triggers>
<DataTrigger Binding="{Binding RelativeSource={RelativeSource Self},
Path=(componentModel:DesignerProperties.IsInDesignMode)}"
Value="True">
<Setter Property="Visibility" Value="Visible"/>
</DataTrigger>
</Style.Triggers>
Utilisez celui-ci:
if (Windows.ApplicationModel.DesignMode.DesignModeEnabled)
{
//design only code here
}
(Les opérations Async et File ne fonctionneront pas ici)
En outre, pour instancier un objet au moment du design en XAML (d est l'espace de noms du concepteur spécial)
<Grid d:DataContext="{d:DesignInstance Type=local:MyViewModel, IsDesignTimeCreatable=True}">
...
</Grid>
Windows.ApplicationModel
) est destinée aux applications Store, incluses dans l'API Windows Runtime. Ce n'est pas une solution WPF prête à l'emploi si vous travaillez uniquement sur une application de bureau Windows standard.