using ObservableCollections; using R3; using System; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Collections.Specialized; using System.Diagnostics; using System.Linq; using System.Text; using System.Threading; using System.Threading.Tasks; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Input; using System.Windows.Media; using System.Windows.Media.Imaging; using System.Windows.Navigation; using System.Windows.Shapes; using System.Windows.Threading; namespace WpfApp { /// /// Interaction logic for MainWindow.xaml /// public partial class MainWindow : Window { //ObservableList list; //public INotifyCollectionChangedSynchronizedView ItemsView { get; set; } public MainWindow() { InitializeComponent(); R3.WpfProviderInitializer.SetDefaultObservableSystem(x => { Trace.WriteLine(x); }); this.DataContext = new ViewModel(); // Dispatcher.BeginInvoke( //list = new ObservableList(); //list.AddRange(new[] { 1, 10, 188 }); //ItemsView = list.CreateSortedView(x => x, x => x, comparer: Comparer.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 observableList { get; } = new ObservableList(); public INotifyCollectionChangedSynchronizedViewList ItemsView { get; } public ReactiveCommand AddCommand { get; } = new ReactiveCommand(); public ReactiveCommand AddRangeCommand { get; } = new ReactiveCommand(); public ReactiveCommand InsertAtRandomCommand { get; } = new ReactiveCommand(); public ReactiveCommand RemoveAtRandomCommand { get; } = new ReactiveCommand(); public ReactiveCommand RemoveRangeCommand { get; } = new ReactiveCommand(); public ReactiveCommand ClearCommand { get; } = new ReactiveCommand(); public ReactiveCommand ReverseCommand { get; } = new ReactiveCommand(); public ReactiveCommand SortCommand { get; } = new ReactiveCommand(); public ReactiveCommand AttachFilterCommand { get; } = new ReactiveCommand(); public ReactiveCommand ResetFilterCommand { get; } = new ReactiveCommand(); public ViewModel() { observableList.Add(1); observableList.Add(2); var view = observableList.CreateView(x => x); //ItemsView = view.ToNotifyCollectionChanged(); ItemsView = observableList.ToNotifyCollectionChanged(); // check for optimize list // ItemsView = observableList.ToNotifyCollectionChanged(SynchronizationContextCollectionEventDispatcher.Current); AddCommand.Subscribe(_ => { // ThreadPool.QueueUserWorkItem(_ => { observableList.Add(Random.Shared.Next()); } }); AddRangeCommand.Subscribe(_ => { var xs = Enumerable.Range(1, 5).Select(_ => Random.Shared.Next()).ToArray(); observableList.AddRange(xs); }); InsertAtRandomCommand.Subscribe(_ => { var from = Random.Shared.Next(0, view.Count); observableList.Insert(from, Random.Shared.Next()); }); RemoveAtRandomCommand.Subscribe(_ => { var from = Random.Shared.Next(0, view.Count); observableList.RemoveAt(from); }); RemoveRangeCommand.Subscribe(_ => { observableList.RemoveRange(2, 5); }); ClearCommand.Subscribe(_ => { observableList.Clear(); }); ReverseCommand.Subscribe(_ => { observableList.Reverse(); }); SortCommand.Subscribe(_ => { observableList.Sort(); }); AttachFilterCommand.Subscribe(_ => { view.AttachFilter(x => x % 2 == 0); }); ResetFilterCommand.Subscribe(_ => { view.ResetFilter(); }); } } public class WpfDispatcherCollection(Dispatcher dispatcher) : ICollectionEventDispatcher { public void Post(CollectionEventDispatcherEventArgs ev) { dispatcher.InvokeAsync(() => { ev.Invoke(); }); } } }