OSC-MTF_CF_SYSv1.1





//+------------------------------------------------------------------+
//|                                               OSC-MTF_CF_SYS.mq4 |
//|                                                           kuncup |
//|                                                                  |
//+------------------------------------------------------------------+
#property copyright "kuncup"
#property link      "http://www.indofx-trader.net"

#property  indicator_buffers 6

#property  indicator_color1  Yellow
#property  indicator_color2  MediumOrchid
#property  indicator_color3  SteelBlue
#property  indicator_color4  Khaki


#property  indicator_width3 2
#property  indicator_width4 2

#property indicator_separate_window
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
extern string _.Method.Note = "0=SMA, 1=EMA, 2=SMMA, 3=WMA";
extern string _.AppliedPrice.Note = "0=Close, 1=Open, 2=High, 3=Low, 4=(H+L)/2, 5=(H+L+C)/3, 6=(H+L+C+C)/4";

extern string D1.Separator = "Daily MA";
extern int D1.HowManyBars = 0;
extern int MA1D1.Period = 8;
extern int MA1D1.Method = 1;
extern int MA1D1.AppliedPrice = 0;
extern int MA2D1.Period = 12;
extern int MA2D1.Method = 1;
extern int MA2D1.AppliedPrice = 0;
extern int MA3D1.Period = 24;
extern int MA3D1.Method = 1;
extern int MA3D1.AppliedPrice = 0;
extern int MA4D1.Period = 72;
extern int MA4D1.Method = 1;
extern int MA4D1.AppliedPrice = 0;

extern string H4.Separator = "H4 MA";
extern int H4.HowManyBars = 0;
extern int MA1H4.Period = 8;
extern int MA1H4.Method = 1;
extern int MA1H4.AppliedPrice = 0;
extern int MA2H4.Period = 12;
extern int MA2H4.Method = 1;
extern int MA2H4.AppliedPrice = 0;
extern int MA3H4.Period = 24;
extern int MA3H4.Method = 1;
extern int MA3H4.AppliedPrice = 0;
extern int MA4H4.Period = 72;
extern int MA4H4.Method = 1;
extern int MA4H4.AppliedPrice = 0;

extern string H1.Separator = "H1 MA";
extern int H1.HowManyBars = 20;
extern int MA1H1.Period = 8;
extern int MA1H1.Method = 1;
extern int MA1H1.AppliedPrice = 0;
extern int MA2H1.Period = 12;
extern int MA2H1.Method = 1;
extern int MA2H1.AppliedPrice = 0;
extern int MA3H1.Period = 24;
extern int MA3H1.Method = 1;
extern int MA3H1.AppliedPrice = 0;
extern int MA4H1.Period = 72;
extern int MA4H1.Method = 1;
extern int MA4H1.AppliedPrice = 0;

extern string M30.Separator = "M30 MA";
extern int M30.HowManyBars = 20;
extern int MA1M30.Period = 8;
extern int MA1M30.Method = 1;
extern int MA1M30.AppliedPrice = 0;
extern int MA2M30.Period = 12;
extern int MA2M30.Method = 1;
extern int MA2M30.AppliedPrice = 0;
extern int MA3M30.Period = 24;
extern int MA3M30.Method = 1;
extern int MA3M30.AppliedPrice = 0;
extern int MA4M30.Period = 72;
extern int MA4M30.Method = 1;
extern int MA4M30.AppliedPrice = 0;

extern string M15.Separator = "M15 MA";
extern int M15.HowManyBars = 20;
extern int MA1M15.Period = 8;
extern int MA1M15.Method = 1;
extern int MA1M15.AppliedPrice = 0;
extern int MA2M15.Period = 12;
extern int MA2M15.Method = 1;
extern int MA2M15.AppliedPrice = 0;
extern int MA3M15.Period = 24;
extern int MA3M15.Method = 1;
extern int MA3M15.AppliedPrice = 0;
extern int MA4M15.Period = 72;
extern int MA4M15.Method = 1;
extern int MA4M15.AppliedPrice = 0;

