//+---------------------------------------------------------------------+ //| CronexDeMarker_Signal.mq5 | //| Copyright © 2016, Nikolay Kositsin | //| Khabarovsk, farria@mail.redcom.ru | //+---------------------------------------------------------------------+ //| Для работы индикатора файл SmoothAlgorithms.mqh следует положить | //| в папку (директорию): каталог_данных_терминала\\MQL5\Include | //+---------------------------------------------------------------------+ #property copyright "Copyright © 2016, Nikolay Kositsin" #property link "farria@mail.redcom.ru" #property description "" //--- номер версии индикатора #property version "1.60" //--- отрисовка индикатора в отдельном окне #property indicator_separate_window //--- фиксированная высота подокна индикатора в пикселях #property indicator_height 20 //--- нижнее и верхнее ограничения шкалы отдельного окна индикатора #property indicator_maximum +1.9 #property indicator_minimum +0.3 //+----------------------------------------------+ //| объявление констант | //+----------------------------------------------+ #define RESET 0 // Константа для возврата терминалу команды на пересчет индикатора #define INDTOTAL 1 // Константа для количества отображаемых индикаторов #define INDICATOR_NAME "CronexDeMarker" // Константа для имени индикатора //+----------------------------------------------+ //--- количество индикаторных буферов #property indicator_buffers 4 // INDTOTAL*4 //--- использовано всего графических построений #property indicator_plots 2 // INDTOTAL*2 //+----------------------------------------------+ //| Параметры отрисовки индикатора 1 | //+----------------------------------------------+ //--- отрисовка индикатора 1 в виде линии #property indicator_type1 DRAW_COLOR_LINE //--- в качестве цвета линии индикатора использованы #property indicator_color1 clrTeal,clrMagenta //--- линия индикатора - штрих #property indicator_style1 STYLE_SOLID //--- толщина линии индикатора равна 2 #property indicator_width1 2 //--- отображение метки индикатора #property indicator_label1 "Signal line" //+----------------------------------------------+ //| Параметры отрисовки индикатора 2 | //+----------------------------------------------+ //--- отрисовка индикатора в виде четырехцветных значков #property indicator_type2 DRAW_COLOR_ARROW //--- в качестве цветов пятицветной гистограммы использованы #property indicator_color2 clrTeal,clrMagenta //--- линия индикатора - сплошная #property indicator_style2 STYLE_SOLID //--- толщина линии индикатора равна 5 #property indicator_width2 5 //--- отображение метки индикатора #property indicator_label2 "Signal Arrow" //+----------------------------------------------+ //| объявление перечислений | //+----------------------------------------------+ enum Smooth_Method { MODE_SMA_, // SMA MODE_EMA_, // EMA MODE_SMMA_, // SMMA MODE_LWMA_, // LWMA MODE_JJMA, // JJMA MODE_JurX, // JurX MODE_ParMA, // ParMA MODE_T3, // T3 MODE_VIDYA, // VIDYA MODE_AMA, // AMA }; //+----------------------------------------------+ //| Входные параметры индикатора | //+----------------------------------------------+ input ENUM_TIMEFRAMES TimeFrame=PERIOD_H4; // Период графика input uint DeMarkerPeriod=25; // период индикатора DeMarker input Smooth_Method XMA_Method=MODE_SMA_;// метод усреднения input uint FastPeriod=14; // период быстрого усреднения input uint SlowPeriod=25; // метод медленного усреднения input int XPhase=15; // параметр сглаживания, //---- для JJMA изменяющийся в пределах -100 ... +100, влияет на качество переходного процесса; //---- Для VIDIA это период CMO, для AMA это период медленной скользящей //+----------------------------------------------+ //--- объявление целочисленных переменных начала отсчета данных int min_rates_total; //+------------------------------------------------------------------+ //| Получение таймфрейма в виде строки | //+------------------------------------------------------------------+ string GetStringTimeframe(ENUM_TIMEFRAMES timeframe) {return(StringSubstr(EnumToString(timeframe),7,-1));} //+------------------------------------------------------------------+ //| Класс индикаторных буферов | //+------------------------------------------------------------------+ class CIndBuffers { //--- public: double m_LineBuffer[]; double m_ColorLineBuffer[]; double m_ArrowBuffer[]; double m_ColorArrowBuffer[]; int m_Handle; ENUM_TIMEFRAMES m_TimeFrame; //--- }; //--- объявление динамических массивов, которые в дальнейшем //--- будут использованы в качестве индикаторных буферов CIndBuffers Ind[INDTOTAL]; //+------------------------------------------------------------------+ //| CronexDeMarker indicator initialization function | //+------------------------------------------------------------------+ bool IndInit(uint Number) { //--- проверка периодов графиков на корректность if(Ind[Number].m_TimeFrameRates_Total || Prev_Calculated<=0)// проверка на первый старт расчета индикатора { limit_=Limit; LastCountBar[Number]=limit_; } else limit_=int(MathMin(LastCountBar[Number]+Limit,Rates_Total-2)); // стартовый номер для расчета новых баров //--- основной цикл расчета индикатора for(int bar=int(limit_); bar>=0 && !IsStopped(); bar--) { //--- обнулим содержимое индикаторных буферов до расчета Ind[Number].m_LineBuffer[bar]=Number+1.0; Ind[Number].m_ArrowBuffer[bar]=EMPTY_VALUE; Ind[Number].m_ColorLineBuffer[bar]=EMPTY_VALUE; Time0=Time[bar]; //--- копируем вновь появившиеся данные в массив if(CopyTime(Symbol(),Ind[Number].m_TimeFrame,Time0,1,Time_)<=0) return(RESET); if(Time0>=Time_[0] && Time[bar+1]=Dn[0]) { Ind[Number].m_ColorLineBuffer[bar]=0; Ind[Number].m_ColorArrowBuffer[bar]=0; } else { Ind[Number].m_ColorLineBuffer[bar]=1; Ind[Number].m_ColorArrowBuffer[bar]=1; } } if(Ind[Number].m_ColorLineBuffer[bar+1]!=EMPTY_VALUE && Ind[Number].m_ColorLineBuffer[bar]==EMPTY_VALUE) { Ind[Number].m_ColorLineBuffer[bar]=Ind[Number].m_ColorLineBuffer[bar+1]; } } //--- завершение расчета одного индикатора return(true); } //+------------------------------------------------------------------+ //| CronexDeMarker indicator initialization function | //+------------------------------------------------------------------+ int OnInit() { //--- инициализация переменных начала отсчета данных min_rates_total=3; //--- инициализация переменных Ind[0].m_TimeFrame=TimeFrame; //--- инициализация буферов индикаторов for(int count=0; countrates_total || prev_calculated<=0)// проверка на первый старт расчета индикатора limit=rates_total-min_rates_total-1; // стартовый номер для расчета всех баров else limit=rates_total-prev_calculated; // стартовый номер для расчета новых баров //--- индексация элементов в массивах как в таймсериях ArraySetAsSeries(time,true); for(int count=0; count