没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
转帖|使用教程|编辑:龚雪|2016-01-21 09:23:04.000|阅读 233 次
概述:WPF下的C1Chart在MVVM设计模式下可以使用,这个概念的应用和您使用其它的控件一样。在ViewMode下需要暴露集合和绑定属性,然后所有的就能很容易在Chart view的XAML中设置。本文介绍在MVVM模式下绑定图表的最基本的步骤。
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
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如下所示:
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@wqylolg.cn
文章转载自:慧都控件网本文将手把手教你如何用VMProtect对这一关键函数进行虚拟化保护,大幅提升代码安全性,让逆向工程攻击者无从下手!
在 PDF 文档中添加页眉和页脚有助于保持一致的版式和专业的外观。本文将介绍如何使用 Spire.PDF for Java,通过 Java 在现有的 PDF 文档中添加页眉和页脚,并提供详细的步骤和代码示例。
对于开发人员来说,由于自动化和定制化,通常首选使用编程方法来去除 PDF 中的水印。Aspose.PDF 提供可靠且可定制的解决方案,可无缝集成到各种应用程序中,确保准确性并保持文档完整性。
在 Web 环境中,将 PDF 转换为 HTML 有助于提升内容的可访问性和交互性。本文将介绍如何在 React 中使用 JavaScript 和 Spire.PDF for JavaScript 库将 PDF 转换为 HTML。
行业认可的优秀Visual Studio控件集,涵盖信息系统开发所需的全部功能。
ComponentOne Studio for WPF它的网格、日程安排、图表、报表等控件都拥有先进的数据绑定功能和丰富的数据显示效果
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@wqylolg.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