WPF - RadioButton에 대한 데이터바인딩(2)
RadioButton에 대해서 직접 데이터바인딩을 하는 경우, 중간에 풀려버리는 이슈에 대해서 지난번에 이미 소개해드렸지요.
WPF - RadioButton 데이터 바인딩 해제 현상
; https://www.sysnet.pe.kr/2/0/609
해결책도 같이 제시해드리긴 했지만, 사실 별로 마음에 들진 않습니다. 왜냐하면, 단순히 RadioButton만 나열하면 될 것을, 복잡하게 ListBox로 정의하면서 그에 대한 템플릿까지 정의하려니 다루기가 별로 깔끔하지 않다는 것이죠.
그래서 좀 더 고민해 본 결과, 좀 더 간단하게 구현할 수 있는 방법을 찾았습니다.
물론, 다른 사람들이 이미 고민한 내용이지요.
WPF RadioButtons and data binding
; http://geekswithblogs.net/claraoscura/archive/2008/10/17/125901.aspx
위의 사람이 제시한 방법은 바로... ^^ 그룹 이름을 달리하는 것입니다. 즉 아래와 같은 식이지요.
<Window x:Class="WpfApplication1.Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:my="clr-namespace:WpfApplication1" x:Name="My" Width="100" Height="100">
<StackPanel ToggleButton.Checked="GroupBox_Checked" DataContext="{Binding Path=DisplayData, ElementName=My}">
<RadioButton GroupName="g1" IsChecked="{Binding Path=Radio1}"
Name="radioButton1">test1</RadioButton>
<RadioButton GroupName="g2" IsChecked="{Binding Path=Radio2}"
Name="radioButton2">test2</RadioButton>
<RadioButton GroupName="g3" IsChecked="{Binding Path=Radio3}"
Name="radioButton3">test3</RadioButton>
</StackPanel>
</Window>
그래도, ListView 컨트롤을 쓰는 것보다는 확실히 소스크기가 줄어듭니다. 하지만, 예상하시겠지만 서로 다른 그룹이름으로 인해서 체크박스가 별도로 동작하게 되어 체크가 배타적으로 이뤄지지 않습니다. 그래서 위의 소스 코드에 ToggleButton.Checked를 연결해서 다음과 같은 동작을 연결시켜 줘야 합니다.
private void GroupBox_Checked(object sender, RoutedEventArgs e)
{
RadioButton source = e.Source as RadioButton;
StackPanel stackPanel = sender as StackPanel;
foreach (RadioButton btn in stackPanel.Children)
{
if (source.Content.ToString().Equals(btn.Content.ToString(),
StringComparison.OrdinalIgnoreCase) == true)
{
continue;
}
btn.IsChecked = false;
}
}
그래도 정형화된 틀로 사용되어질 수 있으니 이렇게 처리하는 것도 그다지 나빠보이지는 않습니다. 여러분들은... 어느 쪽을 선택하시겠어요? ^^
첨부된 프로젝트는 위의 소스 코드를 테스트한 것입니다.
[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]