簡體   English   中英

C#在每個堆積的柱形圖上繪制一條水平線

[英]C# Draw a horizontal line on each stacked column chart

當前,我需要開發一個以圖表為主要組件的工具。 圖表控件對我來說也是新的。 我已經做了大量的閱讀,研究以學習和理解圖表控件的整體情況。

畢竟,我一直堅持並質疑如何在堆積柱形圖上繪制水平線(藍色和紅色水平線),如下圖所示:

這是我的項目的要求

這是我到目前為止所做的:

我的圖表工具項目

到目前為止,這是我的代碼:

            // X-Axis labels settings
        chart.ChartAreas[0].AxisX.LabelStyle.Angle = -45;
        chart.ChartAreas[0].AxisX.Interval = 1;

        // Y-Axis labels settings
        //chart.ChartAreas[0].AxisY.Minimum = 100;
        chart.ChartAreas[0].AxisY.Minimum = 95;

        // Plotting chart
        using (YieldEntities context = new YieldEntities())
        {

            // Extract yield loss list
            var yeilds = (
                from yeild in context.YeildDatas
                group yeild by new { yeild.Loss } into newyeild
                select new
                {
                    Loss = newyeild.Key.Loss,
                    Percentage = newyeild.Sum(p => p.Percentage)
                }).OrderByDescending(p => p.Percentage);

            //context.YeildDatas.Select(p => new { p.Loss, Percentage = p }).Distinct();

            // Create new series
            foreach (var yield in yeilds)
            {
                chart.Series.Add(yield.Loss);
                chart.Series[yield.Loss].ChartType = SeriesChartType.StackedColumn100;
            }

            // Label settings for first series
            chart.Series[0].SmartLabelStyle.Enabled = false;
            chart.Series[0].LabelAngle = -90;
            chart.Series[0].Font = new Font(Font.FontFamily, 15, FontStyle.Bold);
            chart.Series[0].IsValueShownAsLabel = true;

            var query = context.YeildDatas.ToList();
            foreach (var item in query)
            {
                DataPoint dp = new DataPoint();
                dp.SetValueXY(item.DateString, item.Percentage);
                chart.Series[item.Loss].Points.Add(dp);
            }

            // Set empty datapoint for each series
            foreach (var yield in yeilds)
            {
                DataPoint nulldp = new DataPoint();
                nulldp.SetValueXY("", 0);
                chart.Series[yield.Loss].Points.Insert(1, nulldp);
                chart.Series[yield.Loss].Points.Insert(6, nulldp);
                chart.Series[yield.Loss].Points.Insert(11, nulldp);
            }

            chart.Legends["Legend"].IsEquallySpacedItems = true;
            chart.Legends["Legend"].IsTextAutoFit = true;

        }

我希望有任何專家來指導我解決這個問題。

這僅是示例,您可以從此處開始:

// Data point to pixel
var pixelX = this.chart1.ChartAreas[0].AxisX.ValueToPixelPosition(dataPointX);
var pixelY = this.chart1.ChartAreas[0].AxisY.ValueToPixelPosition(dataPointY);

// Pixel to data point
var dataPointX = this.chart1.ChartAreas[0].AxisX.PixelPositionToValue(pixelX);
var dataPointY = this.chart1.ChartAreas[0].AxisY.PixelPositionToValue(pixelY);

// Use event Paint to draw your line
private void chart1_Paint(object sender, PaintEventArgs e)
{
  // Convert dataPoint to pixel
  var dataPointX = this.chart1.Series[0].Points[0].XValue;
  var dataPointY = this.chart1.Series[0].Points[0].YValues[0];

  var pixelX = this.chart1.ChartAreas[0].AxisX.ValueToPixelPosition(dataPointX);
  var pixelY = this.chart1.ChartAreas[0].AxisY.ValueToPixelPosition(dataPointY);

  // Only sample, pen should be initialized outside Paint method
  Pen pen = new Pen(Brushes.Red);

  // Example of drawing line with width=100 pixel
  e.Graphics.DrawLine(pen, pixelX, pixelY, pixelX + 100, pixelY);  
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM