我有一个DataTable,我添加到Foreach循环中的图表,如下所示,并将Dtmonth DataRow分配给XXAX的图表,这是一个月名:

                foreach (DataRow dr in dtMD.Rows)
                {

                    DataTable dtMDByName = ocw.GetMDByName(Convert.ToDateTime(txtStartDate.Text), Convert.ToDateTime(txtEndDate.Text), dr["MD"].ToString());

                    if (dtMDByName.Rows.Count > 0)
                    {
                        ChartSeries MDChartSeries = new ChartSeries();
                        MDChartSeries.Name = dtMDByName.Rows[0][1].ToString();
                        MDChartSeries.Type = ChartSeriesType.Line;

                        foreach (DataRow drByName in dtMDByName.Rows)
                        {
                            MDChartSeries.AddItem(Convert.ToDouble(drByName["T"]));

                            radMD.PlotArea.XAxis.DataLabelsColumn = drByName["dtMonth"].ToString();
                        }

                        radMD.ChartTitle.TextBlock.Text = "MDs";
                        radMD.PlotArea.XAxis.AutoScale = true;
                        radMD.Series.Add(MDChartSeries);

                    }
                }
.

但它仍然显示为xaxis中的数字,在上面的代码中做错了什么?

即使我在第二个循环之外执行它,我仍然没有显示月份名称:

radMD.PlotArea.XAxis.DataLabelsColumn = "dtMonth";
.

感谢

有帮助吗?

解决方案

发现您需要将自动缩放设置为false,然后添加TextBlock,如下所示:

                              radMD.PlotArea.XAxis.AutoScale = true;
                                for (int i = 0; i < dtMDByName.Rows.Count; i++)
                                {
                                    radMD.PlotArea.XAxis[i].TextBlock.Text = dtMDByName.Rows[i][3].ToString();
                                }
.

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top