extern string M5.Separator = "M5 MA";
extern int M5.HowManyBars = 0;
extern int MA1M5.Period = 8;
extern int MA1M5.Method = 1;
extern int MA1M5.AppliedPrice = 0;
extern int MA2M5.Period = 12;
extern int MA2M5.Method = 1;
extern int MA2M5.AppliedPrice = 0;
extern int MA3M5.Period = 24;
extern int MA3M5.Method = 1;
extern int MA3M5.AppliedPrice = 0;
extern int MA4M5.Period = 72;
extern int MA4M5.Method = 1;
extern int MA4M5.AppliedPrice = 0;


double Ema1[];
double Ema2[];
double Ema3[];
double Ema4[];
double HighPrice[];
double LowPrice[];

int init()
  {
//---- indicators


   SetIndexBuffer(0,Ema1);
   SetIndexBuffer(1,Ema2);
   SetIndexBuffer(2,Ema3);
   SetIndexBuffer(3,Ema4);
   SetIndexBuffer(4,HighPrice);
   SetIndexBuffer(5,LowPrice);
   SetIndexStyle(0,DRAW_LINE);
   SetIndexStyle(1,DRAW_LINE);
   SetIndexStyle(2,DRAW_LINE);
   SetIndexStyle(3,DRAW_LINE);
   SetIndexStyle(4,DRAW_NONE);
   SetIndexStyle(5,DRAW_NONE);
   
  
   
   
   SetIndexEmptyValue(0, 0.0);
   SetIndexEmptyValue(1, 0.0);
   SetIndexEmptyValue(2, 0.0);
   SetIndexEmptyValue(3, 0.0);   
   IndicatorShortName("MTF MA Viewer");
//----
   return(0);
  }
//+------------------------------------------------------------------+
//| Custom indicator deinitialization function                       |
//+------------------------------------------------------------------+
int deinit()
  {
//----
   for(int i=0;i<D1.HowManyBars;i++){
      ObjectDelete("tlWickD1"+i);
      ObjectDelete("tlBodyD1"+i);
   }
   for(i=0;i<H4.HowManyBars;i++){
      ObjectDelete("tlWickH4"+i);
      ObjectDelete("tlBodyH4"+i);
   }
   for(i=0;i<H1.HowManyBars;i++){
      ObjectDelete("tlWickH1"+i);
      ObjectDelete("tlBodyH1"+i);
   }
   for(i=0;i<M30.HowManyBars;i++){
      ObjectDelete("tlWickM30"+i);
      ObjectDelete("tlBodyM30"+i);
   }
   for(i=0;i<M15.HowManyBars;i++){
      ObjectDelete("tlWickM15"+i);
      ObjectDelete("tlBodyM15"+i);
   }
   for(i=0;i<M5.HowManyBars;i++){
      ObjectDelete("tlWickM5"+i);
      ObjectDelete("tlBodyM5"+i);
   }
   
   if (WindowFind("TF D1") != -1) ObjectDelete("TF D1");
   if (WindowFind("TF H4") != -1) ObjectDelete("TF H4");
   if (WindowFind("TF H1") != -1) ObjectDelete("TF H1");
   if (WindowFind("TF M30") != -1) ObjectDelete("TF M30");
   if (WindowFind("TF M15") != -1) ObjectDelete("TF M15");
   if (WindowFind("TF M5") != -1) ObjectDelete("TF M5");
//----
   return(0);
  }
