У меня есть группа из трех переключателей. В зависимости от того, какой переключатель выбран, я хочу отключить один из трех элементов управления - текстовое поле, раскрывающийся список или кнопку. Как отображать элементы управления на основе результата выбранного переключателя?
Отображение элементов управления на основе выбранной радиокнопки
Ответы (2)
Вы можете привязать видимость элемента управления к свойству IsChecked RadioButton, используя 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>
РЕДАКТИРОВАТЬ :
Эти решения отлично работают, и их легко реализовать. Есть ли способ предотвратить скрытие элементов управления в режиме разработки?
Я не знаю о других дизайнерах (например, Blend), но в дизайнере Visual Studio элементы управления никогда не скрываются ...
В любом случае, вы можете реализовать свой собственный конвертер, который всегда будет возвращать Visible в режиме разработки. По какой-то непонятной причине класс BooleanToVisibilityConverter запечатан, поэтому вы не можете наследовать от него. Вместо этого вы можете делегировать преобразование BooleanToVisibilityConverter, если не хотите переписывать логику преобразования:
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
}
Чтобы компонент оставался видимым во время разработки, вы можете добавить FallbackValue
из true
к флажку как:
<RadioButton x:Name="cbxEmail" Content="Email Details" IsEnabled="{Binding IsEmail, FallbackValue=true}" IsChecked="{Binding IsEmail, Mode=OneWay, FallbackValue=true}"
Grid.Column="2"/>