WPF下实现堆积柱状图

VS2010下

准备依赖文件:

System.Windows.Forms.dll;

System.Windows.Forms.DataVisualization.Charting.dll;

WindowsFormIntegration.dll

MainWindow.xaml编辑如下

<Window x:Class="MainWindow.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:WinFormHost="clr-namespace:System.Windows.Forms.Integration;assembly=WindowsFormsIntegration"
    xmlns:WinFormControls="clr-namespace:System.Windows.Forms;assembly=System.Windows.Forms"
    xmlns:wfc="clr-namespace:System.Windows.Forms.DataVisualization.Charting;assembly=System.Windows.Forms.DataVisualization"
    Title="WPF Chart Demo" Width="903" Height="581">
    <Grid Name="grid1">
        
        <WindowsFormsHost Margin="0,47,0,0">
            <wfc:Chart Name="Chart1"/>
        </WindowsFormsHost>
    </Grid>
</Window>

MainWindow.xaml.cs代码如下

 private void button1_Click(object sender, RoutedEventArgs e)
        {
            
                addData();
        }


        private void addData() {

            var windowsFormsHost = (WindowsFormsHost)grid1.Children[0];

            var chart = (Chart)windowsFormsHost.Child;

            chart.Series.Clear();
            chart.ChartAreas.Clear();
            // ChartArea追加
            chart.ChartAreas.Add("ChartArea1");
            chart.ChartAreas[0].AxisX.Interval = 1;
            chart.ChartAreas[0].Axes[0].MajorGrid.Enabled = false;
            chart.ChartAreas[0].BorderColor =System.Drawing.Color.Red;

            //series的制作和值的追加
            Series seriesSin = new Series();
            seriesSin.ChartType = SeriesChartType.StackedColumn;
            seriesSin.MarkerStyle = MarkerStyle.Circle;
            

            Series seriesCos = new Series();
            seriesCos.ChartType = SeriesChartType.StackedColumn;
            seriesCos.MarkerStyle = MarkerStyle.Circle;

           string[] xValues = new string[] { "A", "B", "C", "D", "E"};    //x轴的数据
            int[,] yValues = new int[,] { { 10, 20, 30, 40, 50 }, { 20, 40, 60, 80, 100 } };    //y轴的数据

            for (int x = 1; x <= xValues.Length; x++)
            {

                seriesCos.IsValueShownAsLabel = true;
                seriesSin.IsValueShownAsLabel = true;
                seriesSin.Points.AddXY(x, x);
                seriesCos.Points.AddXY(x, x);


            }


            chart.Series.Add(seriesSin);
            chart.Series.Add(seriesCos);
        }

效果:

上述的

seriesSin.ChartType = SeriesChartType.StackedColumn;

可以设置各种的统计图表如:


更具上诉代码就可以实现;

项目和相关dll:下载

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值