//+---------------------------------------------------------------------+ //| ColorJFatlAcceleration.mq5 | //| Copyright © 2010, Nikolay Kositsin | //| Khabarovsk, farria@mail.redcom.ru | //+---------------------------------------------------------------------+ //| Place the SmoothAlgorithms.mqh file | //| in the directory: terminal_data_folder\MQL5\Include | //+---------------------------------------------------------------------+ #property copyright "2010, Nikolay Kositsin" #property link "farria@mail.redcom.ru" #property version "1.00" //---- drawing the indicator in a separate window #property indicator_separate_window //---- three buffers are used for calculation and drawing the indicator #property indicator_buffers 3 //---- only three plots are used #property indicator_plots 2 //---- drawing the indicator as a line #property indicator_type1 DRAW_LINE //---- use gray color for the indicator #property indicator_color1 Gray //---- the indicator line is a continuous curve #property indicator_style1 STYLE_SOLID //---- indicator line width is equal to 2 #property indicator_width1 2 //---- displaying the indicator label #property indicator_label1 "JFATL Acceleration" //---- drawing the indicator as a label #property indicator_type2 DRAW_COLOR_ARROW //---- gray, dark orchid and red colors are used for the indicator #property indicator_color2 Gray,DarkOrchid,Red //---- the indicator line is a continuous curve #property indicator_style2 STYLE_SOLID //---- indicator line width is equal to 2 #property indicator_width2 2 //---- displaying the indicator label #property indicator_label2 "JFATL Acceleration" enum Applied_price_ // Type of constant { PRICE_CLOSE_ = 1, // PRICE_CLOSE PRICE_OPEN_, // PRICE_OPEN PRICE_HIGH_, // PRICE_HIGH PRICE_LOW_, // PRICE_LOW PRICE_MEDIAN_, // PRICE_MEDIAN PRICE_TYPICAL_, // PRICE_TYPICAL PRICE_WEIGHTED_, // PRICE_WEIGHTED PRICE_SIMPLE, // PRICE_SIMPLE PRICE_QUARTER_, // PRICE_QUARTER_ PRICE_TRENDFOLLOW0_, // PRICE_TRENDFOLLOW0 PRICE_TRENDFOLLOW1_ // PRICE_TRENDFOLLOW1 }; //+-----------------------------------+ //| Indicator input parameters | //+-----------------------------------+ input int LengthFatl=8; // JMA period of Fatl smoothing input int PhaseFatl=100; // JMA parameter of Fatl smoothing [-100...+100] input int SpeedPeriod=1; // Speed period input int AccelerationPeriod=1; // Acceleration period input int Smooth=2; // Indicator JMA smoothing depth input int SmPhase=100; // Indicator JMA smoothing parameter [-100...+100] input Applied_price_ IPC=PRICE_CLOSE_; // Applied price input int FATLShift=0; // Horizontal shift of the indicator in bars //---- declaration and initialization of a variable for storing the number of FATL calculated bars int FATLPeriod=39; //---- declaration of dynamic arrays that //---- will be used as indicator buffers double IndBuffer[]; double ColorBuffer[]; double LineIndBuffer[]; int start,fstart,jfstart,mstart,spstart,FATLSize; double dPriceShift; //+------------------------------------------------------------------+ //| iPriceSeries() function description | //| CFATL, CJJMA and CMomentum classes description | //+------------------------------------------------------------------+ #include //+------------------------------------------------------------------+ //| Custom indicator initialization function | //+------------------------------------------------------------------+ void OnInit() { //---- initialization of variables fstart=FATLPeriod; jfstart=fstart+30; mstart=jfstart+SpeedPeriod; spstart=mstart+30+1; start=spstart+AccelerationPeriod; //---- set LineIndBuffer[] dynamic array as an indicator buffer SetIndexBuffer(0,LineIndBuffer,INDICATOR_DATA); //---- shifting the indicator horizontally by FATLShift PlotIndexSetInteger(0,PLOT_SHIFT,FATLShift); //---- performing the shift of the beginning of the indicator drawing PlotIndexSetInteger(0,PLOT_DRAW_BEGIN,start); //---- restriction to draw empty values for the indicator PlotIndexSetDouble(0,PLOT_EMPTY_VALUE,0.0); //---- set IndBuffer[] dynamic array as an indicator buffer SetIndexBuffer(1,IndBuffer,INDICATOR_DATA); //---- shifting the indicator horizontally by FATLShift PlotIndexSetInteger(1,PLOT_SHIFT,FATLShift); //---- performing the shift of the beginning of the indicator drawing PlotIndexSetInteger(1,PLOT_DRAW_BEGIN,start); //---- restriction to draw empty values for the indicator PlotIndexSetDouble(1,PLOT_EMPTY_VALUE,0.0); //---- selecting a symbol for drawing PlotIndexSetInteger(1,PLOT_ARROW,159); //---- set ColorBuffer[] dynamic array as an indicator buffer SetIndexBuffer(2,ColorBuffer,INDICATOR_COLOR_INDEX); //---- performing the shift of the beginning of the indicator drawing PlotIndexSetInteger(2,PLOT_DRAW_BEGIN,start); //---- initializations of a variable for the indicator short name string shortname; StringConcatenate(shortname,"JFATL Acceleration(",LengthFatl," ,",PhaseFatl," ,",SpeedPeriod,")"); //---- creating a name for displaying in a separate sub-window and in a tooltip IndicatorSetString(INDICATOR_SHORTNAME,shortname); //---- determination of accuracy of displaying the indicator values IndicatorSetInteger(INDICATOR_DIGITS,0); //---- declaration of a variable of the CJJMA class CJJMA JMA; //---- setting up alerts for unacceptable values of external variables JMA.JJMALengthCheck("Length_", LengthFatl); JMA.JJMAPhaseCheck("Phase_", PhaseFatl); JMA.JJMALengthCheck("SpeedMomPeriod", SpeedPeriod); JMA.JJMALengthCheck("Smooth", Smooth); JMA.JJMAPhaseCheck("SmPhase", SmPhase); //---- } //+------------------------------------------------------------------+ //| Custom indicator iteration function | //+------------------------------------------------------------------+ int OnCalculate(const int rates_total, // number of bars in history at the current tick const int prev_calculated,// number of bars calculated at previous call 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[]) { //---- checking the number of bars to be enough for the calculation if(rates_totalrates_total || prev_calculated<=0) // checking for the first start of the indicator calculation { first=0; // starting index for calculation of all bars } else first=prev_calculated-1; // starting index for calculation of new bars //---- declaration of the CFATL, CJJMA and CMomentum classes variables static CJJMA JMA1,JMA2; static CFATL FATL; static CMomentum MOM1,MOM2; //---- main indicator calculation loop for(bar=first; barrates_total || prev_calculated<=0) first=start; //---- main loop of the signal line coloring for(bar=first; barIndBuffer[bar-1]) ColorBuffer[bar]=1; if(IndBuffer[bar]