如何在Telerik的RadCartesianChart工具提示中显示不受CategoryPath或ValuePath约束的值?

时间:2019-11-01 05:15:36

标签: c# mvvm telerik

我正在使用Telerik RadCartesianChart。我应该显示一个工具提示,该提示可以在图表中传达有关系列的信息(例如日期,值,系列标题)。我能够显示分别绑定在图表的CategoryPath和ValuePath中的日期和值。但是我不知道如何显示属于同一数据源但不受CategoryPath或ValuePath约束的系列标题。 以下是我到目前为止所做的事情。

<telerik:RadCartesianChart x:Name="chart" Margin="0,10,0,36" Width="auto" Grid.RowSpan="2">
    <telerik:RadCartesianChart.Behaviors>
        <telerik:ChartTooltipBehavior HorizontalOffset="-11" VerticalOffset="-50" />
    </telerik:RadCartesianChart.Behaviors>
    <telerik:RadCartesianChart.TooltipTemplate>
        <DataTemplate>
            <Grid>
                <Border Background="White" BorderBrush="Black" BorderThickness="1" Padding="5" CornerRadius="3">
                    <StackPanel>
                        <StackPanel Orientation="Horizontal">
                            <TextBlock Text="{Binding Category}" />
                        </StackPanel>
                        <StackPanel Orientation="Horizontal">
                            <TextBlock Text="{Binding Value, StringFormat=\{0:N2\}}" />
                        </StackPanel>
                    </StackPanel>
                </Border>
            </Grid>
        </DataTemplate>
    </telerik:RadCartesianChart.TooltipTemplate>
    <telerik:RadCartesianChart.HorizontalAxis>
        <telerik:DateTimeCategoricalAxis
            x:Name="datetimeAxis"                                            
        LabelFitMode="MultiLine"
        LabelFormat="{Binding Tab.CurrentPoC.LabelFormat}"
        LabelInterval="1"
        LabelOffset="0"
        LabelRotationAngle="270"
        LabelStyle="{DynamicResource LabelStyle}"
        LastLabelVisibility="Visible"
        LineDashArray="1 1"
        LineStroke="{DynamicResource CouleurTexte}"
        LineThickness="1"
        MajorTickInterval="1"
        MajorTickLength="1"
        PlotMode="OnTicks"
        SmartLabelsMode="SmartStep"
        TickThickness="5"
        ZIndex="0" Height="5" />
    </telerik:RadCartesianChart.HorizontalAxis>
    <telerik:RadCartesianChart.VerticalAxis>
        <telerik:LinearAxis Foreground="White" LastLabelVisibility="Visible" HorizontalLocation="Right"/>
    </telerik:RadCartesianChart.VerticalAxis>
    <telerik:RadCartesianChart.Grid>
        <telerik:CartesianChartGrid MajorLinesVisibility="Y" />
    </telerik:RadCartesianChart.Grid>
    <telerik:RadCartesianChart.Resources>
        <Style x:Key="AxisLineStyle" TargetType="{x:Type telerik:LinearAxis}" >
            <Setter Property="Foreground" Value="{Binding ColorName, Mode=TwoWay, Converter={StaticResource NVarToBrushConverter}}"/>
            <Setter Property="Background" Value="{Binding ColorName, Mode=TwoWay, Converter={StaticResource NVarToBrushConverter}}"/>
        </Style>
        <DataTemplate x:Key="ellipseTemplate">
            <Ellipse Height="10" Width="10" Fill="{Binding Converter={StaticResource PaletteConverter}}"/>
        </DataTemplate>
        <DataTemplate x:Key="rectangleTemplate">
            <Rectangle Height="10" Width="10" Fill="{Binding Converter={StaticResource PaletteConverter}}" />
        </DataTemplate>
        <DataTemplate x:Key="triangleTemplate">
            <Polygon Points="10,5 5,10 15,10 10,3" Stroke="GreenYellow" StrokeThickness="2" Fill="{Binding Converter={StaticResource PaletteConverter}}"/>
        </DataTemplate>
        <!--<DataTemplate x:Key="+Template">
                <Rectangle Height="10" Width="10" Fill="{Binding Converter={StaticResource PaletteConverter}}" />
            </DataTemplate>
            <DataTemplate x:Key="xTemplate">
                <Rectangle Height="10" Width="10" Fill="{Binding Converter={StaticResource PaletteConverter}}" />
            </DataTemplate>-->
        <Style TargetType="telerik:LineSeries" BasedOn="{StaticResource LineSeriesStyle}">
            <Setter Property="LegendSettings" Value="{Binding Converter={StaticResource ChartViewLegendSettingsValueConverter}}"/>
            <Setter Property="ShowLabels" Value="False"/>
            <Setter Property="Stroke" Value="{Binding ColorName, Mode=TwoWay, Converter={StaticResource NVarToBrushConverter}}"/>
            <Setter Property="VerticalAxis">
                <Setter.Value>
                    <telerik:LinearAxis ElementBrush="{Binding Tab.CurrentPoC.LineSeriesColor}" HorizontalLocation="Left"/>
                </Setter.Value>
            </Setter>
            <Setter Property="PointTemplateSelector" Value="{StaticResource templateSelector}"/>
        </Style>
        <Style TargetType="telerik:BarSeries"  BasedOn="{StaticResource BarSeriesStyle}">
            <Setter Property="CombineMode" Value="Stack"/>
            <Setter Property="LegendSettings" Value="{Binding Converter={StaticResource ChartViewLegendSettingsValueConverter}}"/>
            <Setter Property="ShowLabels" Value="False"/>
            <Setter Property="VerticalAxis">
                <Setter.Value>
                    <telerik:LinearAxis ElementBrush="Gray" HorizontalLocation="Right"/>
                </Setter.Value>
            </Setter>
            <Setter Property="PointTemplate">
                <Setter.Value>
                    <DataTemplate>
                        <Rectangle Fill="{Binding Converter={StaticResource PaletteConverter}}" />
                    </DataTemplate>
                </Setter.Value>
            </Setter>
        </Style>
        <Style TargetType="telerik:PointSeries" BasedOn="{StaticResource PointSeriesStyle}">
            <Setter Property="LegendSettings" Value="{Binding Converter={StaticResource ChartViewLegendSettingsValueConverter}}"/>
            <Setter Property="ShowLabels" Value="False"/>
            <Setter Property="Width" Value="15"/>
            <Setter Property="Height" Value="15"/>
            <Setter Property="VerticalAxis">
                <Setter.Value>
                    <telerik:LinearAxis ElementBrush="{Binding Tab.CurrentPoC.PointSeriesColor}" HorizontalLocation="Left" />
                    <!--Style="{DynamicResource AxisLineStyle}"-->
                </Setter.Value>
            </Setter>
            <Setter Property="PointTemplateSelector" Value="{StaticResource templateSelector}"/>
        </Style>
    </telerik:RadCartesianChart.Resources>
    <telerik:RadCartesianChart.SeriesProvider>
        <telerik:ChartSeriesProvider Source="{Binding Tab.CurrentPoC.GraphsToDisplay, Mode=TwoWay}">
            <telerik:ChartSeriesProvider.SeriesDescriptors>
                <telerik:CategoricalSeriesDescriptor x:Name="CatSeries" CategoryPath="TimeStampX" ValuePath="ValueY" ItemsSourcePath="Data" TypePath="SerieType"/>
            </telerik:ChartSeriesProvider.SeriesDescriptors>
        </telerik:ChartSeriesProvider>
    </telerik:RadCartesianChart.SeriesProvider>
</telerik:RadCartesianChart>

2 个答案:

答案 0 :(得分:1)

要满足您的要求,可以使用Presenter对象的DataPoint属性。

DataPoint对象是传递到TooltipTemplate的数据上下文。

PresenterDataPoint的属性,其中包含对承载具体数据点的系列对象的引用。

    <telerik:RadCartesianChart.TooltipTemplate>
        <DataTemplate>
            <TextBlock Text="{Binding Presenter.DataContext.MySeriesNameProperty}" />
        </DataTemplate>
    </telerik:RadCartesianChart.TooltipTemplate>

您可以在RadChartView documentation中阅读有关DataPoint类的更多信息。

答案 1 :(得分:0)

我通过向数据源对象添加名为LegendName的新属性来使其工作。然后像这样<TextBlock Text="{Binding Path=DataItem.LegendName}"/>更改绑定路径。不确定这是否是正确的方法,但是它是否按预期工作。