當前位置: 首頁>>代碼示例>>C#>>正文


C# Chart.DataBind方法代碼示例

本文整理匯總了C#中System.Windows.Forms.DataVisualization.Charting.Chart.DataBind方法的典型用法代碼示例。如果您正苦於以下問題:C# Chart.DataBind方法的具體用法?C# Chart.DataBind怎麽用?C# Chart.DataBind使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在System.Windows.Forms.DataVisualization.Charting.Chart的用法示例。


在下文中一共展示了Chart.DataBind方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: SaveChart

        private static void SaveChart(List<double> requestTimes, TimeSpan totalTime, double minTime, double maxTime, double avgTime)
        {
            DataSet dataSet = new DataSet();
            DataTable dt = new DataTable();
            dt.Columns.Add("Seconds", typeof(int));
            dt.Columns.Add("RequestCount", typeof(int));

            Dictionary<int, int> timeTable = new Dictionary<int, int>();

            List<DataRow> rows = new List<DataRow>();
            List<int> intTimes = requestTimes.OrderBy(t => t).Select(t => (int)Math.Round(t/1000)).ToList();

            foreach (int time in intTimes)
            {
                DataRow row = rows.FirstOrDefault(r => ((int)r[0]) == time);

                if (row == null)
                {
                    row = dt.NewRow();
                    row[0] = time;
                    row[1] = 0;
                    rows.Add(row);
                }

                row[1] = ((int)row[1]) + 1;
            }

            rows.ForEach(r => dt.Rows.Add(r));

            dataSet.Tables.Add(dt);

            Chart chart = new Chart();
            chart.DataSource = dataSet.Tables[0];
            chart.Width = 900;
            chart.Height = 500;

            Series series = new Series();
            series.Name = "Serie1";
            series.Color = Color.FromArgb(220, 0, 27);
            series.ChartType = SeriesChartType.Column;
            series.ShadowOffset = 0;
            series.IsValueShownAsLabel = true;
            series.XValueMember = "Seconds";
            series.YValueMembers = "RequestCount";
            series.Font = new Font(series.Font.FontFamily, 10);
            chart.Series.Add(series);

            ChartArea ca = new ChartArea();
            ca.Name = "ChartArea1";
            ca.BackColor = Color.White;
            ca.BorderWidth = 0;
            ca.AxisX = new Axis();
            ca.AxisY = new Axis();
            ca.AxisX.Title = "Time (seconds)";
            Font f = ca.AxisX.TitleFont;
            ca.AxisX.TitleFont = new Font(f.FontFamily, 12, f.Style);
            ca.AxisY.Title = "Request count";
            ca.AxisY.TitleFont = ca.AxisX.TitleFont;
            ca.AxisX.MajorGrid.LineColor = Color.LightGray;
            ca.AxisY.MajorGrid.LineColor = ca.AxisX.MajorGrid.LineColor;
            chart.ChartAreas.Add(ca);

            chart.Titles.Add("Requests times");
            chart.Titles[0].Font = ca.AxisX.TitleFont;
            chart.Titles.Add(GetChartDescriptionString(totalTime, minTime, maxTime, avgTime));
            chart.Titles[1].Font = new Font(chart.Titles[1].Font.FontFamily, 10);

            chart.DataBind();

            int i = 0;
            string fileName = "";

            //loop until you find a free file name (in case multiple instances are running at the same time)
            do
            {
                fileName = string.Format("chart-{0}.png", i++);
            }
            while(File.Exists(fileName));

            chart.SaveImage(fileName, ChartImageFormat.Png);
        }
開發者ID:dland512,項目名稱:loadrunnerx,代碼行數:81,代碼來源:Program.cs

示例2: chartdatatable

        private void chartdatatable(DataTable dt, Chart Chart1)
        {
            Chart1.Series.Clear();
            Chart1.DataSource = dt;
            string serieName = "";
            int amountofrows = Convert.ToInt32(dt.Rows.Count);
            List<string> xvals = new List<string>();
            List<double> yvals = new List<double>();

            foreach (DataColumn column in dt.Columns)
            {
                xvals.Add(column.ColumnName);

            }
            int i = 1;
            foreach (DataRow row in dt.Rows)
            {
                serieName = "Simulation" + i;
                Chart1.Series.Add(serieName);
                Chart1.Series[serieName].ChartType = SeriesChartType.Line;
                //       List<double> yvals = new List<double>();
                foreach (DataColumn column in dt.Columns)
                {
                    yvals.Add(Convert.ToDouble(row[column]));
                }
                try//add the newly created sereies...
                {
                    Chart1.Series[serieName].XValueType = ChartValueType.String;
                    Chart1.Series[serieName].YValueType = ChartValueType.Auto;
                    Chart1.Series[serieName].Points.DataBindXY(xvals.ToArray(), yvals.ToArray());
                    yvals.Clear();
                }
                catch (Exception)
                {

                    throw new InvalidOperationException("Kunde inte bind punkterna till Diagrammet");
                }

                i++;
            }

            Chart1.DataBind();
            Chart1.Visible = true;
        }
開發者ID:seanclogher,項目名稱:Modelling-Tool,代碼行數:44,代碼來源:frmModellingTool.cs

示例3: BuildChart

        public void BuildChart(string fileName, IEnumerable<PieChartItem> data, PieChartContext context)
        {
            if (data == null || data.Count() == 0)
                throw new System.FormatException("There is not data to plot.");

            using (var targetChart = new Chart()) {

                ChartArea mainChartArea = new ChartArea("MainArea");
                targetChart.ChartAreas.Add(mainChartArea);
                targetChart.ChartAreas[0].Area3DStyle.Enable3D = context.Show3DStyle;

                ChartHelper.InitializeChart(targetChart, context.ImageSize);

                if (!string.IsNullOrWhiteSpace(context.Title)) {

                    targetChart.Titles.Add(new Title(context.Title, Docking.Top,
                                                     new System.Drawing.Font(context.TitleFontName,
                                                                             context.TitleFontSize,
                                                                             System.Drawing.FontStyle.Bold),
                                                                             context.TitleFontColor));
                }

                targetChart.Series.Add(context.Title);
                targetChart.Series[0].XValueMember = "Label";
                targetChart.Series[0].YValueMembers = "Value";
                targetChart.DataSource = data;

                targetChart.Series[0].IsVisibleInLegend = true;
                targetChart.Series[0].ChartType = SeriesChartType.Pie;

                targetChart.Series[0].LegendText = "#VALX";

                // https://technet.microsoft.com/en-us/library/dd239373.aspx
                switch (context.LabelStyle) {
                    case PieChartLabelStyle.None:
                        targetChart.Series[0].Label = string.Empty;
                        targetChart.Series[0].XValueMember = string.Empty;
                        break;
                    case PieChartLabelStyle.Value:
                        targetChart.Series[0].Label = "#VALY";
                        break;
                    case PieChartLabelStyle.Percent:
                        targetChart.Series[0].Label = "#PERCENT{P2}";
                        break;
                    case PieChartLabelStyle.ValuePercent:
                        targetChart.Series[0].Label = "#VALY / #PERCENT{P2}";
                        break;
                    case PieChartLabelStyle.Label:
                        targetChart.Series[0].Label = "#VALX";
                        break;
                    case PieChartLabelStyle.LabelValue:
                        targetChart.Series[0].Label = "#VALX (#VALY)";
                        break;
                    case PieChartLabelStyle.LabelPercent:
                        targetChart.Series[0].Label = "#VALX (#PERCENT{P2})";
                        break;
                    case PieChartLabelStyle.LabelValuePercent:
                        targetChart.Series[0].Label = "#VALX (#VALY / #PERCENT{P2})";
                        break;
                    default:
                        throw new ArgumentOutOfRangeException("LabelStyle");
                }

                targetChart.Series[0].IsValueShownAsLabel = context.IsValueShownAsLabel;

                if (context.IsLabelOutside)
                    targetChart.Series[0]["PieLabelStyle"] = "Outside";

                System.Drawing.Color lineColor = context.LineColor;

                targetChart.ChartAreas[0].AxisX.LineColor =
                    targetChart.ChartAreas[0].AxisY.LineColor =
                        targetChart.ChartAreas[0].AxisX.InterlacedColor =
                            targetChart.ChartAreas[0].AxisY.InterlacedColor =
                                targetChart.ChartAreas[0].AxisX.MajorGrid.LineColor =
                targetChart.ChartAreas[0].AxisY.MajorGrid.LineColor =
                    targetChart.ChartAreas[0].AxisX.TitleForeColor =
                        targetChart.ChartAreas[0].AxisY.TitleForeColor =
                            targetChart.ChartAreas[0].AxisX.MajorTickMark.LineColor =
                                targetChart.ChartAreas[0].AxisY.MajorTickMark.LineColor = lineColor;

                ChartHelper.AddLegend(targetChart, ChartHelper.ParseLegendStyle(context.LegendStyle));

                targetChart.DataBind();

                targetChart.SaveImage(fileName, ChartImageFormat.Png);
            }
        }
