data:image/s3,"s3://crabby-images/425e4/425e4e9eaa7b9f9e18757b6286df73b59fc4d42a" alt="The life at treeview"
data:image/s3,"s3://crabby-images/46353/46353ef6ce1cdeadfcff18a8e3c4301fafbaa5b9" alt="the life at treeview the life at treeview"
Each data template only cares about its own specific hierarchy which is: The hierarchy is a function of the way the objects are structured in their parent/child relationship. Notice that we aren’t creating hierarchical templates per-se. Let’s make a simple Person class that stores a name: We just need to continue the hierarchy as we have previously in the Model and then tweak the corresponding data templates. Let’s say that we want to be able to explore the players on the team. The above therefore creates the view we originally were wanting:Īvalonia TreeView Initial Working View Adding More HierarchyĪlright, let’s say that we really want to look at the league information one layer down. Inside the block we define what we render for the current level of the hierarchy before Avalonia iterates on the children items. It has the additional ItemsSource property that we need to tell it about our hierarchy. This is is similar to the HierarchicalDataTemplate class in WPF. Therefore in its definition (lines 19-21) we use a TreeDataTemplate not DataTemplate. In this case this is the Teams property on a conference. In the case of the Conference however we need to tell it about the children object. We are going to write a TextBlock whenever the control is trying to render a Team object. In the case of the Team class (lines 22-24) it is just like our previous examples you may have seen. We use the DataType keyword to give Avalonia a hint of which type each template is to be applied to.
data:image/s3,"s3://crabby-images/63f20/63f20aedc64ee622d35fffea9faa395db7f3800b" alt="the life at treeview the life at treeview"
Let’s look at a modified version of the aboveĪs we can see we have two data templates for our two types. The TreeView control has a property called DataTemplates where we define the data templates for our items.
#The life at treeview how to
The problem is we haven’t told it how to present our items. We also aren’t seeing the teams underneath each league. So that’s not exactly satisfying is it? Yeah we have our top level leagues but it obviously doesn’t know how to present it. If we run this out of the gate we get the following in our application:
data:image/s3,"s3://crabby-images/425e4/425e4e9eaa7b9f9e18757b6286df73b59fc4d42a" alt="The life at treeview"