Trend Channel

Overview

The Trend Channel annotation allows you to add a trend channel to a chart.

This article explains how to add a Trend Channel and configure its basic and visual settings. You can find more settings and other useful information in the articles describing annotations in general:

Basic Settings

To add a Trend Channel annotation to a chart, call the trendChannel() method of the annotations() object.

Next, use the xAnchor(), valueAnchor(), secondXAnchor(), secondValueAnchor(), thirdXAnchor() and thirdValueAnchor() methods to set 3 points that determine the position of the trend channel. Usually, the most convenient way to do this is object notation:

// create a stock chart
chart = anychart.stock();

// create a plot on the chart
var plot = chart.plot(0);

// access the annotations() object of the plot to work with annotations
var controller = plot.annotations();

// create a Trend Channel annotation
controller.trendChannel({
    xAnchor: "2007-01-07",
    valueAnchor: 28.92,
    secondXAnchor: "2007-09-23",
    secondValueAnchor: 33.13,
    thirdXAnchor: "2006-07-30",
    thirdValueAnchor: 17.24
});

This is how it looks like:

Playground

Appearance

The appearance settings of a Trend Channel annotation can be configured in three states: normal, hover, and selected. Use the following methods:

Combine them with these methods:

You can also use object notation to specify the settings. In the sample below, there are two Trend Channel annotations with some of the visual settings configured (by using an object in the first case and methods in the second):

// create the first Trend Channel annotation and configure its visual settings
var trendChannel1 = controller.trendChannel({
    xAnchor: "2007-01-07",
    valueAnchor: 28.92,
    secondXAnchor: "2007-09-23",
    secondValueAnchor: 33.13,
    thirdXAnchor: "2006-07-30",
    thirdValueAnchor: 17.24,
    hovered: {
        fill: "#398cae 0.3",
        stroke: "2 #ff0000"
    },
    selected: {
        fill: "#398cae 0.3",
        hatchFill: "forward-diagonal",
        stroke: "4 #ff0000"
    }
});

// create the second Trend Channel annotation
var trendChannel2 = controller.trendChannel();

// set the position of the second annotation
trendChannel2.xAnchor("2004-01-11");
trendChannel2.valueAnchor(29.13);
trendChannel2.secondXAnchor("2005-10-30");
trendChannel2.secondValueAnchor(17.87);
trendChannel2.thirdXAnchor("2004-08-08");
trendChannel2.thirdValueAnchor(17.86);

// configure the visual settings of the second annotation
trendChannel2.normal().fill("none");
trendChannel2.normal().stroke("#006600", 1, "10 2");
trendChannel2.hovered().stroke("#00b300", 2, "10 2");
trendChannel2.selected().stroke("#00b300", 4, "10 2");  

Playground