開發者ID:FerHenrique,項目名稱:Owl,代碼行數:88,代碼來源:PieChartCreator.cs

示例4: BuildChart

        public void BuildChart(string fileName, DataTable data, LineChartContext context)
        {
            if (data == null || data.Columns.Count == 0)
                throw new System.FormatException("There is not data to plot.");

            System.Drawing.Color[] colors = ChartHelper.GetColors();
            if (data.Columns.Count - 1 > colors.Length)
                throw new IndexOutOfRangeException("We don't have enough colors to render this chart.");

            using (var targetChart = new Chart()) {

                ChartArea mainChartArea = new ChartArea("MainArea");
                targetChart.ChartAreas.Add(mainChartArea);

                ChartHelper.InitializeChart(targetChart, context.ImageSize);

                if (!string.IsNullOrWhiteSpace(context.Title)) {

                    targetChart.Titles.Add(new Title(context.Title, Docking.Top,
                                                     new System.Drawing.Font(context.TitleFontName,
                                                                             context.TitleFontSize,
                                                                             System.Drawing.FontStyle.Bold),
                                                                             context.TitleFontColor));
                }

                targetChart.DataSource = data;

                string xval = data.Columns[0].ToString();

                for (int i = 1; i < data.Columns.Count; i++) {

                    string columnName = data.Columns[i].ColumnName;

                    targetChart.Series.Add(columnName);

                    // Using column name as the legend
                    targetChart.Series[i - 1].Name = columnName;
                    targetChart.Series[i - 1].LegendText = columnName;

                    targetChart.Series[i - 1].XValueMember = xval;
                    targetChart.Series[i - 1].XValueType = ChartHelper.ParseCharValueType(context.XValueType);
                    targetChart.Series[i - 1].YValueMembers = data.Columns[i].ToString();
                    targetChart.Series[i - 1].ChartType = SeriesChartType.Line;

                    targetChart.Series[i - 1].Color = colors[i - 1];
                }

                System.Drawing.Color lineColor = context.LineColor;

                targetChart.ChartAreas[0].AxisX.LineColor =
                    targetChart.ChartAreas[0].AxisY.LineColor =
                        targetChart.ChartAreas[0].AxisX.InterlacedColor =
                            targetChart.ChartAreas[0].AxisY.InterlacedColor =
                                targetChart.ChartAreas[0].AxisX.MajorGrid.LineColor =
                targetChart.ChartAreas[0].AxisY.MajorGrid.LineColor =
                    targetChart.ChartAreas[0].AxisX.TitleForeColor =
                        targetChart.ChartAreas[0].AxisY.TitleForeColor =
                            targetChart.ChartAreas[0].AxisX.MajorTickMark.LineColor =
                                targetChart.ChartAreas[0].AxisY.MajorTickMark.LineColor = lineColor;

                ChartHelper.AddLegend(targetChart, ChartHelper.ParseLegendStyle(context.LegendStyle));

                targetChart.DataBind();

                targetChart.SaveImage(fileName, ChartImageFormat.Png);
            }
        }
開發者ID:FerHenrique,項目名稱:Owl,代碼行數:67,代碼來源:LineChartCreator.cs

示例5: buttonGenerateChart_Click


