Table of Contents

Adding an Indicator to the Chart

The following example demonstrates how to add an indicator for drawing on a chart:

private readonly Connector _connector = new Connector();
private Security _security;
private Subscription _candleSubscription;
private SimpleMovingAverage _sma;
readonly TimeSpan _timeFrame = TimeSpan.FromMinutes(1);
private ChartArea _area;
private ChartCandleElement _candlesElem;
private ChartIndicatorElement _longMaElem;

// Initializing chart and indicator
private void InitializeChart()
{
    // _chart - StockSharp.Xaml.Charting.Chart
    // Creating a chart area
    _area = new ChartArea();
    _chart.Areas.Add(_area);
    
    // Creating a chart element representing candles
    _candlesElem = new ChartCandleElement();
    _area.Elements.Add(_candlesElem);
    
    // Creating a chart element representing the indicator
    _longMaElem = new ChartIndicatorElement
    {
        Title = "Long"
    };
    _area.Elements.Add(_longMaElem);
    
    // Creating an indicator
    _sma = new SimpleMovingAverage() { Length = 80 };
    
    // Subscribing to the candle receiving event
    _connector.CandleReceived += OnCandleReceived;
}

// Method for subscribing to candles
private void SubscribeToCandles()
{
    // Creating a subscription to candles with the specified timeframe
    _candleSubscription = new Subscription(
        DataType.TimeFrame(_timeFrame),
        _security)
    {
        MarketData = 
        {
            // Requesting historical data for 30 days
            From = DateTime.Today.Subtract(TimeSpan.FromDays(30)),
            To = DateTime.Now,
            // Receiving only finished candles
            IsFinishedOnly = true
        }
    };
    
    // Starting the subscription
    _connector.Subscribe(_candleSubscription);
}

// Handler for the candle receiving event
private void OnCandleReceived(Subscription subscription, ICandleMessage candle)
{
    // Checking if the candle belongs to our subscription
    if (subscription != _candleSubscription)
        return;
    
    // Checking the candle state
    if (candle.State != CandleStates.Finished)
        return;
    
    // Processing the candle with the indicator
    var longValue = _sma.Process(candle);
    
    // Creating data for drawing
    var data = new ChartDrawData();
    data
        .Group(candle.OpenTime)
            .Add(_candlesElem, candle)
            .Add(_longMaElem, longValue);
    
    // Drawing on the chart in the UI thread
    this.GuiAsync(() => _chart.Draw(data));
}

// Method for unsubscribing when closing the window
private void UnsubscribeFromCandles()
{
    if (_candleSubscription != null)
    {
        _connector.CandleReceived -= OnCandleReceived;
        _connector.UnSubscribe(_candleSubscription);
        _candleSubscription = null;
    }
}

indicators chart

Example of working with multiple indicators

private readonly Connector _connector = new Connector();
private Security _security;
private Subscription _candleSubscription;
private SimpleMovingAverage _shortSma;
private SimpleMovingAverage _longSma;
private ChartArea _mainArea;
private ChartArea _indicatorArea;
private ChartCandleElement _candlesElem;
private ChartIndicatorElement _shortSmaElem;
private ChartIndicatorElement _longSmaElem;
private RelativeStrengthIndex _rsi;
private ChartIndicatorElement _rsiElem;

// Initializing chart and indicators
private void InitializeChartWithMultipleIndicators()
{
    // Creating the main area for candles and moving averages
    _mainArea = new ChartArea();
    _chart.Areas.Add(_mainArea);
    
    // Creating an area for RSI
    _indicatorArea = new ChartArea();
    _chart.Areas.Add(_indicatorArea);
    
    // Creating chart elements
    _candlesElem = new ChartCandleElement();
    _shortSmaElem = new ChartIndicatorElement { Title = "SMA (short)" };
    _longSmaElem = new ChartIndicatorElement { Title = "SMA (long)" };
    _rsiElem = new ChartIndicatorElement { Title = "RSI" };
    
    // Setting element colors
    _shortSmaElem.Color = Colors.Red;
    _longSmaElem.Color = Colors.Blue;
    _rsiElem.Color = Colors.Green;
    
    // Adding elements to their respective areas
    _mainArea.Elements.Add(_candlesElem);
    _mainArea.Elements.Add(_shortSmaElem);
    _mainArea.Elements.Add(_longSmaElem);
    _indicatorArea.Elements.Add(_rsiElem);
    
    // Creating indicators
    _shortSma = new SimpleMovingAverage { Length = 9 };
    _longSma = new SimpleMovingAverage { Length = 20 };
    _rsi = new RelativeStrengthIndex { Length = 14 };
    
    // Subscribing to the candle receiving event
    _connector.CandleReceived += OnCandleReceivedMultipleIndicators;
    
    // Creating a subscription to candles
    _candleSubscription = new Subscription(
        DataType.TimeFrame(TimeSpan.FromMinutes(5)),
        _security)
    {
        MarketData = 
        {
            From = DateTime.Today.Subtract(TimeSpan.FromDays(30)),
            To = DateTime.Now,
            IsFinishedOnly = true
        }
    };
    
    // Starting the subscription
    _connector.Subscribe(_candleSubscription);
}

// Handler for the candle receiving event for multiple indicators
private void OnCandleReceivedMultipleIndicators(Subscription subscription, ICandleMessage candle)
{
    // Checking if the candle belongs to our subscription
    if (subscription != _candleSubscription)
        return;
    
    if (candle.State != CandleStates.Finished)
        return;
    
    // Processing the candle with indicators
    var shortSmaValue = _shortSma.Process(candle);
    var longSmaValue = _longSma.Process(candle);
    var rsiValue = _rsi.Process(candle);
    
    // Creating data for drawing
    var data = new ChartDrawData();
    data
        .Group(candle.OpenTime)
            .Add(_candlesElem, candle)
            .Add(_shortSmaElem, shortSmaValue)
            .Add(_longSmaElem, longSmaValue)
            .Add(_rsiElem, rsiValue);
    
    // Drawing on the chart in the UI thread
    this.GuiAsync(() => _chart.Draw(data));
}

See also

Components for building charts