使用免费版本的Visiblox Silverlight Charts可以实现渐变效果。请参阅示例应用程序“后见之明”,了解如何将 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>
就个人而言,我会采取事后诸葛亮的行动,当情节区域上有多个系列时,删除线下的区域。我认为在这一点上梯度会妨碍数据,正如你上面提到的,对此做一些事情会产生计算成本。这也可能导致对数据的误解,所以要小心。
在将数据导入图表方面,您可以使用 Visiblox BindableDataSeries 将业务对象直接绑定到图表上。:)
披露:我之前曾担任 Visiblox Charts 的开发人员。
希望这可以帮助!