WPF绘图工具包y轴标签对于小数字显示为零

本文关键字:于小 数字显示 标签 绘图 工具包 WPF | 更新日期: 2023-09-27 18:24:14

我使用WPF工具箱(3.5)创建了一个图表,但我无法获得显示小数字的y轴标签(例如.001)。我已将y轴的最小值和最大值分别设置为.001和.009,尽管图表在图形上是正确的,y轴范围标签显示"0"或".01"。我猜这是3.5工具包中图表控件的限制,但我希望我遗漏了一些内容。下面是一些示例代码:

XAML:

    <Window x:Class="WpfChartApplication.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">
<Grid>
    <chartingToolkit:Chart Name="chart1">
        <chartingToolkit:LineSeries
                        Title="Rates"
                        ItemsSource="{Binding Rates}"
                        IndependentValueBinding="{Binding Time}"
                        DependentValueBinding="{Binding Value}"
                >
            <chartingToolkit:LineSeries.DependentRangeAxis>
                <chartingToolkit:LinearAxis
                                Orientation="Y"
                                Title="Y Value"
                                ShowGridLines="True"
                        Maximum=".009"
                        Minimum=".001"/>
            </chartingToolkit:LineSeries.DependentRangeAxis>
        </chartingToolkit:LineSeries>
        <chartingToolkit:Chart.Axes>
            <chartingToolkit:LinearAxis Orientation="X" 
                                        Title="X Value"
                                        ShowGridLines="True"
                                        />
        </chartingToolkit:Chart.Axes>
    </chartingToolkit:Chart>
</Grid>

以及背后的代码:

    using System.Collections.Generic;
    using System.Windows;
namespace WpfChartApplication
{
public partial class MainWindow : Window
{

    public MainWindow()
    {
        InitializeComponent();
        var cVm = new ChartViewModel();
        chart1.DataContext = cVm;
    }
}
public class ChartViewModel
{
    public List<Rate> Rates { get; set; }
    public ChartViewModel()
    {
        Rates = new List<Rate>();
        Rates.Add(new Rate(1, .001));
        Rates.Add(new Rate(2, .003));
        Rates.Add(new Rate(3, .001));
        Rates.Add(new Rate(4, .002));
        Rates.Add(new Rate(5, .001));
        Rates.Add(new Rate(6, .001));
        Rates.Add(new Rate(7, .003));
        Rates.Add(new Rate(8, .007));
        Rates.Add(new Rate(9, .009));
        Rates.Add(new Rate(10, .008));
    }
}
public class Rate
{
    public Rate(int time, double value)
    {
        Time = time;
        Value = value;
    }
    public int Time { get; set; }
    public double Value { get; set; }
}
}

WPF绘图工具包y轴标签对于小数字显示为零

您可以更改标签样式以获得效果

<Style x:Key="NumericAxisLabelStyle" TargetType="{x:Type chartingToolkit:NumericAxisLabel}">
  <Setter Property="IsTabStop" Value="False" />
  <Setter Property="StringFormat" Value="{}{0:0.###}" />
  <Setter Property="Template">
    <Setter.Value>
      <ControlTemplate TargetType="{x:Type chartingToolkit:NumericAxisLabel}">
        <TextBlock Text="{TemplateBinding FormattedContent}" />
      </ControlTemplate>
    </Setter.Value>
  </Setter>
</Style>
<chartingToolkit:Chart Name="chart1">
  <chartingToolkit:LineSeries Title="Rates"
                              ItemsSource="{Binding Rates}"
                              IndependentValueBinding="{Binding Time}"
                              DependentValueBinding="{Binding Value}">
    <chartingToolkit:LineSeries.DependentRangeAxis>
      <chartingToolkit:LinearAxis Orientation="Y"
                                  Title="Y Value"
                                  ShowGridLines="True"
                                  AxisLabelStyle="{StaticResource NumericAxisLabelStyle}"
                                  Maximum=".009"
                                  Minimum=".001" />
    </chartingToolkit:LineSeries.DependentRangeAxis>
  </chartingToolkit:LineSeries>
  <chartingToolkit:Chart.Axes>
    <chartingToolkit:LinearAxis Orientation="X" Title="X Value" ShowGridLines="True" />
  </chartingToolkit:Chart.Axes>
</chartingToolkit:Chart>

希望这能帮助。。。