Compare commits
1 Commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
3a4ef7e1f0 |
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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>
|
||||||
|
@ -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(_ =>
|
// observableList.Add(iii++);
|
||||||
{
|
observableList.Clear();
|
||||||
list.Add(adder++);
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void OnClosed(EventArgs e)
|
|
||||||
{
|
|
||||||
ItemsView.Dispose();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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>
|
||||||
|
|
||||||
|
@ -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))
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -230,14 +230,8 @@ namespace ObservableCollections
|
|||||||
}
|
}
|
||||||
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;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user