Skip to content

Latest commit

 

History

History
36 lines (27 loc) · 2.19 KB

File metadata and controls

36 lines (27 loc) · 2.19 KB

Using Events to communicate

Events is a publisher-subscriber way of communicating. One view model has an event that another view model can subscribe to. When the first view model invoke the event, the second view model will run its code.

Note: When dealing with events, one should always unsubscribe to the events. Failing to do so can lead to memory leaks.

The idea

MainViewModel is the glue between IFriendsViewModel and IHairColorCountingViewModel. So, each IFriendViewModel has to tell MainViewModel that its hair color has changed, that way it can tell HairColorCountingViewModel to reevaluate.

FriendViewModel should have an event that MainViewModel can assign code that can reevaluate hair color.

How did I implement it?

For each FriendViewModel I have added a HairColorChangedEvent. The event gets invoked in the HairColor setter (that will run each time the user chooses a hair color).

The MainViewModel assigns the event for each friend after it has retrieved all the friends. It assigns the event with the code that evaluates the hair color counter.

MainVieWModel has also implemented IDisposable and a Dispose method. This method de-assigns the event for each of the friends. Dispose will be called by MainWindow.xaml.cs from a Closed event assignment.

Summary

Using events is a fairly straight forward way of implementing communication. Disposing the events are important, and this can be hard to remember when working with a large project.

One of the reasons why I really do not like event is that you get no references from code vision. This means it can be hard to follow the flow of events. One would need to search for the event in the entire code base in order to understand what gets called when. Sending arguments also needs some additional work.