Получение свечки реального времени от Альфа-Директ

Получение свечки реального времени от Альфа-Директ
Atom
7/3/2012
BBB


Здравствуйте, прочитал всю документацию но никак не получается это реализовать(версия 4.1.1), может кто даст рабочий пример кода...


Tags:


Thanks:


< 1 2 3  >
Mikhail Sukhov

Avatar
Date: 6/20/2013
Reply


Приведите пожалуйста StackTrace. Картинки с ошибками и сам код не несут практически никакой полезной информации.

Thanks:

UsilaDobry

Avatar
Date: 6/20/2013
Reply


Михаил Сухов: Приведите пожалуйста StackTrace. Картинки с ошибками и сам код не несут практически никакой полезной информации.

StackTrace? Это трассировка исключения? Не знаю правильно ли я понял, Вы имеете ввиду вот эту информацию?

Thanks:

Mikhail Sukhov

Avatar
Date: 6/20/2013
Reply


UsilaDobry:

Михаил Сухов: Приведите пожалуйста StackTrace. Картинки с ошибками и сам код не несут практически никакой полезной информации.

StackTrace? Это трассировка исключения? Не знаю правильно ли я понял, Вы имеете ввиду вот эту информацию?

Да это. А теперь нажмите на это окно Ctrl+C и вставьте сообщение как текст на форум. Спасибо.

Thanks:

UsilaDobry

Avatar
Date: 6/20/2013
Reply




System.InvalidCastException: Не удалось привести тип объекта "StockSharp.Algo.Candles.TimeFrameCandle[]" к типу "System.Collections.Generic.List`1[StockSharp.Algo.Candles.Candle]".

в StockSharp.AlfaDirect.AlfaTrader.#=qNmkP6QzBPHM7MSi3K7zNb8hpEPmvaemYv5w1q7pSlzs=(CandleSeries #=qw2Ij9lcQ52_YjUxYlygqJQ==, AlfaTimeFrames #=qmt9jajmekZJ3lvX4EWDlsw==, Range`1 #=qUa$g1WHcmZt7GKP9MHGYdQ==, Boolean #=qyMqxPE6iw9OG3w187t$YJg==, #=qrYpFuQVysBZ8IKEVqMgJNeOJnek4Tqt17H5Lhdsr7oOl5WXmF$V4OcRiLRkcvZGh& #=qdyEgQw5_gfsmxp61TgMHpQ==)

в StockSharp.AlfaDirect.AlfaTrader.SubscribeHistoricalCandles(CandleSeries series, DateTime from, DateTime to)

в StockSharp.Algo.Candles.CandleManager.#=qMxwX6RCGPPukCh3ls8RxBpA7IM61KWm0NtodaOEzPbw=.#=q6S9eoetqGa49tVuWloNQCnRypxcDn7PYNPl2C$RaYnkKcnu1wUHa2NHB6vFg6y0WaNoYZQe4eQyVPI8HWrXBIyz4LMDluX5GlBYwdeY220k=(CandleSeries #=q1SVIqTyklP0v2Vmdbxf5pQ==, DateTime #=qv2yp$YhyUweWh$XfcRdgUw==, DateTime #=qHyx5tP4ns5E8bwaA97HB6A==)

в #=qX3OhqnqEph0ylOwbVoprdaRyUdFykOOlTJqNaUikiywB2d5GxCHY1J7pgbbIcyah1whRfbIIDuqG1CROSXDxrw==.#=qXRmgGHeIzniBfKG_gUxziw==()

в StockSharp.Algo.Candles.CandleManager.Start(CandleSeries series, DateTime from, DateTime to)

в StockSharp.Algo.Candles.CandleHelper.Start(ICandleManager manager, CandleSeries series)

в MARKET_SUCCESS_ALFA.MainWindow.ShowChartClick(Object sender, RoutedEventArgs e) в c:\Users\UsilaDobry\Documents\Visual Studio 2012\Projects\MARKET SUCCESS ALFA\MainWindow.xaml.cs:строка 241


ОК

Thanks:

Mikhail Sukhov

