2

我在 .asp.net 中有一个名为 chrt 的饼图。我希望值而不是标签以货币格式显示在图表中。我希望标签显示在图例中。我执行以下操作并在我的图表而不是标签上显示值,并且标签仍然显示在图例中。

chrt.Series[0].IsValueShownAsLabel = true;

例子:

图表显示“12345.678”图例显示“销售额”

我现在需要的只是让图表以美元显示。

如果我然后执行以下操作,它将格式更改为图表上的货币,但不幸的是用货币格式的值替换了图例中的标签。

foreach (Series b in chrt.Series)
        {                            
            foreach (DataPoint c in b.Points)
            {                 
                //Sets both legend and chart value
                c.Label = c.YValues[0].ToString("C");                                   
            }
        }

例子:

图表显示“$12345.68” 图例显示“$12345.68”

我也尝试了下面的代码,但它将图例设置为值并将其格式化为货币,使图表上的值保持原样。

foreach (Series b in chrt.Series)
        {                            
            foreach (DataPoint c in b.Points)
            {            
               //Sets just the legend to the dollar values
               c.AxisLabel = c.YValues[0].ToString("C");
            }
         }

例子:

图表显示“12345.678” 图例显示“$12345.68”

我想要它显示的只是

图表显示“$12345.68”图例显示“销售额”

4

1 回答 1

6

我能弄清楚的唯一方法是不设置

chrt.Series[0].IsValueShownAsLabel = true;

然后在系列级别手动将标签和图例文本设置为我想要的。可以使用关键字#VALY 和#VALX,因此它将在运行时替换为值,并通过将格式字符串放在其后的花括号内,应用格式。因此,在这种情况下,每千位分隔符处带有 , 的美元符号,如果那里没有任何内容,则将小数点左侧替换为 0,如果那里没有任何内容,则将其替换为 0,但最多只有 2 个小数位。

foreach (Series b in chrt.Series)
        {

            b.Label = "#VALY{$#,##0.00}";           
            b.LegendText = "#VALX";
        }

例子:

12345.678 变为 12,345.67 美元

.1234 变为 0.12 美元

1234 变为 $1,234.00

于 2013-11-26T15:22:13.450 回答