Изменение цветов по умолчанию для WPFToolkit Chart Control - PullRequest
2 голосов
/ 13 сентября 2010

Кто-нибудь знает, как найти или найти какие-либо хорошие примеры явной настройки цвета ряда точек данных при использовании элемента управления диаграммы WPFToolkit?Я хотел бы установить это как стиль в моем XAML.

Ответы [ 2 ]

6 голосов
/ 13 сентября 2010

Вы можете установить палитру на графике.Этот пример для ColumnSeries, но вы можете адаптировать его для любого типа, который вы используете.

<charting:Chart ... Palette="{StaticResource MyPalette}">

Определение палитры выглядит так:

<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>
4 голосов
/ 16 апреля 2015

На всякий случай, если кому-то интересно, есть более простой способ сделать это. Вам просто нужно установить DataPointStyle в ColumnSeries и изменить свойство 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>
...