在使用WPFToolkit图表控件时,是否有人知道如何或找到明确设置数据点系列颜色的任何好例子?我想在我的XAML中将其设置为样式。
答案 0 :(得分:6)
您可以在图表上设置调色板。此示例适用于ColumnSeries,但您可以根据您使用的任何类型对其进行调整。
<charting:Chart ... Palette="{StaticResource MyPalette}">
Palette定义如下所示:
<datavis:ResourceDictionaryCollection x:Key="MyPalette">
<ResourceDictionary>
<Style x:Key="DataPointStyle" BasedOn="{StaticResource ColumnSeries1Style}" TargetType="Control" />
</ResourceDictionary>
<ResourceDictionary>
<Style x:Key="DataPointStyle" BasedOn="{StaticResource ColumnSeries2Style}" TargetType="Control" />
</ResourceDictionary>
... add more if necessary
</datavis:ResourceDictionaryCollection>
“ColumnSeries1Style”和“ColumnSeries1Style”样式定义该系列的背景画笔:
<Style x:Key="ColumnSeries1Style" TargetType="Control">
<Setter Property="Background" Value="{StaticResource Series1Brush}" />
</Style>
<Style x:Key="ColumnSeries2Style" TargetType="Control">
<Setter Property="Background" Value="{StaticResource Series2Brush}" />
</Style>
您可以根据需要定义画笔。以下是如何获取默认图表中使用的渐变填充:
<Color x:Key="Series1Color" A="255" R="139" G="180" B="232" />
<Color x:Key="Series1HighlightColor" A="255" R="188" G="229" B="255" />
<RadialGradientBrush x:Key="Series1Brush">
<RadialGradientBrush.RelativeTransform>
<TransformGroup>
<ScaleTransform CenterX="0.5" CenterY="0.5" ScaleX="2.09" ScaleY="1.819" />
<TranslateTransform X="-0.425" Y="-0.486" />
</TransformGroup>
</RadialGradientBrush.RelativeTransform>
<GradientStop Color="{StaticResource Series1HighlightColor}"/>
<GradientStop Color="{StaticResource Series1Color}" Offset="1"/>
</RadialGradientBrush>
答案 1 :(得分:3)
如果有人感兴趣,有一种更简单的方法。您只需在ColumnSeries中设置DataPointStyle并更改Background属性。
<DVC:ColumnSeries IndependentValueBinding="{Binding Path=Key}"
DependentValueBinding="{Binding Path=Value}">
<DVC:ColumnSeries.DataPointStyle>
<Style TargetType="DVC:ColumnDataPoint">
<Setter Property="Background" Value="#00777F"/>
</Style>
</DVC:ColumnSeries.DataPointStyle>
</DVC:ColumnSeries>