Your Privacy Matters: We use our own and third-party cookies to improve your experience on our website. By continuing to use the website we understand that you accept their use. Cookie Policy
100
Bind chart to Observable Collection in Xaml
posted

Hi

I'm looking for an example of binding an observable collection to a Chart in xaml.

This is an app i'm playing around with and it supplies its data to the view using the MVVM pattern.  For the life of me i cannot find an example of how to do this.  Any example i come across has data hard coded into the xaml which i find really annoying - why not use northwind/adventureworks to show these examples?

I have a observable collection with products and quantities all i want to do is show the quantities for each product on a chart.  This will work if i just bind the itemsource of the chart to the observable collection.  but i want to show the product name along the x-axis and also in the legend.

Can anyone give me an example?

Thanks
Paul 

Parents
No Data
Reply
  • 28496
    Suggested Answer
    Offline posted

    here is a simple example of binding a series to an ObservableCollection in XAML.

            <igCA:XamChart Name="xamChart1">
                <igCA:XamChart.Series>
                    <igCA:Series ChartType="Column" DataMapping="Label=ProductName;Value=Quantity;">
                        <igCA:Series.DataSource>
                            <local:MyData />
                        </igCA:Series.DataSource>
                    </igCA:Series>
                </igCA:XamChart.Series>
            </igCA:XamChart>

        public class MyData : ObservableCollection<Product>
        {
            public MyData()
                : base()
            {
                this.Add(new Product() { ProductName = "Product A", Quantity = 1 });
                this.Add(new Product() { ProductName = "Product B", Quantity = 2 });
                this.Add(new Product() { ProductName = "Product C", Quantity = 3 });
                this.Add(new Product() { ProductName = "Product D", Quantity = 4 });
            }
        }
        public class Product
        {
            public string ProductName { get; set; }
            public int Quantity { get; set; }
        }

Children