首页 文章

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

提问于
浏览
5

我使用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; }
}
}

1 回答

  • 6

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

    <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>
    

    希望这可以帮助...

相关问题