我已经在WPF应用程序中实现了折线图。但是,当我运行我的应用程序时,我在图表上的垂直Y轴并未使用它给出的整个空间。简而言之:Y轴折叠。
ProfileWindow.xaml中的代码:
<lvc:CartesianChart Series="{Binding SeriesCollection}" LegendLocation="Right" Grid.Row="2" Grid.Column="2" Grid.RowSpan="3">
<lvc:CartesianChart.AxisY>
<lvc:Axis Title="Height" MinValue="0" MaxValue="1000" LabelFormatter="{Binding YFormatter}">
<lvc:Axis.Separator>
<lvc:Separator Step="50"></lvc:Separator>
</lvc:Axis.Separator>
</lvc:Axis>
</lvc:CartesianChart.AxisY>
<lvc:CartesianChart.AxisX>
<lvc:Axis Title="Samples" Labels="{Binding Labels}"></lvc:Axis>
</lvc:CartesianChart.AxisX>
</lvc:CartesianChart>
</Grid>
我尝试使用Axis.Separator来设置50的步骤。但是如您所见,这是行不通的。
Mainwindow.xaml.cs中的代码
public MainWindow()
{
InitializeComponent();
AppWindow = this;
OpenChildWindow(new DashboardWindow());
SeriesCollection = new SeriesCollection
{
new LineSeries
{
Title = "Series 1",
Values = new ChartValues<double> { 4, 60, 5, 2 ,4 }
},
new LineSeries
{
Title = "Series 2",
Values = new ChartValues<double> { 6, 7, 30, 4 ,6 },
},
new LineSeries
{
Title = "Series 3",
Values = new ChartValues<double> { 4,2,700,2,7 },
}
};
Labels = new[] { "Jan", "Feb", "Mar", "Apr", "May" };
YFormatter = value => value.ToString("C");
DataContext = this;
}
public SeriesCollection SeriesCollection { get; set; }
public string[] Labels { get; set; }
public Func<double, string> YFormatter { get; set; }
我的思维/实现方式在哪里错?
将设置Axis.MaxValue
为固定值时,绘图将无法缩放。
MaxValue
从y轴上删除该属性。轴的范围将由数据点或系列的最大值自动确定。这样,绘图将始终使用屏幕上的最大可用空间(缩放以适合)。
<lvc:CartesianChart Series="{Binding SeriesCollection}"
Height="300"
LegendLocation="Right"
Grid.Row="2"
Grid.Column="2"
Grid.RowSpan="3">
<lvc:CartesianChart.AxisY>
<lvc:Axis Title="Height" LabelFormatter="{Binding YFormatter}">
<lvc:Axis.Separator>
<lvc:Separator Step="50" />
</lvc:Axis.Separator>
</lvc:Axis>
</lvc:CartesianChart.AxisY>
<lvc:CartesianChart.AxisX>
<lvc:Axis Title="Samples" Labels="{Binding Labels}" />
</lvc:CartesianChart.AxisX>
</lvc:CartesianChart>
感谢您的回答,但是,当我运行Visual Studio时,这不能解决图表的缩小问题。还有什么可能是错误的吗?
您还必须给图表一个
Height
。这个很重要。