//+------------------------------------------------------------------+ //| MAMASign.mq5 | //| MQL5 Code: Copyright © 2015, Nikolay Kositsin | //| Khabarovsk, farria@mail.redcom.ru | //+------------------------------------------------------------------+ //--- авторство индикатора #property copyright "Copyright © 2015, Nikolay Kositsin" #property link "farria@mail.redcom.ru" //--- номер версии индикатора #property version "1.10" //--- отрисовка индикатора в основном окне #property indicator_chart_window //--- для расчёта и отрисовки индикатора использовано два буфера #property indicator_buffers 2 //--- использовано два графических построения #property indicator_plots 2 //+----------------------------------------------+ //| объявление констант | //+----------------------------------------------+ #define RESET 0 // Константа для возврата терминалу команды на пересчет индикатора //+----------------------------------------------+ //| Параметры отрисовки медвежьего индикатора | //+----------------------------------------------+ //--- отрисовка индикатора 1 в виде символа #property indicator_type1 DRAW_ARROW //--- в качестве цвета медвежьей линии индикатора использован DeepPink цвет #property indicator_color1 clrDeepPink //--- толщина линии индикатора 1 равна 4 #property indicator_width1 4 //--- отображение бычей метки индикатора #property indicator_label1 "LeadingSign Sell" //+----------------------------------------------+ //| Параметры отрисовки бычьго индикатора | //+----------------------------------------------+ //--- отрисовка индикатора 2 в виде символа #property indicator_type2 DRAW_ARROW //--- в качестве цвета бычей линии индикатора использован Blue цвет #property indicator_color2 clrBlue //--- толщина линии индикатора 2 равна 4 #property indicator_width2 4 //--- отображение медвежьей метки индикатора #property indicator_label2 "LeadingSign Buy" //+----------------------------------------------+ //| Входные параметры индикатора | //+----------------------------------------------+ 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_, //Simple Price (OC/2) PRICE_QUARTER_, //Quarted Price (HLOC/4) PRICE_TRENDFOLLOW0_, //TrendFollow_1 Price PRICE_TRENDFOLLOW1_, //TrendFollow_2 Price PRICE_DEMARK_ //Demark Price }; //+----------------------------------------------+ //| Входные параметры индикатора | //+----------------------------------------------+ input double FastLimit = 0.5; input double SlowLimit = 0.05; input Applied_price_ IPC=PRICE_CLOSE_;// Ценовая константа //+----------------------------------------------+ //--- объявление динамических массивов, которые в дальнейшем //--- будут использованы в качестве индикаторных буферов double SellBuffer[]; double BuyBuffer[]; //--- объявление целочисленных переменных для хендлов индикаторов int ATR_Handle; //--- объявление целочисленных переменных начала отсчета данных int min_rates_total; //+------------------------------------------------------------------+ //| CountVelue() function | //+------------------------------------------------------------------+ double CountVelue(double &Array1[],double &Array2[]) { //--- double Resalt= (0.0962*Array1[0] +0.5769*Array1[2] -0.5769*Array1[4] -0.0962*Array1[6]) *(0.075*Array2[1]+0.54); //--- return(Resalt); } //+------------------------------------------------------------------+ //| ReCountArray() function | //+------------------------------------------------------------------+ void ReCountArray(double &Array[]) { //--- Array[6]=Array[5]; Array[5]=Array[4]; Array[4]=Array[3]; Array[3]=Array[2]; Array[2]=Array[1]; Array[1]=Array[0]; //--- return; } //+------------------------------------------------------------------+ //| SmoothVelue() function | //+------------------------------------------------------------------+ double SmoothVelue(double &Array[]) { //--- return(0.2*Array[0]+0.8*Array[1]); } //+------------------------------------------------------------------+ //| Custom indicator initialization function | //+------------------------------------------------------------------+ int OnInit() { //--- инициализация глобальных переменных int ATR_Period=15; min_rates_total=int(MathMax(ATR_Period,7+1)); //--- получение хендла индикатора ATR ATR_Handle=iATR(NULL,0,ATR_Period); if(ATR_Handle==INVALID_HANDLE) { Print(" Не удалось получить хендл индикатора ATR"); return(INIT_FAILED); } //--- превращение динамического массива в индикаторный буфер SetIndexBuffer(0,SellBuffer,INDICATOR_DATA); //--- осуществление сдвига начала отсчёта отрисовки индикатора 1 PlotIndexSetInteger(0,PLOT_DRAW_BEGIN,min_rates_total); //--- символ для индикатора PlotIndexSetInteger(0,PLOT_ARROW,171); //--- превращение динамического массива в индикаторный буфер SetIndexBuffer(1,BuyBuffer,INDICATOR_DATA); //--- осуществление сдвига начала отсчёта отрисовки индикатора 2 PlotIndexSetInteger(1,PLOT_DRAW_BEGIN,min_rates_total); //--- символ для индикатора PlotIndexSetInteger(1,PLOT_ARROW,171); //--- инициализации переменной для короткого имени индикатора string shortname; StringConcatenate(shortname,"MAMASign(",FastLimit,", ",SlowLimit,")"); //--- создание имени для отображения в отдельном подокне и во всплывающей подсказке IndicatorSetString(INDICATOR_SHORTNAME,shortname); //--- определение точности отображения значений индикатора IndicatorSetInteger(INDICATOR_DIGITS,_Digits); //--- завершение инициализации return(INIT_SUCCEEDED); } //+------------------------------------------------------------------+ //| Custom indicator 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)1.50*period[1]) period[0]=1.50*period[1]; if(period[0]<0.67*period[1]) period[0]=0.67*period[1]; if(period[0]<6.00) period[0]=6.00; if(period[0]>50.0) period[0]=50.0; //--- period[0]=0.2*period[0]+0.8*period[1]; //--- if(I1[0]) Phase[0]=57.27272987*MathArctan(Q1[0]/I1[0]); else Phase[0]=57.27272987; //--- DeltaPhase=Phase[1]-Phase[0]; if(DeltaPhase<1) DeltaPhase=1.0; //--- alpha=FastLimit/DeltaPhase; if(alphaMAMA_ && FAMAMAMA) { //--- копируем вновь появившиеся данные в массив ATR[] if(CopyBuffer(ATR_Handle,0,time[bar],1,ATR)<=0) return(RESET); SellBuffer[bar]=high[bar]+ATR[0]*3/8; } //--- if(barOpen[bar])return(High[bar]); else { if(Close[bar]Open[bar])return((High[bar]+Close[bar])/2.0); else { if(Close[bar]Open[bar]) res=(res+High[bar])/2; if(Close[bar]==Open[bar]) res=(res+Close[bar])/2; return(((res-Low[bar])+(res-High[bar]))/2); } //--- default: return(Close[bar]); } } //+------------------------------------------------------------------+