//+------------------------------------------------------------------+
//| Custom indicator iteration function                              |
//+------------------------------------------------------------------+
int start()
  {
   int    counted_bars=IndicatorCounted();
   //if (Period()>PERIOD_H1) return(0);
//----
   double cp,op,hp,lp;   
   int x=0;
   int BarCount=D1.HowManyBars;   
   color cl;
   double maxhp=0;
   for(int i=1;i<BarCount+1;i++){
      
      cp = iClose(NULL, PERIOD_D1, x);
      op = iOpen(NULL, PERIOD_D1, x);
      hp = iHigh(NULL, PERIOD_D1, x);
      lp = iLow(NULL, PERIOD_D1, x);
      if (cp > op){
         cl = DodgerBlue;       
      }else if(cp < op){
         cl = Red;         
      }else{
         cl = Green;        
      }
      
      DrawTl("tlWickD1"+x, Time[i], Time[i], lp, hp, cl, 1);
      DrawTl("tlBodyD1"+x, Time[i], Time[i], op, cp, cl, 3);
      HighPrice[i]=hp;
      LowPrice[i] =lp;
      if (hp>maxhp) maxhp=hp;
      
      Ema1[i] = iMA(NULL,PERIOD_D1,MA1D1.Period,0,MA1D1.Method,MA1D1.AppliedPrice,x);
      Ema2[i] = iMA(NULL,PERIOD_D1,MA2D1.Period,0,MA2D1.Method,MA2D1.AppliedPrice,x);
      Ema3[i] = iMA(NULL,PERIOD_D1,MA3D1.Period,0,MA3D1.Method,MA3D1.AppliedPrice,x);
      Ema4[i] = iMA(NULL,PERIOD_D1,MA4D1.Period,0,MA4D1.Method,MA4D1.AppliedPrice,x);
      x++;
   }

   if (BarCount!=0) 
   drawText("TF D1", maxhp+(15*Point), Silver, Time[i-1]);
   
   else 
   if(ObjectFind("TF D1") != -1) ObjectDelete("TF D1");
   
  //return(0);
   int lasti=i+1;
   x=0;
   BarCount=H4.HowManyBars;
   maxhp=0;
   for(i=lasti;i<lasti+BarCount;i++){
   
      cp = iClose(NULL, PERIOD_H4, x);
      op = iOpen(NULL, PERIOD_H4, x);
      hp = iHigh(NULL, PERIOD_H4, x);
      lp = iLow(NULL, PERIOD_H4, x);
      if (cp > op){
         cl = DodgerBlue;       
      }else if(cp < op){
         cl = Red;         
      }else{
         cl = Green;        
      }
      
      DrawTl("tlWickH4"+x, Time[i], Time[i], lp, hp, cl, 1);
      DrawTl("tlBodyH4"+x, Time[i], Time[i], op, cp, cl, 3);
      HighPrice[i]=hp;
      LowPrice[i] =lp;
      if (hp>maxhp) maxhp=hp;
      Ema1[i] = iMA(NULL,PERIOD_H4,MA1H4.Period,0,MA1H4.Method,MA1H4.AppliedPrice,x);
      Ema2[i] = iMA(NULL,PERIOD_H4,MA2H4.Period,0,MA2H4.Method,MA2H4.AppliedPrice,x);
      Ema3[i] = iMA(NULL,PERIOD_H4,MA3H4.Period,0,MA3H4.Method,MA3H4.AppliedPrice,x);
      Ema4[i] = iMA(NULL,PERIOD_H4,MA4H4.Period,0,MA4H4.Method,MA4H4.AppliedPrice,x);
      x++;
      
   }
   if (BarCount!=0) 
   drawText("TF H4", maxhp+(15*Point), Silver, Time[i-1]);
   else 
   if(ObjectFind("TF H4") != -1) ObjectDelete("TF H4");
   
   lasti=i+1;
   x=0;
   BarCount=H1.HowManyBars;
   maxhp=0;
   for(i=lasti;i<lasti+BarCount;i++){
   
      cp = iClose(NULL, PERIOD_H1, x);
      op = iOpen(NULL, PERIOD_H1, x);
      hp = iHigh(NULL, PERIOD_H1, x);
      lp = iLow(NULL, PERIOD_H1, x);
      if (cp > op){
         cl = DodgerBlue;       
      }else if(cp < op){
         cl = Red;         
      }else{
         cl = Green;        
      }
      
      DrawTl("tlWickH1"+x, Time[i], Time[i], lp, hp, cl, 1);
      DrawTl("tlBodyH1"+x, Time[i], Time[i], op, cp, cl, 3);
      HighPrice[i]=hp;
      LowPrice[i] =lp;
      if (hp>maxhp) maxhp=hp;
      
      Ema1[i] = iMA(NULL,PERIOD_H1,MA1H1.Period,0,MA1H1.Method,MA1H1.AppliedPrice,x);
      Ema2[i] = iMA(NULL,PERIOD_H1,MA2H1.Period,0,MA2H1.Method,MA2H1.AppliedPrice,x);
      Ema3[i] = iMA(NULL,PERIOD_H1,MA3H1.Period,0,MA3H1.Method,MA3H1.AppliedPrice,x);
      Ema4[i] = iMA(NULL,PERIOD_H1,MA4H1.Period,0,MA4H1.Method,MA4H1.AppliedPrice,x);
      x++;
      
   }
   if (BarCount!=0) 
   drawText("TF H1", maxhp+(15*Point) , Silver, Time[i-1]);
   else 
   if(ObjectFind("TF H1") != -1) ObjectDelete("TF H1");


   lasti=i+1;
   x=0;
   BarCount=M30.HowManyBars;
   maxhp=0;
   for(i=lasti;i<lasti+BarCount;i++){
   
      cp = iClose(NULL, PERIOD_M30, x);
      op = iOpen(NULL, PERIOD_M30, x);
      hp = iHigh(NULL, PERIOD_M30, x);
      lp = iLow(NULL, PERIOD_M30, x);
      if (cp > op){
         cl = DodgerBlue;       
      }else if(cp < op){
         cl = Red;         
      }else{
         cl = Green;        
      }
      
      DrawTl("tlWickM30"+x, Time[i], Time[i], lp, hp, cl, 1);
      DrawTl("tlBodyM30"+x, Time[i], Time[i], op, cp, cl, 3);
      HighPrice[i]=hp;
      LowPrice[i] =lp;
      if (hp>maxhp) maxhp=hp;
      
      Ema1[i] = iMA(NULL,PERIOD_M30,MA1M30.Period,0,MA1M30.Method,MA1M30.AppliedPrice,x);
      Ema2[i] = iMA(NULL,PERIOD_M30,MA2M30.Period,0,MA2M30.Method,MA2M30.AppliedPrice,x);
      Ema3[i] = iMA(NULL,PERIOD_M30,MA3M30.Period,0,MA3M30.Method,MA3M30.AppliedPrice,x);
      Ema4[i] = iMA(NULL,PERIOD_M30,MA4M30.Period,0,MA4M30.Method,MA4M30.AppliedPrice,x);
      x++;
      
   }
   if (BarCount!=0) 
   drawText("TF M30", maxhp+(15*Point)  ,Silver, Time[i-1]);
   else 
   if(ObjectFind("TF M30") != -1) ObjectDelete("TF M30");
   
   
   lasti=i+1;
   x=0;
   BarCount=M15.HowManyBars;
   maxhp=0;
   for(i=lasti;i<lasti+BarCount;i++){
   
      cp = iClose(NULL, PERIOD_M15, x);
      op = iOpen(NULL, PERIOD_M15, x);
      hp = iHigh(NULL, PERIOD_M15, x);
      lp = iLow(NULL, PERIOD_M15, x);
      if (cp > op){
         cl = Blue;       
      }else if(cp < op){
         cl = Red;         
      }else{
         cl = Green;        
      }
      
      DrawTl("tlWickM15"+x, Time[i], Time[i], lp, hp, cl, 1);
      DrawTl("tlBodyM15"+x, Time[i], Time[i], op, cp, cl, 3);
      HighPrice[i]=hp;
      LowPrice[i] =lp;
      if (hp>maxhp) maxhp=hp;
      
      Ema1[i] = iMA(NULL,PERIOD_M15,MA1M15.Period,0,MA1M15.Method,MA1M15.AppliedPrice,x);
      Ema2[i] = iMA(NULL,PERIOD_M15,MA2M15.Period,0,MA2M15.Method,MA2M15.AppliedPrice,x);
      Ema3[i] = iMA(NULL,PERIOD_M15,MA3M15.Period,0,MA3M15.Method,MA3M15.AppliedPrice,x);
      Ema4[i] = iMA(NULL,PERIOD_M15,MA4M15.Period,0,MA4M15.Method,MA4M15.AppliedPrice,x);
      x++;
      
   }
   if (BarCount!=0) 
   drawText("TF M15",maxhp+(15*Point)  ,Silver, Time[i-1]);
   else 
   if(ObjectFind("TF M15") != -1) ObjectDelete("TF M15");
   
   
   lasti=i+1;
   x=0;
   BarCount=M5.HowManyBars;
   maxhp=0;
   for(i=lasti;i<lasti+BarCount;i++){
   
      cp = iClose(NULL, PERIOD_M5, x);
      op = iOpen(NULL, PERIOD_M5, x);
      hp = iHigh(NULL, PERIOD_M5, x);
      lp = iLow(NULL, PERIOD_M5, x);
      if (cp > op){
         cl = Blue;       
      }else if(cp < op){
         cl = Red;         
      }else{
         cl = Green;        
      }
      
      DrawTl("tlWickM5"+x, Time[i], Time[i], lp, hp, cl, 1);
      DrawTl("tlBodyM5"+x, Time[i], Time[i], op, cp, cl, 3);
      HighPrice[i]=hp;
      LowPrice[i] =lp;
      if (hp>maxhp) maxhp=hp;
      
      Ema1[i] = iMA(NULL,PERIOD_M5,MA1M5.Period,0,MA1M5.Method,MA1M5.AppliedPrice,x);
      Ema2[i] = iMA(NULL,PERIOD_M5,MA2M5.Period,0,MA2M5.Method,MA2M5.AppliedPrice,x);
      Ema3[i] = iMA(NULL,PERIOD_M5,MA3M5.Period,0,MA3M5.Method,MA3M5.AppliedPrice,x);
      Ema4[i] = iMA(NULL,PERIOD_M5,MA4M5.Period,0,MA4M5.Method,MA4M5.AppliedPrice,x);
      x++;
      
   }
   if (BarCount!=0) 
   drawText("TF M5",maxhp+(15*Point) ,Silver, Time[i-1]);
   else 
   if(ObjectFind("TF M5") != -1) ObjectDelete("TF M5");      
   
   
   return(0);
  }
