wpf-devexpress-dot-xpf-dot-charts-dot-annotation-053b5db4.md
Specifies the annotation position.
Namespace : DevExpress.Xpf.Charts
Assembly : DevExpress.Xpf.Charts.v25.2.dll
NuGet Package : DevExpress.Wpf.Charts
public AnnotationShapePosition ShapePosition { get; set; }
Public Property ShapePosition As AnnotationShapePosition
| Type | Description |
|---|---|
| AnnotationShapePosition |
An AnnotationShapePosition class descendant representing the shape position type.
|
The ShapePosition property can be specified as the RelativePosition or FreePosition type.
The following table uses examples to describe these two annotation shape position types.
|
The Property Values
|
The Example Image
|
Description
| | --- | --- | --- | |
ShapePosition = RelativePosition
|
|
If the Annotation.ShapePosition property is specified as the RelativePosition type, use the RelativePosition.ConnectorLength and RelativePosition.Angle properties to modify the annotation shape position.
In this example, the ConnectorLength property is set to 70 and the RelativePosition.Angle property is 45.
| |
ShapePosition = FreePosition
|
|
If the Annotation.ShapePosition property is specified as the FreePosition type, you can use the FreePosition.VerticalAlignment and FreePosition.HorizontalAlignment properties to specify the annotation layout. To define the parent element, use the FreePosition.DockTarget property. To define the indents from the parent element edges, use the Annotation.Margin property.
In this example, the annotation is docked to a Chart control. The HorizontalAlignment property is set to Right and the VerticalAlignment property is set to Top. The Margin property is defined as (0, 90, 50, 0).
|
This example demonstrates how to anchor an annotation to a series point.
To do this, specify the SeriesPointAnchorPoint.SeriesPoint property.
<dxc:Annotation Content="Annotation #1">
<dxc:Annotation.AnchorPoint>
<dxc:SeriesPointAnchorPoint SeriesPoint="{Binding ElementName=seriesPoint}"/>
</dxc:Annotation.AnchorPoint>
<dxc:Annotation.ShapePosition>
<dxc:RelativePosition Angle="60"
ConnectorLength="50"/>
</dxc:Annotation.ShapePosition>
</dxc:Annotation>
The following example creates an annotation that is anchored to a pane.
<dxc:ChartControl x:Name="chartControl">
<dxc:XYDiagram2D x:Name="diagram">
<dxc:XYDiagram2D.SecondaryAxesX>
<dxc:SecondaryAxisX2D x:Name="xAxis"/>
</dxc:XYDiagram2D.SecondaryAxesX>
<dxc:XYDiagram2D.SecondaryAxesY>
<dxc:SecondaryAxisY2D x:Name="yAxis"/>
</dxc:XYDiagram2D.SecondaryAxesY>
<dxc:XYDiagram2D.Panes>
<dxc:Pane x:Name="pane"/>
</dxc:XYDiagram2D.Panes>
<!--...-->
</dxc:XYDiagram2D>
</dxc:ChartControl>
using DevExpress.Xpf.Charts;
//...
private void Window_Loaded(object sender, RoutedEventArgs e) {
Annotation annotation = new Annotation();
annotation.Content = "Annotation";
annotation.AnchorPoint = new PaneAnchorPoint {
AxisXCoordinate = new AxisXCoordinate { AxisValue = new TimeSpan(0, 0, 5), Axis = xAxis },
AxisYCoordinate = new AxisYCoordinate { AxisValue = 100, Axis = yAxis },
Pane = pane
};
annotation.ShapePosition = new RelativePosition { Angle = 30, ConnectorLength = 60 };
chartControl.Annotations.Add(annotation);
}
Imports DevExpress.Xpf.Charts
'...
Private Sub Window_Loaded(ByVal sender As Object, ByVal e As RoutedEventArgs)
Dim annotation As Annotation = New Annotation()
annotation.Content = "Annotation"
annotation.AnchorPoint = New PaneAnchorPoint With {
.AxisXCoordinate = New AxisXCoordinate With {
.AxisValue = New TimeSpan(0, 0, 5),
.Axis = xAxis
},
.AxisYCoordinate = New AxisYCoordinate With {
.AxisValue = 100,
.Axis = yAxis
},
pane
}
annotation.ShapePosition = New RelativePosition With {
.Angle = 30,
.ConnectorLength = 60
}
chartControl.Annotations.Add(annotation)
End Sub
If the chart is bound to data and you want to anchor an annotation to a series point, use the ChartControl.BoundDataChanged event to access the point collection. The following example creates an annotation for each point of a spline series.
<dxc:ChartControl x:Name="chartControl"
BoundDataChanged="chartControl_BoundDataChanged">
<dxc:XYDiagram2D x:Name="diagram">
<dxc:SplineSeries2D>
<!--...-->
</dxc:SplineSeries2D>
</dxc:XYDiagram2D>
</dxc:ChartControl>
using DevExpress.Xpf.Charts;
//...
private void chartControl_BoundDataChanged(object sender, RoutedEventArgs e) {
SplineSeries2D series = (SplineSeries2D)diagram.Series[0];
if (series.Points.Count > 0) {
for (int i = 0; i < series.Points.Count; i++) {
chartControl.Annotations.BeginInit();
Annotation annotation = new Annotation() {
Content = series.Points[i].Value.ToString()
};
annotation.AnchorPoint = new SeriesPointAnchorPoint() {
SeriesPoint = series.Points[i]
};
annotation.ShapePosition = new RelativePosition() {
Angle = 0,
ConnectorLength = 0
};
chartControl.Annotations.Add(annotation);
chartControl.Annotations.EndInit();
}
}
}
Imports DevExpress.Xpf.Charts
'...
Private Sub chartControl_BoundDataChanged(ByVal sender As Object, ByVal e As RoutedEventArgs)
Dim series As SplineSeries2D = CType(diagram.Series(0), SplineSeries2D)
If series.Points.Count > 0 Then
For i As Integer = 0 To series.Points.Count - 1
chartControl.Annotations.BeginInit()
Dim annotation As Annotation = New Annotation() With {
.Content = series.Points(i).Value.ToString()
}
annotation.AnchorPoint = New SeriesPointAnchorPoint() With {
.SeriesPoint = series.Points(i)
}
annotation.ShapePosition = New RelativePosition() With {
.Angle = 0,
.ConnectorLength = 0
}
chartControl.Annotations.Add(annotation)
chartControl.Annotations.EndInit()
Next
End If
End Sub
See Also