//.........這裏部分代碼省略.........
            if (tableLayoutInformation == null)
                return;

            DataGridView dataGridViewInformation = (DataGridView)tableLayoutInformation.Controls[0];
            if (dataGridViewInformation == null)
                return;

            DataTable dataTable = (DataTable)dataGridViewInformation.DataSource;
            if (dataTable == null)
                return;

            if (string.IsNullOrEmpty(comboBoxChartColumn.Text) || string.IsNullOrEmpty(comboBoxChartType.Text))
                return;

            string columnName = "";
            foreach (DataColumn dataColumn in dataTable.Columns) {
                if (dataColumn.DataType == typeof(DateTime))
                    columnName = dataColumn.ColumnName;
            }

            //Titles
            Title titleAts = new Title();
            titleAts.Alignment = ContentAlignment.TopCenter;
            titleAts.Name = "chartTitleAts";
            titleAts.Text = "Advanced Technologies and Solutions";

            Title titleChart = new Title();
            titleChart.Alignment = ContentAlignment.TopCenter;
            titleChart.Name = "chartTitle";
            titleChart.Text = tabControl.TabPages[0].Name + " (" + comboBoxChartType.Text + " Chart)";
            titleChart.TextStyle = TextStyle.Shadow;
            titleChart.Font = new Font("Calibri", 16, FontStyle.Bold);

            //Chart
            Chart chart = new Chart();
            chart.Titles.Add(titleAts);
            chart.Titles.Add(titleChart);
            chart.Dock = DockStyle.Fill;
            chart.BackColor = Color.FromName(comboBoxBackground.Text);
            chart.DataSource = dataTable;
            chart.AntiAliasing = AntiAliasingStyles.All;
            chart.TextAntiAliasingQuality = TextAntiAliasingQuality.High;
            chart.Text = dataGridViewInformation.Name;

            //ContextMenuStrip
            ContextMenuStrip contextMenuStrip = new ContextMenuStrip();
            contextMenuStrip.Name = "Chart";
            ToolStripItem toolStripItemChartSaveAsImage = contextMenuStrip.Items.Add("Save as image");
            toolStripItemChartSaveAsImage.Click += toolStripItemChartSaveAsImage_Click;
            chart.ContextMenuStrip = contextMenuStrip;

            //ChartLegends
            chart.Legends.Clear();
            chart.Legends.Add("Legend");
            chart.Legends["Legend"].Name = comboBoxChartColumn.Text;

            //ChartArea
            ChartArea chartArea = new ChartArea();
            chartArea.Name = columnName;
            chartArea.BackGradientStyle = GradientStyle.VerticalCenter;
            chartArea.BackColor = Color.FromName(comboBoxBackground.Text);

            //ChartAreaX
            chartArea.AxisX.Title = columnName;
            chartArea.AxisX.TitleFont = new Font("calibri", 16, FontStyle.Bold);
            chartArea.AxisX.LabelStyle.Format = "yyyy/MM/dd HH:mm:ss";
            chartArea.AxisX.TitleAlignment = StringAlignment.Center;
            chartArea.AxisX.MajorGrid.LineColor = Color.Transparent;
            chartArea.AxisX.Name = columnName;
            chartArea.AxisX.LabelAutoFitStyle = LabelAutoFitStyles.LabelsAngleStep90;
            chartArea.AxisX.ScaleView.Zoomable = true;

            //ChartAreaY
            chartArea.AxisY.Title = comboBoxChartColumn.Text;
            chartArea.AxisY.MajorGrid.LineColor = Color.LightGray;
            chartArea.AxisY.TitleFont = new Font("calibri", 16, FontStyle.Bold);
            chartArea.AxisY.MajorGrid.LineDashStyle = ChartDashStyle.DashDotDot;
            chartArea.AxisY.Name = comboBoxChartColumn.Text;
            chartArea.AxisY.ScaleView.Zoomable = true;

            chart.ChartAreas.Add(chartArea);
            chart.MouseWheel += chart_MouseWheel;

            Series series = new Series(comboBoxChartColumn.Text);
            series.ChartType = (SeriesChartType)Enum.Parse(typeof(SeriesChartType), comboBoxChartType.Text, true);
            series.XValueMember = columnName;
            series.YValueMembers = comboBoxChartColumn.Text;
            series.Color = Color.FromName(comboBoxSeries.Text);
            series.BorderWidth = 5;

            chart.Series.Add(series);

            chart.DataBind();

            FormChart formChart = new FormChart();
            formChart.Controls.Add(chart);
            formChart.Text = tabControl.TabPages[0].Name;
            formChart.StartPosition = FormStartPosition.CenterParent;
            formChart.Show();
        }
開發者ID:rhalf,項目名稱:AtsTqatProReportingTool,代碼行數:101,代碼來源:FormMain.cs


注:本文中的System.Windows.Forms.DataVisualization.Charting.Chart.DataBind方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。