彩票走势图

在MVVM模式下使用C1Chart(1/2)

转帖|使用教程|编辑:龚雪|2016-01-21 09:23:04.000|阅读 233 次

概述:WPF下的C1Chart在MVVM设计模式下可以使用,这个概念的应用和您使用其它的控件一样。在ViewMode下需要暴露集合和绑定属性,然后所有的就能很容易在Chart view的XAML中设置。本文介绍在MVVM模式下绑定图表的最基本的步骤。

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>

相关链接:

<C1 Studio Enterprise下载>

WPF下的C1Chart在MVVM设计模式下可以使用,这个概念的应用和您使用其它的控件一样。在ViewMode下需要暴露集合和绑定属性,然后所有的就能很容易在Chart view的XAML中设置。本文介绍在MVVM模式下绑定图表的最基本的步骤。

首先从创建一个新的WPF应用程序开始,给项目添加如下的Sales类:

public class Sales
{
public Sales(string product,double salevalue)
{
_product = product;
_salevalue = salevalue;
}
#region privateFields
string _product;
double _salevalue;
#endregion
#region publicProperties
public string Product
{
get { return _product; }
set { _product = value; }
}
public double SaleValue
{
get { return _salevalue; }
set { _salevalue = value; }
}
#endregion
}

下一步创建ViewModelBase类,之后SalesViewModel类将继承它。ViewModelBase继承INotifyPropertyChanged接口。

public class ViewModelBase:INotifyPropertyChanged
{
#region INotifyPropertyChanged Members

public event PropertyChangedEventHandler PropertyChanged;

#endregion
public ViewModelBase()
{
}
protected void OnPropertyChanged(string property)
{
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs(property));
}
}
}

现在创建ChartViewModel。代码如下:

public class ChartViewModel:ViewModelBase
{
#region Ctor..
public ChartViewModel()
{
_saleslist = new ObservableCollection();
LoadData();

}
#endregion
#region private Fields
ObservableCollection _saleslist;
#endregion
#region publicProperties
public ObservableCollection SalesList
{
get { return _saleslist; }
set { _saleslist = value; OnPropertyChanged("SalesList");}
}
#endregion
#region privateMethods
void LoadData()
{
_saleslist.Add(new Sales("Confectionaries", 2500));
_saleslist.Add(new Sales("Plastics", 3500));
_saleslist.Add(new Sales("Electronics", 7500));
_saleslist.Add(new Sales("Produces", 800));
}
#endregion
}

在这个类中,我们简单的创建SalesList集合和导入数据。接着在MainWindow上放一个C1Chart。添加ViewMode的namespace如下所示:

xmlns:local=”clr-namespace:C1ChartMVVMSample.ViewModel”

创建一个ChartViewModel资源如下:

<Window.Resources>
<local:ChartViewModel x:Key="vm"/>
</Window.Resources>

设置含有图表的控件的datacontext如下:

DataContext="{StaticResource vm}"

设置图表的datacontext如下:

DataContext="{Binding Path=SalesList}"

设置ChartData的ItemNameBinding到Sales类的Product字段如下:

ItemNameBinding="{Binding Path=Product}"

给Sales类的SaleValue field设置图表的DataSeries的ValueBinding。

ValueBinding="{Binding Path=SaleValue}"

如上是所有需要做的事情。完整的MainWindowXAML代码如下:

<Window x:Class="C1ChartMVVMSample.MainWindow"
xmlns="//schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="//schemas.microsoft.com/winfx/2006/xaml"
Title="MainWindow" Height="350" Width="525"
xmlns:loacl="clr-namespace:C1ChartMVVMSample.ViewModel"
xmlns:c1chart="//schemas.componentone.com/xaml/c1chart">
<Window.Resources>
<loacl:ChartViewModel x:Key="vm"/>
</Window.Resources>
<Grid DataContext="{StaticResource vm}">
<c1chart:C1Chart Height="256" HorizontalAlignment="Left" Margin="22,26,0,0" Name="c1Chart1" VerticalAlignment="Top" Width="469" DataContext="{Binding Path=SalesList}" Theme="{DynamicResource {ComponentResourceKey ResourceId=MediaPlayer, TypeInTargetAssembly=c1chart:C1Chart}}">
<c1chart:C1Chart.Data>
<c1chart:ChartData ItemNameBinding="{Binding Path=Product}">
<c1chart:DataSeries Label="Product" ValueBinding="{Binding Path=SaleValue}" ItemsSource="{Binding}" />

</c1chart:ChartData>
</c1chart:C1Chart.Data>
<c1chart:C1ChartLegend DockPanel.Dock="Right" />
</c1chart:C1Chart>
</Grid>
</Window>

在ViewModel的构造器里导入数据,在chart的设计时就可以可见了。本文设计的Demo如下所示:

PS: 关于ComponentOne,这些产品你可以关注>>
本文转载自
葡萄城经典UI产品新年大促,惊喜折扣礼品送不停!优惠详情点击查看>>
新年新禧新气象,送礼送福送优惠!优惠详情点击查看>>

标签:WPF用户界面控件ComponentOneMVVM

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@cahobeh.cn

文章转载自:慧都控件网

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP