選択したラジオボタンに基づく表示のコントロール
-
20-08-2019 - |
質問
私は3つのラジオボタンのグループを持っています。テキストボックス、ドロップダウンリスト、またはボタン - 選択されたラジオボタンに応じて、私は3つのコントロールの1 disaplyたいです。どのように私は、選択したラジオボタンの結果に基づいてコントロールを表示しますか?
解決
あなたはBooleanToVisibilityConverter
を使用して、ラジオボタンのにisCheckedプロパティにコントロールの可視性をバインドすることができます:
<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ます:
ソリューションは素晴らしい作品と、それは実装が簡単だということ。とにかく、私はデザインモードで隠れているからコントロールが防ぐことができていますか?
私は他のデザイナー(例えばブレンド)について知らないが、Visual Studioのデザイナでコントロールが隠されることはありません...
とにかく、あなたは常にデザインモードで可視返す独自のコンバータを実装することができます。いくつかのあいまいな理由で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"/>
所属していません StackOverflow