Visualizzazione dei controlli in base al pulsante di opzione selezionato
-
20-08-2019 - |
Domanda
Ho un gruppo di tre pulsanti di opzione. A seconda del pulsante di opzione selezionato, desidero disabilitare uno dei tre controlli: una casella di testo, un elenco a discesa o un pulsante. Come posso visualizzare i controlli in base al risultato di un pulsante di opzione selezionato?
Soluzione
Puoi associare la visibilità del controllo alla proprietà IsChecked di RadioButton, usando BooleanToVisibilityConverter
:
<Page
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
<Page.Resources>
<BooleanToVisibilityConverter x:Key="convVisibility"/>
</Page.Resources>
<Grid>
<StackPanel Orientation="Vertical">
<RadioButton Name="radioButton1" GroupName="group1">Control1</RadioButton>
<RadioButton Name="radioButton2" GroupName="group1">Control2</RadioButton>
<RadioButton Name="radioButton3" GroupName="group1">Control3</RadioButton>
<Grid>
<Button Visibility="{Binding IsChecked, ElementName=radioButton1, Converter={StaticResource convVisibility}}">1. Button</Button>
<TextBlock Visibility="{Binding IsChecked, ElementName=radioButton2, Converter={StaticResource convVisibility}}">2. TextBlock</TextBlock>
<TextBox Visibility="{Binding IsChecked, ElementName=radioButton3, Converter={StaticResource convVisibility}}">3. TextBox</TextBox>
</Grid>
</StackPanel>
</Grid>
</Page>
EDIT:
Quelle soluzioni funzionano alla grande ed è semplice da implementare. Posso comunque impedire che i controlli vengano nascosti in modalità progettazione?
Non conosco altri designer (Blend per esempio), ma nel designer di Visual Studio i controlli non sono mai nascosti ...
Ad ogni modo, potresti implementare il tuo convertitore, che restituirà sempre Visibile in modalità progettazione. Per qualche oscura ragione la classe BooleanToVisibilityConverter è sigillata, quindi non puoi ereditarla. Puoi invece delegare la conversione a un BooleanToVisibilityConverter, se non vuoi riscrivere la logica di conversione:
public class MyBooleanToVisibilityConverter : IValueConverter
{
private BooleanToVisibilityConverter _converter = new BooleanToVisibilityConverter();
private DependencyObject _dummy = new DependencyObject();
private bool DesignMode
{
get
{
return DesignerProperties.GetIsInDesignMode(_dummy);
}
}
#region IValueConverter Members
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
if (DesignMode)
return Visibility.Visible;
else
return _converter.Convert(value, targetType, parameter, culture);
}
public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
return _converter.ConvertBack(value, targetType, parameter, culture);
}
#endregion
}
Altri suggerimenti
Per mantenere visibile il componente durante la fase di progettazione è possibile aggiungere un FallbackValue
di true
alla casella di controllo come:
<RadioButton x:Name="cbxEmail" Content="Email Details" IsEnabled="{Binding IsEmail, FallbackValue=true}" IsChecked="{Binding IsEmail, Mode=OneWay, FallbackValue=true}"
Grid.Column="2"/>