我有一个堆积的条形图,其中只有5个类别(但是类别的值每年都在变化,这是一个滑动5年的窗口)。
我已经成功地将条形定制为所需的颜色。
但是现在我希望使每个类别的标签与自定义的条形颜色相同。
有没有办法做到这一点?
答案 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)
在您的系列和标签填充表达式上使用它。这将确保为两者显示相同的颜色。如果您有多个带有相同值的图形,这还将确保多个图形上的相同数据系列始终具有相同的颜色。