//+------------------------------------------------------------------+ //| SlopeDirectionLine_HTF.mq5 | //| Copyright © 2008, asystem2000 | //| thefuturemaster@hotmail.com | //+------------------------------------------------------------------+ #property copyright "Copyright © 2008, asystem2000" #property link "thefuturemaster@hotmail.com" //--- Indicator version #property version "1.00" #property description "SlopeDirectionLine" //--- drawing the indicator in the main window #property indicator_chart_window //---- number of indicator buffers is 2 #property indicator_buffers 2 //--- one plot is used #property indicator_plots 1 //+-------------------------------------+ //| Declaration of constants | //+-------------------------------------+ #define RESET 0 // A constant for returning the indicator recalculation command to the terminal #define INDICATOR_NAME "SlopeDirectionLine" // A constant for the indicator name #define SIZE 3 // A constant for the number of calls of the CountIndicator function in the code //+-------------------------------------+ //| Indicator drawing parameters | //+-------------------------------------+ //---- drawing the indicator as a multicolored line #property indicator_type1 DRAW_COLOR_LINE //---- the following colors are used in a three-color line #property indicator_color1 clrDeepPink,clrGray,clrDarkViolet //---- the indicator line is a continuous curve #property indicator_style1 STYLE_SOLID //--- indicator line width is 3 #property indicator_width1 3 #property indicator_label1 INDICATOR_NAME+" HTF" //+-------------------------------------+ //| Declaration of enumerations | //+-------------------------------------+ enum Applied_price_ //Type of constant { 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 }; //+-------------------------------------+ //| Declaration of enumerations | //+-------------------------------------+ 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 }; //+-------------------------------------+ //| Indicator input parameters | //+-------------------------------------+ input ENUM_TIMEFRAMES TimeFrame=PERIOD_H4; // Indicator chart period (timeframe) input Smooth_Method MA_Method1=MODE_LWMA; // Method of the first averaging input uint Length1=12; // Depth of the first averaging input int Phase1=15; // First smoothing parameter //--- Phase1: for JJMA it varies within the range -100 ... +100 and influences the quality of the transient period; //--- Phase1: for VIDIA it is a CMO period, for AMA it is a slow average period input Smooth_Method MA_Method2=MODE_SMA; // Method of averaging of the second smoothing input int Phase2=15; // Parameter o the second smoothing //--- Phase2: for JJMA it varies within the range -100 ... +100 and influences the quality of the transient period; //--- Phase2: for VIDIA it is a CMO period, for AMA it is a slow average period input Applied_price_ IPC=PRICE_CLOSE; // Price constant input int Shift=0; // Horizontal shift of the indicator in bars input int PriceShift=0; // Vertical shift of the indicator in points input bool On_Push = false; // Allow push notifications input bool On_Email = false; // Allow emails input bool On_Alert = true; // Allow sending alerts input bool On_Play_Sound = false; // Allow playing a sound signal input string NameFileSound = "expert.wav"; // The name of a sound file input string CommentSirName="SlopeDirectionLine: "; // The first part of the alert comment input uint SignalBar=1; // Bar number for the signal //+-------------------------------------+ //--- declaration of dynamic arrays that //--- will be used as indicator buffers double IndBuffer[]; double ColorIndBuffer[]; //--- declaration of the integer variables for the start of data calculation int min_rates_total; //--- declaration of integer variables for the indicators handles int Ind_Handle; //+------------------------------------------------------------------+ //| Getting a timeframe as a line | //+------------------------------------------------------------------+ string GetStringTimeframe(ENUM_TIMEFRAMES timeframe) {return(StringSubstr(EnumToString(timeframe),7,-1));} //+------------------------------------------------------------------+ //| Custom indicator initialization function | //+------------------------------------------------------------------+ int OnInit() { //--- Checking correctness of the chart periods if(!TimeFramesCheck(INDICATOR_NAME,TimeFrame)) return(INIT_FAILED); //--- initialization of variables min_rates_total=2; //--- getting the handle of the SlopeDirectionLine indicator Ind_Handle=iCustom(Symbol(),TimeFrame,"SlopeDirectionLine",MA_Method1,Length1,Phase1,MA_Method2,Phase2, IPC,0,PriceShift,On_Push,On_Email,On_Alert,On_Play_Sound,NameFileSound,CommentSirName,SignalBar); if(Ind_Handle==INVALID_HANDLE) { Print(" Failed to get the handle of the SlopeDirectionLine indicator"); return(INIT_FAILED); } //--- Initialize indicator buffers IndInit(0,IndBuffer,0.0,min_rates_total,Shift); //--- Set dynamic array as an indicator buffer SetIndexBuffer(1,ColorIndBuffer,INDICATOR_DATA); ArraySetAsSeries(ColorIndBuffer,true); //--- Creation of the name to be displayed in a separate sub-window and in a pop up help string shortname; StringConcatenate(shortname,INDICATOR_NAME,"(",GetStringTimeframe(TimeFrame),")"); IndicatorSetString(INDICATOR_SHORTNAME,shortname); //--- Determining the accuracy of displaying the indicator values IndicatorSetInteger(INDICATOR_DIGITS,_Digits); //--- initialization end return(INIT_SUCCEEDED); } //+------------------------------------------------------------------+ //| Custom iteration function | //+------------------------------------------------------------------+ int OnCalculate(const int rates_total, // number of bars in history at the current tick const int prev_calculated,// amount of history in bars at the previous tick 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 if the number of bars is enough for the calculation if(rates_totalRates_Total || Prev_Calculated<=0)// Checking for the first start of the indicator calculation { limit=Rates_Total-min_rates_total-1; // Starting index for calculation of all bars LastCountBar[Numb]=limit; } else limit=LastCountBar[Numb]+Rates_Total-Prev_Calculated; // Starting index for calculation of new bars //--- main indicator calculation loop for(int bar=limit; bar>=0 && !IsStopped(); bar--) { //---- reset the contents of the indicator buffers for calculation IndBuf[bar]=0.0; //---- Copy new data to the IndTime array if(CopyTime(Symbol(),TFrame,iTime[bar],1,IndTime)<=0) return(RESET); if(iTime[bar]>=IndTime[0] && iTime[bar+1]