//+---------------------------------------------------------------------+ //| True_Range_Bands.mq5 | //| Copyright © 2010, basisforex@gmail.com | //| basisforex@gmail.com | //+---------------------------------------------------------------------+ //| Для работы индикатора следует положить файл SmoothAlgorithms.mqh | //| в папку (директорию): каталог_данных_терминала\\MQL5\Include | //+---------------------------------------------------------------------+ #property copyright "Copyright © 2012, basisforex@gmail.com" #property link "basisforex@gmail.com" #property description "True Range Bands" //---- номер версии индикатора #property version "1.10" //---- отрисовка индикатора в главном окне #property indicator_chart_window //---- количество индикаторных буферов 2 #property indicator_buffers 2 //---- использовано всего одно графическое построение #property indicator_plots 1 //+----------------------------------------------+ //| объявление констант | //+----------------------------------------------+ #define RESET 0 // Константа для возврата терминалу команды на пересчёт индикатора //+----------------------------------------------+ //| Параметры отрисовки индикатора | //+----------------------------------------------+ //---- отрисовка индикатора в виде облака #property indicator_type1 DRAW_FILLING //---- в качестве цветов облака индикатора использован #property indicator_color1 clrLightGray //---- отображение метки индикатора #property indicator_label1 "True Range Bands" //+----------------------------------------------+ //| Описание класса CXMA | //+----------------------------------------------+ #include //+----------------------------------------------+ //---- объявление переменных класса CXMA из файла SmoothAlgorithms.mqh CXMA XMA1; //+----------------------------------------------+ //| объявление перечислений | //+----------------------------------------------+ enum Applied_price_ //Тип константы { PRICE_CLOSE_ = 1, //Close PRICE_OPEN_, //Open PRICE_HIGH_, //High PRICE_LOW_, //Low PRICE_MEDIAN_, //Median Price (HL/2) PRICE_TYPICAL_, //Typical Price (HLC/3) PRICE_WEIGHTED_, //Weighted Close (HLCC/4) PRICE_SIMPL_, //Simpl Price (OC/2) PRICE_QUARTER_, //Quarted Price (HLOC/4) PRICE_TRENDFOLLOW0_, //TrendFollow_1 Price PRICE_TRENDFOLLOW1_, //TrendFollow_2 Price PRICE_DEMARK_ //Demark Price }; //+----------------------------------------------+ //| объявление перечислений | //+----------------------------------------------+ /*enum Smooth_Method - перечисление объявлено в файле SmoothAlgorithms.mqh { 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 uint Period_ATR=14; // период АТR input double Deviation = 1.618; // девиация input Smooth_Method XMA_Method=MODE_SMMA_; // метод усреднения input uint XLength=12; // глубина усреднения input int XPhase=15; // параметр сглаживания, //---- для JJMA изменяющийся в пределах -100 ... +100, влияет на качество переходного процесса; input Applied_price_ Applied_price=PRICE_CLOSE_; // тип цены или handle input int Shift=0; // Сдвиг индикатора по горизонтали в барах //+-----------------------------------+ //---- объявление динамических массивов, которые будут в // дальнейшем использованы в качестве индикаторных буферов double ExtLineBuffer1[],ExtLineBuffer2[]; //---- Объявление целых переменных для хранения хендлов индикаторов int ATR_Handle; //---- Объявление целых переменных начала отсчёта данных int min_rates_total; //+------------------------------------------------------------------+ //| True Range Bands indicator initialization function | //+------------------------------------------------------------------+ int OnInit() { //---- Инициализация переменных начала отсчёта данных min_rates_total=int(Period_ATR); int min_rates=GetStartBars(XMA_Method,XLength,XPhase); min_rates_total=MathMax(min_rates_total,min_rates); //---- получение хендла индикатора ATR ATR_Handle=iATR(NULL,0,Period_ATR); if(ATR_Handle==INVALID_HANDLE) { Print(" Не удалось получить хендл индикатора ATR"); return(INIT_FAILED); } //---- превращение динамических массивов в индикаторные буферы SetIndexBuffer(0,ExtLineBuffer1,INDICATOR_DATA); SetIndexBuffer(1,ExtLineBuffer2,INDICATOR_DATA); //---- установка позиции, с которой начинается отрисовка уровней PlotIndexSetInteger(0,PLOT_DRAW_BEGIN,min_rates_total); //---- осуществление сдвига индикатора 1 по горизонтали на Shift PlotIndexSetInteger(0,PLOT_SHIFT,Shift); //---- запрет на отрисовку индикатором пустых значений PlotIndexSetDouble(0,PLOT_EMPTY_VALUE,0.0); //---- индексация элементов в буферах как в таймсериях ArraySetAsSeries(ExtLineBuffer1,true); ArraySetAsSeries(ExtLineBuffer2,true); //---- инициализации переменной для короткого имени индикатора string shortname; StringConcatenate(shortname,"True Range Bands(",Period_ATR,")"); //--- создание имени для отображения в отдельном подокне и во всплывающей подсказке IndicatorSetString(INDICATOR_SHORTNAME,shortname); //--- определение точности отображения значений индикатора IndicatorSetInteger(INDICATOR_DIGITS,_Digits); //---- завершение инициализации return(INIT_SUCCEEDED); } //+------------------------------------------------------------------+ //| True Range Bands iteration function | //+------------------------------------------------------------------+ int OnCalculate( const int rates_total, // количество истории в барах на текущем тике const int prev_calculated,// количество истории в барах на предыдущем тике const datetime &time[], const double &open[], const double &high[], const double &low[], const double &close[], const long &tick_volume[], const long &volume[], const int &spread[] ) { //---- проверка количества баров на достаточность для расчёта if(BarsCalculated(ATR_Handle)rates_total || prev_calculated<=0)// проверка на первый старт расчёта индикатора { limit=rates_total-1; // стартовый номер для расчёта всех баров } else limit=rates_total-prev_calculated; // стартовый номер для расчёта новых баров //---- расчёт необходимого количества копируемых данных to_copy=limit+1; //---- копируем вновь появившиеся данные в массивы Range[] if(CopyBuffer(ATR_Handle,0,0,to_copy,Range)<=0) return(RESET); //---- индексация элементов в массивах как в таймсериях ArraySetAsSeries(Range,true); ArraySetAsSeries(open,true); ArraySetAsSeries(low,true); ArraySetAsSeries(high,true); ArraySetAsSeries(close,true); //---- основной цикл расчёта индикатора for(bar=limit; bar>=0 && !IsStopped(); bar--) { price=PriceSeries(Applied_price,bar,open,low,high,close); xma=XMA1.XMASeries(maxbar,prev_calculated,rates_total,XMA_Method,XPhase,XLength,price,bar,true); ATR=Range[bar]; if(price>xma) { ExtLineBuffer1[bar]=NormalizeDouble(xma+ATR*Deviation,_Digits); ExtLineBuffer2[bar]=NormalizeDouble(xma-ATR,_Digits); } else if(price>xma) { ExtLineBuffer1[bar]=NormalizeDouble(xma+ATR,_Digits); ExtLineBuffer2[bar]=NormalizeDouble(xma-ATR*Deviation,_Digits); } else { ExtLineBuffer1[bar]=NormalizeDouble(xma+ATR*Deviation,_Digits); ExtLineBuffer2[bar]=NormalizeDouble(xma-ATR*Deviation,_Digits); } } //---- return(rates_total); } //+------------------------------------------------------------------+