具有渐变的Silverlight线图

时间:2010-06-09 14:31:09

标签: silverlight graph gradient

我有一系列要点,我将在图表上变成一条线。我想要的是给图表下的区域一个渐变填充。它看起来有点像这样的彭博图;

Example Graph

我的问题实际上有三个部分;

  • 首先,我应该如何只填写图表下方的区域?
  • 其次,如何用渐变填充?
  • 最后,如果我在同一个图表上有多行,那么多行以下的任何区域都应该有一个灰度渐变填充,你会如何设置它?

我最大的问题是决定要使用的数据结构,我可以使用许多多边形状(每个行/数据系列一个),然后告诉画笔绘制;

  • 透明,如果它没有任何形状
  • 一个系列的颜色,如果它是一个形状(Alpha相对于高度给出毕业)
  • 黑色,如果它有多种形状(Alpha相对于高度来给出毕业)

然后我会用白色绘制形状的边界。

谢谢,

GAV株系

1 个答案:

答案 0 :(得分:6)

使用免费版Visiblox Silverlight Charts可以实现渐变效果。请参阅示例应用程序'Hindsight',了解如何将Visiblox图表应用于此上下文的应用程序。

我附上了XAML的粗略代码片段,了解如何实现这种效果:

<UserControl x:Class="SilverlightApplication1.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:v="clr-namespace:Visiblox.Charts;assembly=Visiblox.Charts">

<UserControl.Resources>
    <LinearGradientBrush x:Key="GradientBrush" StartPoint="1.0, 0.0" EndPoint="1.0, 1.0">
        <GradientStop Color="AliceBlue" Offset="0.3" />
        <GradientStop Color="DarkBlue" Offset="0.7" />
    </LinearGradientBrush>
</UserControl.Resources>

<Grid x:Name="LayoutRoot" Background="White">
    <v:Chart x:Name="Chart">
        <v:Chart.Series>
            <v:LineSeries x:Name="Series" ShowArea="True" AreaFill="{StaticResource GradientBrush}"/>
        </v:Chart.Series>
    </v:Chart>
</Grid>

就个人而言,我会采取Hindsight所做的动作,当绘图区域有多个系列时,删除线下的区域。我认为在这一点上,渐变会妨碍数据,正如您在上面提到的,对此做一些事情会产生计算成本。这也可能导致对数据的误解,因此要小心。

在将数据导入图表方面,您可以使用Visiblox BindableDataSeries将业务对象直接绑定到图表上。 :)

披露:我之前曾在Visiblox Charts担任开发人员。

希望这有帮助!