New to Telerik UI for WPF? Download free 30-day trial

Populating With Data RadPivotMap

RadPivotMap expects data in tabular format and displays a treemap with grouped data, according to the GroupDefinition-s set.

Assuming that you have the following class:

Example 1

public class TestData 
{ 
     public int Value { get; set; } 
     public string Category { get; set; } 
     public string Subcategory { get; set; } 
} 

Using the above class we can now create sample data.

Example 2

public MainWindow() 
{ 
    InitializeComponent(); 
    this.DataContext = new List<TestData>() 
    { 
        new TestData { Category = "A", Subcategory = "100", Value = 10 }, 
        new TestData { Category = "B", Subcategory = "100", Value = 25 }, 
        new TestData { Category = "C", Subcategory = "200", Value = 40 }, 
        new TestData { Category = "D", Subcategory = "200", Value = 15 }, 
        new TestData { Category = "E", Subcategory = "200", Value = 30 }, 
    }; 
} 

To bind the RadPivotMap you should use the GroupDefinition collection and add several GroupDefinitions - one for each of the properties as presented in the class. The ValuePath property specifies from where the data should be taken. We can also change the color of the groups using Colorizer.

Example 3

<Window.Resources> 
    <telerik:PaletteBrushes x:Key="PivotMapBrushes"> 
        <SolidColorBrush Color="#69C7D3" /> 
        <SolidColorBrush Color="#B1E292" /> 
        <SolidColorBrush Color="#D2B4E2" /> 
        <SolidColorBrush Color="#A2D7F0" /> 
        <SolidColorBrush Color="#E8D982" /> 
        <SolidColorBrush Color="#BBDBC6" /> 
        <SolidColorBrush Color="#B0BADB" /> 
    </telerik:PaletteBrushes>         
</Window.Resources> 
<telerik:RadPivotMap Name="treeMap1"  
                        ValuePath="Value"  
                        ItemsSource="{Binding}"> 
    <telerik:RadPivotMap.GroupDefinitions> 
        <telerik:GroupDefinition Member="Category"> 
            <telerik:GroupDefinition.Mappings> 
                <telerik:PaletteColorizer Brushes="{StaticResource PivotMapBrushes}" /> 
            </telerik:GroupDefinition.Mappings>                
        </telerik:GroupDefinition> 
        <telerik:GroupDefinition Member="SubCategory" /> 
    </telerik:RadPivotMap.GroupDefinitions> 
</telerik:RadPivotMap> 

Figure 1

Telerik WPF PivotMap

You can bind the RadPivotMap to any source that implements one of the following interfaces:

In this article