//+------------------------------------------------------------------+

void drawText(string name,double lvl,color Color, datetime  t)
{
    //string text_name = StringConcatenate(name);
    if(ObjectFind(name) != 0)
    {        
        ObjectCreate(name, OBJ_TEXT, WindowFind("MTF MA Viewer"), t, lvl);
        
        
    }
    ObjectSetText(name, name, 8, "Tahoma", EMPTY);
    ObjectSet(name, OBJPROP_COLOR, Color);
    ObjectMove(name, 0, t, lvl);

}

void DrawTl(string n, datetime from, datetime to, double p1, double p2,color c, int w){
   
   //n=StringConcatenate("",n);
   
   if (ObjectFind(n) != WindowFind("MTF MA Viewer"))
   {   
      ObjectCreate(n, OBJ_TREND, WindowFind("MTF MA Viewer"), from, p1, to , p2);      
   }else{
      ObjectMove(n, 0, from, p1);
      ObjectMove(n, 1, to, p2);     
   } 
   ObjectSet(n, OBJPROP_WIDTH, w);
   ObjectSet(n, OBJPROP_RAY, false);  
   ObjectSet(n, OBJPROP_COLOR, c); 
   ObjectSet(n, OBJPROP_BACK, true);
   WindowRedraw(); 
}





Sample





Analysis



Market Information Used:

Series array that contains close prices for each bar
Series array that contains open prices of each bar
Series array that contains the highest prices of each bar
Series array that contains the lowest prices of each bar
Series array that contains open time of each bar


Indicator Curves created:


Implements a curve of type DRAW_LINE
Implements a curve of type DRAW_NONE

Indicators Used:

Moving average indicator


Custom Indicators Used:

Order Management characteristics:

Other Features: