//+------------------------------------------------------------------+
//|                                         _TRO_jjrvat              |
//|   Copyright � 2008, Avery T. Horton, Jr. aka TheRumpledOne       |
//|                                                                  |
//|   PO BOX 43575, TUCSON, AZ 85733                                 |
//|                                                                  |
//|   GIFTS AND DONATIONS ACCEPTED                                   | 
//|                                                                  |
//|   therumpledone@gmail.com                                        |  
//+------------------------------------------------------------------+ 

#property  copyright "Copyright � 2008, Avery T. Horton, Jr. aka TRO" 
#property  link      "http://www.therumpledone.com/" 


#property indicator_separate_window
#property indicator_buffers 2
#property indicator_color1 Lime    
#property indicator_color2 DarkGreen         
     
   
//---- parameters
 
/*

extern double iParm3 = 6;
extern double iParm4 = 0;
extern double iParm5 = 3;
extern double iParm6 = 0;
extern double iParm7 = 0;
extern double iParm8 = 0;

*/

//---- buffers

   double     ExtBuffer0[];   
   double     ExtBuffer1[];

 

//+------------------------------------------------------------------+ 


 double iParm3 = 6;
 double iParm4 = 0;
 double iParm5 = 3;
 double iParm6 = 0;
 double iParm7 = 0;
 double iParm8 = 0;


 string myPair    = "";
 int    myBars    = 100;

double open    ;  
double close    ; 
double close1   ;  
double high    ;    
double high1    ;   
double low     ;    
double low1     ; 

double mid      ; 
double mid1    ; 


int pCount, qCount   ;


color  MaxColor, MinColor, TriggerColor ;

string PriceDir   ;
string MaxDir, MinDir ;
string tPeriod   ; 

double cHiCl, cClLo, cHi,  cLo,  cX, cVal , cVal1 ;
double pHiCl, pClLo, pHi,  pLo,  pX, pVal , pVal1 ;
double MaxVal  ;
double MinVal  ;
double pMaxVal  ;
double pMinVal  ;

bool LgBias, ShBias  ;

string Trigger, tBias ;

 
//+------------------------------------------------------------------+

int myPeriod = 0 ;



//+------------------------------------------------------------------+

string Arrow12 = "�"; // 12 oclock
string Arrow2  = "�";  // 2 oclock
string Arrow3  = "�";  // 3 oclock
string Arrow5  = "�";  // 5 oclock
string Arrow6  = "�";  // 6 oclock

 color N_color  = Lime;
 color NE_color = LimeGreen;
 color E_color  = Gold;
 color SE_color = Orange;
 color S_color  = Red;

//+------------------------------------------------------------------+

color fColor( double i)
{
color rColor ;

    if ( i ==  2 ) rColor = N_color  ; else {
    if ( i ==  1 ) rColor = NE_color  ; else {
    if ( i == -1 ) rColor = SE_color  ; else {
    if ( i == -2 ) rColor = S_color  ; else {     
                   rColor = E_color ; } } } }

return ( rColor );
}
//+------------------------------------------------------------------+

int fDirection( double i, double j )
{
int rDir ;

    if( i > j  )   rDir = 2;  else 
    if( i < j  )   rDir = -2; else     
                   rDir = 0; 
    
return ( rDir );
}


//+------------------------------------------------------------------+


string fCompass( double i )
{
string rCompass ;

    if ( i == 2 ) rCompass = Arrow12  ; else {
    if ( i == -2 ) rCompass = Arrow6  ; else {      
    rCompass = Arrow3 ; } } 
    
return ( rCompass );
}


//+------------------------------------------------------------------+

string TimeFrameToString(int tf)
{
   string tfs;
   switch(tf) {
      case PERIOD_MN1: tfs="MN"; break;
      case PERIOD_M1:  tfs="M1"  ; break;
      case PERIOD_M5:  tfs="M5"  ; break;
      case PERIOD_M15: tfs="M15" ; break;
      case PERIOD_M30: tfs="M30" ; break;
      case PERIOD_H1:  tfs="H1"  ; break;
      case PERIOD_H4:  tfs="H4"  ; break;
      case PERIOD_D1:  tfs="D1"  ; break;
      case PERIOD_W1:  tfs="W1"  ; break;
   }
   return(tfs);
} 

//+------------------------------------------------------------------+

int init()
{
   SetIndexBuffer(0,ExtBuffer0);
   SetIndexBuffer(1,ExtBuffer1);

   SetIndexStyle(0,DRAW_HISTOGRAM, EMPTY, 4, indicator_color1); 
   SetIndexStyle(1,DRAW_HISTOGRAM, EMPTY, 4, indicator_color2);
   
   

if (myPair == "") myPair = Symbol();
   

if( myPeriod == 0) myPeriod = Period() ;    


string tPeriod = TimeFrameToString(myPeriod) ;

IndicatorShortName("jjrvatx "+myPair+"("+tPeriod+")" );
    
return(0);
}

//+------------------------------------------------------------------+
int deinit()
  {
   return(0);
  }
  
//+------------------------------------------------------------------+
int start()
  {
  
   int counted_bars=IndicatorCounted();
   
   if(counted_bars<0) return(-1);
   
   if(counted_bars>0) counted_bars--;
   
   int bars=Bars-counted_bars;

int    i ;
double xVal, xVal1, xVal2 ;

//---- main calculation loop

while(bars>=0)
{          
       
LgBias = false; 
ShBias = false; 

Trigger = "Wait" ;

TriggerColor = Yellow ;

pMaxVal = 0 ;
pMinVal = 999999999 ;

MaxVal  = 0 ;
MinVal  = 999999999 ;

xVal  = iMA(NULL,myPeriod, 240 , 0 ,MODE_LWMA , PRICE_CLOSE , bars ) ;  

low   = iLow(NULL,myPeriod,bars) ;  
high  = iHigh(NULL,myPeriod,bars) ;  
close = iClose(NULL,myPeriod,bars) ; 

if(close > xVal) { LgBias = true ; tBias = "L" ; } else { ShBias = true ; tBias = "S" ;}

for(i = 1; i < myBars   ; i++ )
{
   xVal  = iMA(NULL,myPeriod, iParm3, iParm4, iParm5, iParm6, i ) ;  
   xVal1 = iMA(NULL,myPeriod, iParm3, iParm4, iParm5, iParm6, i+1 ) ;  
   xVal2 = iMA(NULL,myPeriod, iParm3, iParm4, iParm5, iParm6, i+2 ) ;  

if( MaxVal == 0 ) { if( xVal < xVal1 && xVal1 > xVal2) { MaxVal  = xVal1 ; } } 
else if( pMaxVal == 0 ) { if( xVal < xVal1 && xVal1 > xVal2) { pMaxVal = xVal1 ; } } 
   
if( MinVal == 999999999 ) { if( xVal > xVal1 && xVal1 < xVal2) { MinVal  = xVal1 ; } }  
else if( pMinVal == 999999999 ) { if( xVal > xVal1 && xVal1 < xVal2) { pMinVal = xVal1 ; } }    
   
 



cVal = iMA(NULL,myPeriod, 6 , 0 , MODE_LWMA, PRICE_CLOSE, bars ) ;   


                                                                                                                  
pCount   = fDirection( MaxVal , pMaxVal) ;

MaxColor = fColor( pCount ) ;

MaxDir   = fCompass( pCount ) ;

qCount   = fDirection( MinVal , pMinVal) ;

MinColor = fColor( qCount ) ;

MinDir   = fCompass( qCount ) ;


while(true)
{
if( LgBias && qCount == 2 && close > cVal && low < cVal && close > MinVal ) { ExtBuffer0[bars] = 1 ; break; }

if( ShBias && pCount == -2 && close < cVal && high > cVal && close < MaxVal ) { ExtBuffer0[bars] = -1 ; break; }

ExtBuffer0[bars] = 0 ; break;


} // while 

} // for i=
       
bars--; } // for bars=
 
return(0);

}

//+------------------------------------------------------------------+