Add ChangeKind.Clear but may needs more

This commit is contained in:
neuecc 2024-02-21 19:50:09 +09:00
parent bdbb5c0c76
commit 3a4ef7e1f0
7 changed files with 95 additions and 43 deletions

View File

@ -81,6 +81,9 @@ class HogeFilter : ISynchronizedViewFilter<int, ViewModel>
case ChangedKind.Move: case ChangedKind.Move:
view.Value += $" Move {eventArgs.OldStartingIndex} {eventArgs.NewStartingIndex}"; view.Value += $" Move {eventArgs.OldStartingIndex} {eventArgs.NewStartingIndex}";
break; break;
case ChangedKind.Clear:
view.Value += $" Clear";
break;
default: default:
throw new ArgumentOutOfRangeException(nameof(changedKind), changedKind, null); throw new ArgumentOutOfRangeException(nameof(changedKind), changedKind, null);
} }

View File

@ -6,15 +6,19 @@
xmlns:local="clr-namespace:WpfApp" xmlns:local="clr-namespace:WpfApp"
mc:Ignorable="d" mc:Ignorable="d"
Title="MainWindow" Height="450" Width="800"> Title="MainWindow" Height="450" Width="800">
<Grid> <!--<Grid>
<Grid.ColumnDefinitions> <Grid.ColumnDefinitions>
<ColumnDefinition /> <ColumnDefinition />
<ColumnDefinition /> <ColumnDefinition />
</Grid.ColumnDefinitions> </Grid.ColumnDefinitions>
<ListView ItemsSource="{Binding ItemsView}"></ListView> <ListView ItemsSource="{Binding ItemsView}"></ListView>
<Button Grid.Column="1" Click="Button_Click">Insert</Button> <Button Grid.Column="1" Click="Button_Click">Insert</Button>
</Grid> </Grid>-->
<StackPanel>
<ListBox ItemsSource="{Binding ItemsView}" />
<Button Content="Clear" Command="{Binding ClearCommand}" />
</StackPanel>
</Window> </Window>

View File

@ -1,6 +1,8 @@
using ObservableCollections; using ObservableCollections;
using R3;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Diagnostics;
using System.Linq; using System.Linq;
using System.Text; using System.Text;
using System.Threading; using System.Threading;
@ -22,38 +24,72 @@ namespace WpfApp
/// </summary> /// </summary>
public partial class MainWindow : Window public partial class MainWindow : Window
{ {
ObservableList<int> list; //ObservableList<int> list;
public INotifyCollectionChangedSynchronizedView<int> ItemsView { get; set; } //public INotifyCollectionChangedSynchronizedView<int> ItemsView { get; set; }
public MainWindow() public MainWindow()
{ {
InitializeComponent(); InitializeComponent();
this.DataContext = this;
R3.WpfProviderInitializer.SetDefaultObservableSystem(x =>
{
Trace.WriteLine(x);
});
this.DataContext = new ViewModel();
list = new ObservableList<int>(); //list = new ObservableList<int>();
list.AddRange(new[] { 1, 10, 188 }); //list.AddRange(new[] { 1, 10, 188 });
ItemsView = list.CreateSortedView(x => x, x => x, comparer: Comparer<int>.Default).ToNotifyCollectionChanged(); //ItemsView = list.CreateSortedView(x => x, x => x, comparer: Comparer<int>.Default).ToNotifyCollectionChanged();
//BindingOperations.EnableCollectionSynchronization(ItemsView, new object());
}
//int adder = 99;
//private void Button_Click(object sender, RoutedEventArgs e)
//{
// ThreadPool.QueueUserWorkItem(_ =>
// {
// list.Add(adder++);
// });
//}
//protected override void OnClosed(EventArgs e)
//{
// ItemsView.Dispose();
//}
}
public class ViewModel
{
private ObservableList<int> observableList { get; } = new ObservableList<int>();
public INotifyCollectionChangedSynchronizedView<int> ItemsView { get; }
public ReactiveCommand<Unit> ClearCommand { get; } = new ReactiveCommand<Unit>();
public ViewModel()
{
observableList.Add(1);
observableList.Add(2);
ItemsView = observableList.CreateView(x => x).ToNotifyCollectionChanged();
BindingOperations.EnableCollectionSynchronization(ItemsView, new object()); BindingOperations.EnableCollectionSynchronization(ItemsView, new object());
}
int adder = 99; // var iii = 10;
ClearCommand.Subscribe(_ =>
private void Button_Click(object sender, RoutedEventArgs e)
{
ThreadPool.QueueUserWorkItem(_ =>
{ {
list.Add(adder++); // observableList.Add(iii++);
observableList.Clear();
}); });
} }
protected override void OnClosed(EventArgs e)
{
ItemsView.Dispose();
}
} }
} }

