我正在使用WPF工具包(http://www.codeproject.com/Articles/196502/WPF-Toolkit-Charting-Controls-Line-Bar-Area-Pie-Co)来创建折线图。
这就是我正在做的事情:
<Window x:Class="TempDataAnalyzer.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="MainWindow" Height="350" Width="525" xmlns:chartingToolkit="clr-namespace:System.Windows.Controls.DataVisualization.Charting;assembly=System.Windows.Controls.DataVisualization.Toolkit" Loaded="Window_Loaded">
<Grid>
<chartingToolkit:Chart Name="lineChart" Title="Temperature" VerticalAlignment="Stretch" HorizontalAlignment="Stretch">
<chartingToolkit:LineSeries DependentValuePath="Value" IndependentValuePath="Key" ItemsSource="{Binding}" IsSelectionEnabled="True"/>
</chartingToolkit:Chart>
</Grid>
</Window>
C#:
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
}
private void Window_Loaded(object sender, RoutedEventArgs e)
{
List<KeyValuePair<int, int>> entries = new List<KeyValuePair<int, int>>();
entries.Add(new KeyValuePair<int, int>(0, 0));
entries.Add(new KeyValuePair<int, int>(1, 23));
entries.Add(new KeyValuePair<int, int>(2, 45));
entries.Add(new KeyValuePair<int, int>(3, 46));
entries.Add(new KeyValuePair<int, int>(4, 71));
lineChart.DataContext = entries;
}
}
我需要在指定的Y值处绘制一个“球门线”,比方说,在这种情况下 - 35:
我怎样才能做到这一点?
答案 0 :(得分:2)
我已经在我的一些项目中做了类似的事情。
我创建了这样的一行:
<chartingToolkit:Chart Name="chart1" Title="Chart Title">
<chartingToolkit:LineSeries DependentValuePath="Value" IndependentValuePath="Key" ItemsSource="{Binding}">
<chartingToolkit:LineSeries.PolylineStyle>
<Style TargetType="Polyline">
<Setter Property="StrokeDashArray" Value="5 5 5" />
<Setter Property="StrokeThickness" Value="2"/>
</Style>
</chartingToolkit:LineSeries.PolylineStyle>
<chartingToolkit:LineSeries.DataPointStyle>
<Style TargetType="{x:Type chartingToolkit:LineDataPoint}">
<Setter Property="Background" Value="Red"/>
<Setter Property="Template" Value="{x:Null}" />
</Style>
</chartingToolkit:LineSeries.DataPointStyle>
</chartingToolkit:LineSeries>
</chartingToolkit:Chart>
我将它与MVVM模式一起使用,并将“LineSeries”绑定到ObservableCollection<KeyValuePair<string, int>>
答案 1 :(得分:0)
使用此:
<chartingToolkit:LineSeries.DataPointStyle>
<Style TargetType="chartingToolkit:LineDataPoint">
<!-- <Setter Property="Template" Value="{x:Null}"/> -->
<Setter Property="Opacity" Value="0" />
<Setter Property="Background" Value="Red"/>
<Setter Property="BorderBrush" Value="Red"/>
<Setter Property="Width" Value="2" />
<Setter Property="Height" Value="2" />
</Style>
</chartingToolkit:LineSeries.DataPointStyle>
<chartingToolkit:LineSeries.PolylineStyle>
<Style TargetType="Polyline">
<Setter Property="Opacity" Value="1" />
<Setter Property="StrokeThickness" Value="1"/>
<Setter Property="Stroke" Value="Red" />
</Style>
</chartingToolkit:LineSeries.PolylineStyle>