柱状图

前台

<Window x:Class="VisifireShow.MainWindow"         xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"         xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"         Title="MainWindow" Height="500" Width="710">     <Grid>         <Button Content="柱状图" Name="ButColumn" HorizontalAlignment="Left" Margin="10,59,0,0" VerticalAlignment="Top" Width="75" Click="ButColumn_Click"/>         <Button Content="饼状图" x:Name="ButPie" HorizontalAlignment="Left" Margin="10,116,0,0" VerticalAlignment="Top" Width="75" Click="ButPie_Click"/>         <Button Content="折线图" x:Name="ButSpline" HorizontalAlignment="Left" Margin="10,178,0,0" VerticalAlignment="Top" Width="75" Click="ButSpline_Click" />         <Grid Name="Simon">

</Grid>     </Grid> </Window>

后台

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Input; using System.Windows.Media; using System.Windows.Media.Imaging; using System.Windows.Navigation; using System.Windows.Shapes; using Visifire.Charts;

namespace VisifireShow {     /// <summary>     /// MainWindow.xaml 的交互逻辑     /// </summary>     public partial class MainWindow : Window     {         public MainWindow()         {             InitializeComponent();         }

private List<string> strListx = new List<string>() { "苹果", "樱桃", "菠萝", "香蕉", "榴莲", "葡萄", "桃子", "猕猴桃" };         private List<string> strListy = new List<string>() { "13", "75", "60", "38", "97", "22", "39", "80" };

private List<DateTime> LsTime = new List<DateTime>()             {                new DateTime(2012,1,1),                new DateTime(2012,2,1),                new DateTime(2012,3,1),                new DateTime(2012,4,1),                new DateTime(2012,5,1),                new DateTime(2012,6,1),                new DateTime(2012,7,1),                new DateTime(2012,8,1),                new DateTime(2012,9,1),                new DateTime(2012,10,1),                new DateTime(2012,11,1),                new DateTime(2012,12,1),             };         private List<string> cherry = new List<string>() { "33", "75", "60", "98", "67", "88", "39", "45", "13", "22", "45", "80" };         private List<string> pineapple = new List<string>() { "13", "34", "38", "12", "45", "76", "36", "80", "97", "22", "76", "39" };         private void ButColumn_Click(object sender, RoutedEventArgs e)         {             //MessageBox.Show("柱状图");             Simon.Children.Clear();             CreateChartColumn("11月份水果销量", strListx, strListy);         }

private void ButPie_Click(object sender, RoutedEventArgs e)         {             Simon.Children.Clear();             CreateChartPie("11月份水果销量", strListx, strListy);         }         private void ButSpline_Click(object sender, RoutedEventArgs e)         {             Simon.Children.Clear();             CreateChartSpline("2013年樱桃、菠萝销量", LsTime, cherry, pineapple);         }         #region 柱状图         public void CreateChartColumn(string name, List<string> valuex, List<string> valuey)         {             //创建一个图标             Chart chart = new Chart();

//设置图标的宽度和高度             chart.Width = 580;             chart.Height = 380;             chart.Margin = new Thickness(100, 5, 10, 5);             //是否启用打印和保持图片             chart.ToolBarEnabled = false;

//设置图标的属性             chart.ScrollingEnabled = false;//是否启用或禁用滚动             chart.View3D = true;//3D效果显示

//创建一个标题的对象             Title title = new Title();

//设置标题的名称             title.Text = Name;             title.Padding = new Thickness(0, 10, 5, 0);

//向图标添加标题             chart.Titles.Add(title);

Axis yAxis = new Axis();             //设置图标中Y轴的最小值永远为0                       yAxis.AxisMinimum = 0;             //设置图表中Y轴的后缀                      yAxis.Suffix = "斤";             chart.AxesY.Add(yAxis);

// 创建一个新的数据线。                           DataSeries dataSeries = new DataSeries();

// 设置数据线的格式             dataSeries.RenderAs = RenderAs.StackedColumn;//柱状Stacked

// 设置数据点                          DataPoint dataPoint;             for (int i = 0; i < valuex.Count; i++)             {                 // 创建一个数据点的实例。                                   dataPoint = new DataPoint();                 // 设置X轴点                                    dataPoint.AxisXLabel = valuex[i];                 //设置Y轴点                                   dataPoint.YValue = double.Parse(valuey[i]);                 //添加一个点击事件                        dataPoint.MouseLeftButtonDown += new MouseButtonEventHandler(dataPoint_MouseLeftButtonDown);                 //添加数据点                                   dataSeries.DataPoints.Add(dataPoint);             }

// 添加数据线到数据序列。                            chart.Series.Add(dataSeries);

//将生产的图表增加到Grid,然后通过Grid添加到上层Grid.                       Grid gr = new Grid();             gr.Children.Add(chart);             Simon.Children.Add(gr);         }         #endregion

#region 饼状图         public void CreateChartPie(string name, List<string> valuex, List<string> valuey)         {             //创建一个图标             Chart chart = new Chart();

//设置图标的宽度和高度             chart.Width = 580;             chart.Height = 380;             chart.Margin = new Thickness(100, 5, 10, 5);             //是否启用打印和保持图片             chart.ToolBarEnabled = false;

//设置图标的属性             chart.ScrollingEnabled = false;//是否启用或禁用滚动             chart.View3D = true;//3D效果显示

//创建一个标题的对象             Title title = new Title();

//设置标题的名称             title.Text = name;             title.Padding = new Thickness(0, 10, 5, 0);

//向图标添加标题             chart.Titles.Add(title);

//Axis yAxis = new Axis();             ////设置图标中Y轴的最小值永远为0                       //yAxis.AxisMinimum = 0;             ////设置图表中Y轴的后缀                      //yAxis.Suffix = "斤";             //chart.AxesY.Add(yAxis);

// 创建一个新的数据线。                           DataSeries dataSeries = new DataSeries();

// 设置数据线的格式             dataSeries.RenderAs = RenderAs.Pie;//柱状Stacked

// 设置数据点                          DataPoint dataPoint;             for (int i = 0; i < valuex.Count; i++)             {                 // 创建一个数据点的实例。                                   dataPoint = new DataPoint();                 // 设置X轴点                                    dataPoint.AxisXLabel = valuex[i];

dataPoint.LegendText = "##" + valuex[i];                 //设置Y轴点                                   dataPoint.YValue = double.Parse(valuey[i]);                 //添加一个点击事件                        dataPoint.MouseLeftButtonDown += new MouseButtonEventHandler(dataPoint_MouseLeftButtonDown);                 //添加数据点                                   dataSeries.DataPoints.Add(dataPoint);             }

// 添加数据线到数据序列。                            chart.Series.Add(dataSeries);

//将生产的图表增加到Grid,然后通过Grid添加到上层Grid.                       Grid gr = new Grid();             gr.Children.Add(chart);             Simon.Children.Add(gr);         }         #endregion

#region 折线图         public void CreateChartSpline(string name, List<DateTime> lsTime, List<string> cherry, List<string> pineapple)         {             //创建一个图标             Chart chart = new Chart();

//设置图标的宽度和高度             chart.Width = 580;             chart.Height = 380;             chart.Margin = new Thickness(100, 5, 10, 5);             //是否启用打印和保持图片             chart.ToolBarEnabled = false;

//设置图标的属性             chart.ScrollingEnabled = false;//是否启用或禁用滚动             chart.View3D = true;//3D效果显示

//创建一个标题的对象             Title title = new Title();

//设置标题的名称             title.Text = name;             title.Padding = new Thickness(0, 10, 5, 0);

//向图标添加标题             chart.Titles.Add(title);

//初始化一个新的Axis             Axis xaxis = new Axis();             //设置Axis的属性             //图表的X轴坐标按什么来分类,如时分秒             xaxis.IntervalType = IntervalTypes.Months;             //图表的X轴坐标间隔如2,3,20等,单位为xAxis.IntervalType设置的时分秒。             xaxis.Interval = 1;             //设置X轴的时间显示格式为7-10 11:20                       xaxis.ValueFormatString = "MM月";             //给图标添加Axis                        chart.AxesX.Add(xaxis);

Axis yAxis = new Axis();             //设置图标中Y轴的最小值永远为0                       yAxis.AxisMinimum = 0;             //设置图表中Y轴的后缀                      yAxis.Suffix = "斤";             chart.AxesY.Add(yAxis);

// 创建一个新的数据线。                           DataSeries dataSeries = new DataSeries();             // 设置数据线的格式。                           dataSeries.LegendText = "樱桃";

dataSeries.RenderAs = RenderAs.Spline;//折线图

dataSeries.XValueType = ChartValueTypes.DateTime;             // 设置数据点                          DataPoint dataPoint;             for (int i = 0; i < lsTime.Count; i++)             {                 // 创建一个数据点的实例。                                   dataPoint = new DataPoint();                 // 设置X轴点                                    dataPoint.XValue = lsTime[i];                 //设置Y轴点                                   dataPoint.YValue = double.Parse(cherry[i]);                 dataPoint.MarkerSize = 8;                 //dataPoint.Tag = tableName.Split(‘(‘)[0];                 //设置数据点颜色                                  // dataPoint.Color = new SolidColorBrush(Colors.LightGray);                                   dataPoint.MouseLeftButtonDown += new MouseButtonEventHandler(dataPoint_MouseLeftButtonDown);                 //添加数据点                                   dataSeries.DataPoints.Add(dataPoint);             }

// 添加数据线到数据序列。                            chart.Series.Add(dataSeries);

// 创建一个新的数据线。                           DataSeries dataSeriesPineapple = new DataSeries();             // 设置数据线的格式。

dataSeriesPineapple.LegendText = "菠萝";

dataSeriesPineapple.RenderAs = RenderAs.Spline;//折线图

dataSeriesPineapple.XValueType = ChartValueTypes.DateTime;             // 设置数据点

DataPoint dataPoint2;             for (int i = 0; i < lsTime.Count; i++)             {                 // 创建一个数据点的实例。                                   dataPoint2 = new DataPoint();                 // 设置X轴点                                    dataPoint2.XValue = lsTime[i];                 //设置Y轴点                                   dataPoint2.YValue = double.Parse(pineapple[i]);                 dataPoint2.MarkerSize = 8;                 //dataPoint2.Tag = tableName.Split(‘(‘)[0];                 //设置数据点颜色                                  // dataPoint.Color = new SolidColorBrush(Colors.LightGray);                                   dataPoint2.MouseLeftButtonDown += new MouseButtonEventHandler(dataPoint_MouseLeftButtonDown);                 //添加数据点                                   dataSeriesPineapple.DataPoints.Add(dataPoint2);             }             // 添加数据线到数据序列。                            chart.Series.Add(dataSeriesPineapple);

//将生产的图表增加到Grid,然后通过Grid添加到上层Grid.                       Grid gr = new Grid();             gr.Children.Add(chart);                         Simon.Children.Add(gr);         }         #endregion

#region 点击事件         //点击事件         void dataPoint_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)         {             //DataPoint dp = sender as DataPoint;             //MessageBox.Show(dp.YValue.ToString());         }         #endregion             } }

时间: 2024-12-13 10:50:07

柱状图的相关文章

iOS:使用贝塞尔曲线绘制图表(折线图、柱状图、饼状图)

1.介绍: UIBezierPath :画贝塞尔曲线的path类 UIBezierPath定义 : 贝赛尔曲线的每一个顶点都有两个控制点,用于控制在该顶点两侧的曲线的弧度. 曲线的定义有四个点:起始点.终止点(也称锚点)以及两个相互分离的中间点. 滑动两个中间点,贝塞尔曲线的形状会发生变化. UIBezierPath :对象是CGPathRef数据类型的封装,可以方便的让我们画出 矩形 . 椭圆 或者 直线和曲线的组合形状 初始化方法: + (instancetype)bezierPath; /

折线图 饼状图 柱状图

xaml 文件 <Window x:Class="Supplier.TrendCharts" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" Title="产品价格趋势图" Height="500" Width

使用HorizontalScrollView简单实现柱状图

有个爱折腾的美工是个什么体验...那就是效果,也是,android也就是个UI,UI注重的是用户体验,良好的用户体验跟舒适的UI效果是分不开的.这次要做的效果就是,做完测试后提交的历史记录,以柱状图的形式呈现,那么把这个父布局设置成HorizontalScrollView,把树状图的滚动效果交给HorizontalScrollView,那么问题来了,HorizontalScrollView只能有一个子布局,那么就在这里面嵌套一层最好用的LinearLayout,把它的子布局方向设置成horizo

3-Highcharts 3D图之3D柱状图分组叠堆3D图

<!DOCTYPE> <html lang='en'> <head> <title>3-Highcharts 3D图之3D柱状图分组叠堆3D图</title> <meta http-equiv="content-type" content="text/html;charset=utf-8"> <script src="../jquery-2.1.4/jquery.min.js&q

android 柱状图(带动画的)

import java.util.ArrayList; import android.content.Intent; import android.os.AsyncTask; import android.os.Bundle; import android.support.v7.app.ActionBarActivity; import android.view.View; import android.view.animation.AnimationUtils; import com.gith

Echatrs柱状图的点击事件

最近在做一些图表统计的功能,用到了百度的开源图表软件Echatrs,不得不提的是:不但上手简单而且扩展功能也是十分强大.在使用的过程中也遇到了不少问题,可能由于有关Echatrs的资料并不是很齐全,所以查找资料的过程也是相当曲折的,所以还是自己就遇到的问题总结一下吧. 点击柱状图跳转页面的功能: 找到你的生成Option事件的方法,在其下面添加以下代码.             var chart = ec.init(document.getElementById(id));          

Android 如何 画 柱状图 -------自定义View

实现了 柱状图 根据 SeekBar的滑动 改变的效果: 图示效果: 自定义View的代码: package com.example.coustomviewdemo; import android.R.color; import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.g

从下往上增加的柱状图生成动画(适用于统计类应用)

我们在一些统计,理财应用中,经常能看到很多的柱状图,用来直观的标注信息,最近一个朋友刚好在做这方面的应用,跑来问我这个怎么实现,我笑他不就是简单的实现一个动画嘛,额,然后自己去做的时候才发现各种坑. 1.所有的UIView子类中,UILabel不能实现效果 2.创建View和对View实现的动画效果要放在一个方法中 3.增加的height和减少的top(顶部y坐标)必须成2倍关系 或者 增加的height和增加的bottom(底部y坐标)必须成2倍关系 @最后,直接上代码,大家可以去试验下,我也

H5柱状图2D小插件

1 概述 前端技术在代码的世界里是不可或缺的,而在里面有个东西是经常使用的那便是 js插件,作为一个小白本章节学习如何封装插件,分享下自己的小东西:如何纯js去自己去封装一个柱状图2D小插件? 2 有点low的效果图如下: 3 主要功能 支持超简单使用 支持数据类型json对象 支持设置左右边距 支持设置柱状图宽度 支持柱状图的颜色 支持动画过渡 当然也可以自己增加背景图片功能使其看起来好看一点 ...后续功能可以自己酌情添加 4实现方式 首先 ,我们需要一个容器,在这里只需要一个div就可以了

highcharts 柱状图 动态加载

highcharts柱状图动态加载 (1):导入样式 <script type="text/javascript" src="<%=request.getContextPath()%>/boot_js/jquery/jquery-1.8.3.min.js"></script><script type="text/javascript" src="<%=request.getContextP