Avatar
Date: 6/20/2013
Reply


Ошибка найдена и поправлена. Я постучался в скайп. Давайте проведем тестирование, может там еще что-то есть. Демо у Альфы теперь не предоставляется, а ради небольшой ошибки ехать к ним в офис нет совсем времени.

Thanks: UsilaDobry

UsilaDobry

Avatar
Date: 6/20/2013
Reply


Благодарю, реальные свечи выводятся корректно. Красота. Вот только значения индикатора BollingerBands выводятся странно. Это мой код

private void ShowChartClick(object sender, RoutedEventArgs e)
        {
            try
            {
                var security = SelectedSecurity;
                
                var timeFrame = (AlfaTimeFrames)((ComboBoxItem)HistoryInterval.SelectedItem).Tag;
                
                if (From.Value != null)
                {
                    var from = From.Value.Value;
                    if (To.Value != null)
                    {
                        var to = To.Value.Value;
                
                        if (@from > to)
                        {
                            return;
                        }
                
                        var candles = _trader.GetHistoryData(security, timeFrame, new Range<DateTime>(@from, to));
                        
                        _chartWindow = new ChartWindow
                        {
                            Title = "{0}, {1}, {2} - {3}".Put(security.Code,
                                                              ((ComboBoxItem)HistoryInterval.SelectedItem).Content,
                                                              @from.ToString(CultureInfo.InvariantCulture), to.ToString(CultureInfo.InvariantCulture))
                        };
                
                        var area = new ChartArea();
                        _chartWindow.Chart.ChartTheme = "ExpressionDark";
                        _chartWindow.Chart.IsAutoScroll = true;
                        _chartWindow.Chart.Areas.Add(area);
                
                        _candlesElem = new ChartCandleElement
                        {
                            Antialiasinig = false,
                            UpBodyColor = Colors.Chartreuse,
                            UpWickColor = Colors.Chartreuse,
                            DownBodyColor = Colors.Red,
                            DownWickColor = Colors.Red,
                            IsLegend = true,
                        };
                
                        _chartBollingerElement = new ChartIndicatorElement
                        {
                            Antialiasinig = false,
                            Color = Colors.DeepSkyBlue,
                            IsLegend = true,
                            Indicator = new BollingerBands
                            {
                                Length = 20,
                                Width = 2
                            },
                            Title = "Bollinger Bands",
                            DrawStyle = ChartIndicatorDrawStyles.Line,
                        };
                        _chartBollingerElement.DrawTemplate.VisualTree.SetValue(Shape.FillProperty, new SolidColorBrush(Colors.DeepSkyBlue));
                
                        area.Elements.Add(_candlesElem);
                        area.Elements.Add(_chartBollingerElement);

                        this.GuiAsync(() =>
                            {
                                foreach (var candle in candles)
                                    _chartWindow.Chart.ProcessCandle(_candlesElem, candle);
                            });
                                                        
                        _candleManager = new CandleManager(_trader);
                        
                        _series = new CandleSeries(typeof(TimeFrameCandle), security, (TimeSpan)AlfaTimeFrames.Minute10);
                        
                        _series.ProcessCandle += candle =>
                            {
                                if (candle.State == CandleStates.Finished || candle.State == CandleStates.Changed)
                                {
                                    var final = candle.State == CandleStates.Finished;
                                    
                                    var val = _chartBollingerElement.Indicator.Process(new DecimalIndicatorValue(candle.ClosePrice) { IsFinal = final });
                                    var bollingerValue = new ChartIndicatorValue(_chartBollingerElement.Indicator, val);

                                        this.GuiAsync(() => _chartWindow.Chart.ProcessValues(candle.OpenTime, new Dictionary<IChartElement, object>
                                                                                          {
                                                                                              {_candlesElem, candle},
                                                                                              {_chartBollingerElement, bollingerValue},
                                                                                          }));
                                }
                            };
                        
                        _candleManager.Start(_series);
                
                        _chartWindow.Show();
                    }
                }
            }
            catch (Exception exc)
            {
                MessageBox.Show(exc.ToString());
            }
        }
