Data Source Providers

So far, we've been dealing with simple, hardcoded objects. However, objects can come from long operations for which we'd prefer not to wait, like over a network connection or as translated from XML or relational data. For these cases, we'd really like a layer of indirection for pulling objects from other sources and even pushing that work off to a worker thread if said retrieval is a ponderous operation. For this indirection, we turn to data source providers, whose job is (as the name suggests) to provide data sources for use in binding scenarios.

Object Data Provider

WPF ships with two data source providers, both derived from the DataSourceProvider base class: ObjectDataProvider and XmlDataProvider. Data source providers create a layer of indirection for any kind of operation that produces objects against which to data-bind. For example, if we wanted to load a set of Person objects over the Web, we could encapsulate that logic into a bit of code, as shown in Example 7-29.

Example 7-29. A type to be used by ObjectDataProvider

...
public class Person : INotifyPropertyChanged {...}
public class People : ObservableCollection<Person> {}

public class RemotePeopleLoader {
  // ObjectDataProvider will expose results for binding
  public People LoadPeople(  ) {
    // Load people from afar
    People people = new People(  );
    ...
    return people;
  }
}
...

In Example 7-29, the RemotePeopleLoader class exposes a method (LoadPeople) that will load people however it feels and return that data ...

Get Programming WPF, 2nd Edition now with the O’Reilly learning platform.

O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.