SSRS:堆叠条形图的“类别”轴的自定义颜色

时间:2019-02-15 00:07:25

标签: reportbuilder ssrs-2016 ssdt-bi

我有一个堆积的条形图,其中只有5个类别(但是类别的值每年都在变化,这是一个滑动5年的窗口)。

我已经成功地将条形定制为所需的颜色。

但是现在我希望使每个类别的标签与自定义的条形颜色相同。

有没有办法做到这一点?

1 个答案:

答案 0 :(得分:1)

您可以为此使用自定义代码。

报告属性中| 代码,您可以粘贴以下代码:

Private colourPalette As String() = {"#418CF0", "#FCB441", "#DF3A02", "#056492", "#BFBFBF", "#1A3B69", "#FFE382", "#129CDD", "#CA6B4B", "#005CDB", "#F3D288", "#506381", "#F1B9A8", "#E0830A", "#7893BE"}
Private count As Integer = 0
Private mapping As New System.Collections.Hashtable()

Public Function GetColour(ByVal groupingValue As String) As String

    If mapping.ContainsKey(groupingValue) Then
                    Return mapping(groupingValue)
    End If

    Dim c As String = colourPalette(count Mod colourPalette.Length)

    count = count + 1

    mapping.Add(groupingValue, c)

    Return c

End Function

这将为您提供柔和调色板的选项。如果需要其他颜色,只需将十六进制颜色代码替换为您选择的值即可。

要使用此功能,只需使用以下表达式:

=Code.GetColour(Fields!Thingy.Value)

在您的系列和标签填充表达式上使用它。这将确保为两者显示相同的颜色。如果您有多个带有相同值的图形,这还将确保多个图形上的相同数据系列始终具有相同的颜色。