Thanks:

UsilaDobry

Avatar
Date: 6/20/2013
Reply


Изменил немного код вывода значений индикатора, картинка без изменений...

_series.ProcessCandle += candle =>
                            {
                                try
                                {
                                    if (candle.State == CandleStates.Finished)
                                    {
                                        var valueBb = _chartBollingerElement.Indicator.Process(new CandleIndicatorValue(candle) { IsFinal = true });
                                        this.GuiAsync(() => _chartWindow.Chart.ProcessValues(candle.OpenTime, new Dictionary<IChartElement, object>
                                                    {
                                                        {_candlesElem, candle},
                                                        {_chartBollingerElement, new ChartIndicatorValue(_chartBollingerElement.Indicator, valueBb)},
                                                    }));
                                    }
                                    else
                                    {
                                        this.GuiAsync(() => _chartWindow.Chart.ProcessCandle(_candlesElem, candle));
                                    }
                                }
                                catch (Exception exc)
                                {
                                    MessageBox.Show(exc.ToString());
                                }
                            };
Thanks:

UsilaDobry

Avatar
Date: 6/21/2013
Reply


При выводе реальных свечек AlfaTrader засыпает logFile каждые 5 секунд сообщениями

2013/06/21 10:15:08.168|       |AlfaTrader|StartExport()
2013/06/21 10:15:08.169|       |AlfaTrader|Экспорт в процессе запуска.
2013/06/21 10:15:08.174|       |AlfaTrader|Экспорт запущен.
2013/06/21 10:15:09.204|       |AlfaTrader|RegisterTrades: RTSI-9.13@FORTS
2013/06/21 10:15:09.236|       |AlfaTrader|create order: id = 117646314, tr. id = 853345110
2013/06/21 10:15:09.236|       |AlfaTrader|Создание ордера из терминала, tr. id 853345110
2013/06/21 10:15:09.244|       |AlfaTrader|update order: id = 117646314
2013/06/21 10:15:09.246|       |AlfaTrader|Order changed: 853345110/117646314 Покупка Цена=121000 Объем=1 Сост=Done Бал=1 
2013/06/21 10:15:09.249|       |AlfaTrader|New order: 853345110/117646314 Покупка Цена=121000 Объем=1 Сост=Done Бал=1 
2013/06/21 10:15:15.662|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 01.01.0001 0:00:00 - 21.06.2013 10:15:15
2013/06/21 10:15:17.308|       |AlfaTrader|RegisterQuotes: RTSI-9.13@FORTS
2013/06/21 10:15:18.185|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 01.01.0001 0:01:00 - 21.06.2013 10:16:18
2013/06/21 10:16:32.576|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:16:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.629|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.677|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.725|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.772|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.819|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.874|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.928|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:32.976|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:32
2013/06/21 10:16:33.024|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:33
2013/06/21 10:16:33.130|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:33
2013/06/21 10:16:33.183|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:33
2013/06/21 10:16:33.230|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:33
2013/06/21 10:16:33.278|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:33
2013/06/21 10:16:33.325|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:33
2013/06/21 10:16:38.326|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:38
2013/06/21 10:16:43.328|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:43
2013/06/21 10:16:48.336|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:48
2013/06/21 10:16:53.346|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:53
2013/06/21 10:16:58.352|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:17:58
2013/06/21 10:17:03.359|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:18:03
2013/06/21 10:17:08.366|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:17:00 - 21.06.2013 10:18:08
2013/06/21 10:17:13.376|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:13
2013/06/21 10:17:18.382|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:18
2013/06/21 10:17:23.388|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:23
2013/06/21 10:17:28.401|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:28
2013/06/21 10:17:33.407|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:33
2013/06/21 10:17:38.416|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:38
2013/06/21 10:17:43.419|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:43
2013/06/21 10:17:48.428|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:48
2013/06/21 10:17:53.438|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:53
2013/06/21 10:17:58.442|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:18:58
2013/06/21 10:18:03.451|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:19:03
2013/06/21 10:18:08.462|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:19:08
2013/06/21 10:18:13.468|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:19:13
2013/06/21 10:18:18.473|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:19:18
2013/06/21 10:18:23.480|       |AlfaTrader|GetLocalHistoryData: RTSI-9.13@FORTS, 21.06.2013 10:18:00 - 21.06.2013 10:19:23

Запустил простую стратегию для пробы, для контроля вывожу законченные свечи в debug, но законченные свечи не выводятся, свечи выводятся в debug каждые 5 секунд... И стратегия не понимает состояние свечки Finished, срабатывает на каждые 5 секунд... Возможно из-за этого и индикатор выводится не корректно?..

Код запуска стратегии

private void TradingBtn_Click(object sender, RoutedEventArgs e)
        {
            try
            {
                if (_strategyFirst == null)
                {
                    var security = SelectedSecurity;

                    _candleManager = new CandleManager(_trader);

                    _series = new CandleSeries(typeof(TimeFrameCandle), security, (TimeSpan)AlfaTimeFrames.Minute1);

                    _candleManager.Start(_series);

                    _series.ProcessCandle += candle =>
                    {
                        if (candle.State != CandleStates.Finished)
                            return;

                        Debug.WriteLine("{0}", candle.ToString());
                    };

                    _strategyFirst = new StrategyFirst(_series)
                        {
                            Trader = _trader,
                            Security = SelectedSecurity,
                            Portfolio = SelectedPortfolio,
                            Volume = 1
                        };

                    _strategyFirst.WhenOrderRegistered()
                                  .Do(order => this.GuiAsync(() => _chartWindow.Chart.ProcessValues(order.Time, new Dictionary<IChartElement, object> { { _chartOrderElement, order }, })))
                                  .Apply();
                    _strategyFirst.WhenNewMyTrades()
                                  .Do(trades => trades.ForEach(t => this.GuiAsync(() => _chartWindow.Chart.ProcessValues(t.Trade.Time, new Dictionary<IChartElement, object> { { _chartTradeElement, t }, }))))
                                  .Apply();

                    _strategyFirst.ProcessStateChanged += s =>
                                  {
                                      TradingBtn.Content = s.ProcessState == ProcessStates.Started
                                                                             ? "Cтоп"
                                                                             : "Старт";
                                  };

                    _trader.RegisterMarketDepth(SelectedSecurity);

                    _logManager.Sources.Add(_strategyFirst);

                    _strategyFirst.Start();

                }
                else if (_strategyFirst.ProcessState == ProcessStates.Stopping ||
                             _strategyFirst.ProcessState == ProcessStates.Stopped)
                {
                    // в ином случаем запускаем стратегию
                    _strategyFirst.Start();
                }
                else
                {
                    //или останавливаем
                    if (_strategyFirst.Position != 0)
                        _strategyFirst.ClosePosition();
                    _strategyFirst.Stop();
                }
            }
            catch (Exception exc)
            {
                MessageBox.Show(exc.ToString());
            }
        }

Код стратегии

using System;
using System.Windows;
using StockSharp.Algo.Candles;
using StockSharp.Algo.Strategies;
using StockSharp.Logging;

namespace MARKET_SUCCESS_ALFA
{
    class StrategyFirst : Strategy
    {
        private readonly CandleSeries _candleSeries;

        public StrategyFirst(CandleSeries series)
        {
            _candleSeries = series;
        }

