Я сохранил обратный логический преобразователь, чтобы связать свойство bool с помощью переключателя. Работает нормально в первый раз. Я получил исключение переполнения стека, когда снова установил тот же экземпляр свойства модели с контекстом данных окна.
C#:
public partial class Launcher : Window,INotifyPropertyChanged
{
public Launcher()
{
InitializeComponent();
}
bool test;
public bool Test
{
get
{
return test;
}
set
{
test = value;
RaiseEvent("Test");
}
}
void RaiseEvent(string name)
{
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(name));
}
public event PropertyChangedEventHandler PropertyChanged;
private void Button_Click(object sender, RoutedEventArgs e)
{//
On first button click its work normally after close the mainwindow again click the same
button to launch the Mainwindow.
Window obj = new MainWindow();
obj.DataContext = this;
obj.ShowDialog();
}
}
public class InverseBoolConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
{
return value is bool && (bool)value ? false : true;
}
public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
{
if (value is bool)
{
return !(bool)value;
}
return value;
}
}
XAML:
<Window.Resources>
<local:InverseBoolConverter x:Key="inverse"/>
</Window.Resources>
<Grid>
<Grid.RowDefinitions>
<RowDefinition/>
<RowDefinition/>
</Grid.RowDefinitions>
<RadioButton Content="A" IsChecked="{Binding Test,Converter={StaticResource inverse}}" GroupName="A"/>
<RadioButton Content="B" Grid.Row="1" IsChecked="{Binding Test}" GroupName="A"/>
</Grid>
Посмотрите на общий код, событие щелчка по этой кнопке используется для активации главного окна. В этом случае при втором щелчке, обратное преобразование запускается несколько раз, и, наконец, результатом является исключение.