View File

@ -10,6 +10,12 @@
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<PackageReference Include="R3" Version="1.0.4" />
<PackageReference Include="R3Extensions.WPF" Version="1.0.4" />
</ItemGroup>
<ItemGroup>
<ProjectReference Include="..\..\src\ObservableCollections.R3\ObservableCollections.R3.csproj" />
<ProjectReference Include="..\..\src\ObservableCollections\ObservableCollections.csproj" /> <ProjectReference Include="..\..\src\ObservableCollections\ObservableCollections.csproj" />
</ItemGroup> </ItemGroup>

View File

@ -12,7 +12,7 @@ namespace ObservableCollections
public enum ChangedKind public enum ChangedKind
{ {
Add, Remove, Move Add, Remove, Move, Clear
} }
public class SynchronizedViewFilter<T, TView> : ISynchronizedViewFilter<T, TView> public class SynchronizedViewFilter<T, TView> : ISynchronizedViewFilter<T, TView>
@ -106,6 +106,11 @@ namespace ObservableCollections
filter.OnCollectionChanged(ChangedKind.Move, value, view, eventArgs); filter.OnCollectionChanged(ChangedKind.Move, value, view, eventArgs);
} }
internal static void InvokeOnClear<T, TView>(this ISynchronizedViewFilter<T, TView> filter, in NotifyCollectionChangedEventArgs<T> eventArgs)
{
filter.OnCollectionChanged(ChangedKind.Clear, default!, default!, eventArgs);
}
internal static void InvokeOnAttach<T, TView>(this ISynchronizedViewFilter<T, TView> filter, T value, TView view) internal static void InvokeOnAttach<T, TView>(this ISynchronizedViewFilter<T, TView> filter, T value, TView view)
{ {
if (filter.IsMatch(value, view)) if (filter.IsMatch(value, view))

View File

@ -75,6 +75,10 @@ namespace ObservableCollections.Internal
case ChangedKind.Move: case ChangedKind.Move:
CollectionChanged?.Invoke(this, new NotifyCollectionChangedEventArgs(NotifyCollectionChangedAction.Move, view, eventArgs.NewStartingIndex, eventArgs.OldStartingIndex)); CollectionChanged?.Invoke(this, new NotifyCollectionChangedEventArgs(NotifyCollectionChangedAction.Move, view, eventArgs.NewStartingIndex, eventArgs.OldStartingIndex));
break; break;
case ChangedKind.Clear:
PropertyChanged?.Invoke(this, CountPropertyChangedEventArgs);
CollectionChanged?.Invoke(this, new NotifyCollectionChangedEventArgs(NotifyCollectionChangedAction.Reset));
break;
default: default:
throw new ArgumentOutOfRangeException(nameof(changedKind), changedKind, null); throw new ArgumentOutOfRangeException(nameof(changedKind), changedKind, null);
} }

View File

@ -210,34 +210,28 @@ namespace ObservableCollections
break; break;
case NotifyCollectionChangedAction.Replace: case NotifyCollectionChangedAction.Replace:
// ObservableList does not support replace range // ObservableList does not support replace range
{ {
var v = (e.NewItem, selector(e.NewItem)); var v = (e.NewItem, selector(e.NewItem));
var oldItem = list[e.NewStartingIndex]; var oldItem = list[e.NewStartingIndex];
list[e.NewStartingIndex] = v; list[e.NewStartingIndex] = v;
filter.InvokeOnRemove(oldItem, e); filter.InvokeOnRemove(oldItem, e);
filter.InvokeOnAdd(v, e); filter.InvokeOnAdd(v, e);
break; break;
} }
case NotifyCollectionChangedAction.Move: case NotifyCollectionChangedAction.Move:
{ {
var removeItem = list[e.OldStartingIndex]; var removeItem = list[e.OldStartingIndex];
list.RemoveAt(e.OldStartingIndex); list.RemoveAt(e.OldStartingIndex);
list.Insert(e.NewStartingIndex, removeItem); list.Insert(e.NewStartingIndex, removeItem);
filter.InvokeOnMove(removeItem, e); filter.InvokeOnMove(removeItem, e);
} }
break; break;
case NotifyCollectionChangedAction.Reset: case NotifyCollectionChangedAction.Reset:
if (!filter.IsNullFilter())
{
foreach (var item in list)
{
filter.InvokeOnRemove(item, e);
}
}
list.Clear(); list.Clear();
filter.InvokeOnClear(e);
break; break;
default: default:
break; break;