        protected override void OnStarted()
        {
            try
            {
                _candleSeries.ProcessCandle += candle =>
                    {
                        if (candle.State != CandleStates.Finished) return;
                        //Получаем последнюю свечу
                        Candle candleLastFinish = _candleSeries.GetCandle<TimeFrameCandle>(0);
                        //Получаем предпослежнюю свечу
                        Candle candlePenultFinish = _candleSeries.GetCandle<TimeFrameCandle>(1);

                        //Сигнал на покупку
                        bool signalBuy = candleLastFinish.OpenPrice <
                                         candleLastFinish.ClosePrice;
                        signalBuy = signalBuy &&
                                    candlePenultFinish.OpenPrice <
                                    candlePenultFinish.ClosePrice;
                        signalBuy = signalBuy && Position == 0;

                        //Сигнал на закрытие длинной позиции
                        bool signalStopBuy = Position > 0;
                        signalStopBuy = signalStopBuy &&
                                        candleLastFinish.OpenPrice >
                                        candleLastFinish.ClosePrice;

                        //Сигнал на продажу
                        bool signalSell = candleLastFinish.OpenPrice >
                                          candleLastFinish.ClosePrice;
                        signalSell = signalSell &&
                                     candlePenultFinish.OpenPrice >
                                     candlePenultFinish.ClosePrice;
                        signalSell = signalSell && Position == 0;

                        //Сигнал на закрытие короткой позиции
                        bool signalStopSell = Position < 0;
                        signalStopSell = signalStopSell &&
                                         candleLastFinish.OpenPrice <
                                         candleLastFinish.ClosePrice;
                        //Реагируем на сигнал покупки
                        if (signalBuy)
                        {
                            //RegisterOrder(this.BuyAtLimit(Security.MaxPrice));
                            this.AddInfoLog("ОТКРЫВАЕМ ДЛИННУЮ позицию {0}.", candleLastFinish.CloseTime);
                        }
                        //Реагируем на сигнал закрытия позиции
                        if (signalStopBuy)
                        {
                            //RegisterOrder(this.SellAtLimit(Security.MinPrice));
                            this.AddInfoLog("ЗАКРЫВАЕМ ДЛИННУЮ позицию {0}.", candleLastFinish.CloseTime);
                        }
                        //Реагируем на сигнал продажи
                        if (signalSell)
                        {
                            //RegisterOrder(this.SellAtLimit(Security.MinPrice));
                            this.AddInfoLog("ОТКРЫВАЕМ КОРОТКУЮ позицию {0}.", candleLastFinish.CloseTime);
                        }
                        //Реагируем на сигнал закрытия позиции
                        if (signalStopSell)
                        {
                            //RegisterOrder(this.BuyAtLimit(Security.MaxPrice));
                            this.AddInfoLog("ЗАКРЫВАЕМ КОРОТКУЮ позицию {0}.", candleLastFinish.CloseTime);
                        }
                    };
            }
            catch (Exception exc)
            {
                MessageBox.Show(exc.ToString());  
            }
        }

        protected override void OnStopped()
        {

        }
    }
}

Вывод в debug

AlfaDirect - debug.jpg 165 KB (420)
Thanks:

Mikhail Sukhov

Avatar
Date: 6/21/2013
Reply


UsilaDobry: Изменил немного код вывода значений индикатора, картинка без изменений...

IIndicator.IsFormed проверяется?

Thanks:

UsilaDobry

Avatar
Date: 6/21/2013
Reply


Михаил Сухов:

UsilaDobry: Изменил немного код вывода значений индикатора, картинка без изменений...

IIndicator.IsFormed проверяется?

Разве свойство значения индикатора IsFinal = true не решает эту проверку? Значение окончательное, более неизменное в данный момент времени... У меня такое чувство, что значения индикатора считаются каждые 5 секунд по мере поступления исторических тиков, это как-то пересекается с моим предыдущим постом...

_series.ProcessCandle += candle =>
                            {
                                    if (candle.State == CandleStates.Finished)
                                    {
                                        var valueBb = _chartBollingerElement.Indicator.Process(new CandleIndicatorValue(candle) { IsFinal = true });
                                        this.GuiAsync(() => _chartWindow.Chart.ProcessValues(candle.OpenTime, new Dictionary<IChartElement, object>
                                                    {
                                                        {_candlesElem, candle},
                                                        {_chartBollingerElement, new ChartIndicatorValue(_chartBollingerElement.Indicator, valueBb)},
                                                    }));
                                    }
                                    else
                                    {
                                        this.GuiAsync(() => _chartWindow.Chart.ProcessCandle(_candlesElem, candle));
                                    }
                            };
Thanks:
< 1 2 3  >

Attach files by dragging & dropping, , or pasting from the clipboard.

loading
clippy