Indicators Used
Miscellaneous
0
Views
0
Downloads
0
Favorites
CCI_Woodies_Lnx_v3_1_v3
//+------------------------------------------------------------------+
//| Real Woodie CCI.mq4 |
//| Based on the code of Jason Robinson (jnrtrading). |
//| |
//| After read the Woodie introductory document I started a search |
//| for the right coloured CCI. |
//| I can´t find anyone in accomplish with the explanation of Woodie |
//| So, I take the code from another CCI, and I added |
//| the center LSMA line according to the official explanation. |
//| Everything you see is an exact copy like it´s explained in the |
//| document new_woodie_do1. Specially the colors. |
//| If you have some doubts can obtain a copy |
//| from http://woodiescciclub.com/ |
//| |
//| Linuxser 2007 |
//| for any doubts or suggestions contact me on Forex-TSD forum |
//+------------------------------------------------------------------+
#property copyright "Under The GNU General Public License"
#property link "www.gnu.org"
//----
#property indicator_separate_window
#property indicator_buffers 8
#property indicator_color1 Blue
#property indicator_color2 Red
#property indicator_color3 Gray
#property indicator_color4 Gold
#property indicator_color5 Black
#property indicator_color6 Tomato
#property indicator_color7 Lime
#property indicator_color8 Red
//----
#property indicator_level1 300
#property indicator_level2 200
#property indicator_level3 100
#property indicator_level4 -100
#property indicator_level5 -200
#property indicator_level6 -300
//----
#property indicator_width1 2
#property indicator_width2 2
#property indicator_width3 2
#property indicator_width4 2
#property indicator_width5 2
#property indicator_width6 1
#property indicator_width7 2
#property indicator_width8 2
//----
#property indicator_levelcolor Silver
#property indicator_levelstyle STYLE_DOT
#property indicator_levelwidth 1
//---- input parameters
extern int TrendCCI_Period = 14;
extern int EntryCCI_Period = 6;
extern int LSMAPeriod = 25;
extern int EMAPeriod = 34;
extern int Trend_period=5;
extern string text1 = "-----------------------";
extern string text2 = "Mode 1 Shows LSMA hide EMA";
extern string text3 = "Mode 2 Shows EMA hide LSMA";
extern int MODE=1;
extern string text4="-----------------------";
extern bool ZeroLineCross_Alert=false;
extern int CountBars=500;
//----
double TrendCCI[];
double EntryCCI[];
double CCITrendUp[];
double CCITrendDown[];
double CCINoTrend[];
double CCITimeBar[];
double ZeroLine[];
double LSMABuffer1[];
double LSMABuffer2[];
int FromZero=0;
double LineHighEMA[];
double LineLowEMA[];
int trendUp,trendDown;
//+------------------------------------------------------------------+
//| Custom indicator initialization function |
//+------------------------------------------------------------------+
int init()
{
//---- indicators
SetIndexStyle(4,DRAW_LINE);
SetIndexBuffer(4,TrendCCI);
SetIndexLabel(4,"TrendCCI");
SetIndexStyle(0,DRAW_HISTOGRAM);
SetIndexBuffer(0,CCITrendUp);
SetIndexLabel(0,NULL);
SetIndexStyle(1,DRAW_HISTOGRAM);
SetIndexBuffer(1,CCITrendDown);
SetIndexLabel(1,NULL);
SetIndexStyle(2,DRAW_HISTOGRAM);
SetIndexBuffer(2,CCINoTrend);
SetIndexLabel(2,NULL);
SetIndexStyle(3,DRAW_HISTOGRAM);
SetIndexBuffer(3,CCITimeBar);
SetIndexLabel(3,NULL);
SetIndexStyle(5,DRAW_LINE);//
SetIndexBuffer(5,EntryCCI);
SetIndexLabel(5,"EntryCCI");
SetIndexStyle(6,DRAW_LINE);
SetIndexBuffer(6,LSMABuffer2);
SetIndexLabel(6,NULL);
SetIndexArrow(6,159);
SetIndexStyle(7,DRAW_LINE);
SetIndexBuffer(7,LSMABuffer1);
SetIndexArrow(7,159);
SetIndexLabel(7,NULL);
//----
return(0);
}
//+------------------------------------------------------------------+
//| Custor indicator deinitialization function |
//+------------------------------------------------------------------+
int deinit()
{
//----
//----
return(0);
}
//+------------------------------------------------------------------+
//| Custom indicator iteration function |
//+------------------------------------------------------------------+
int start()
{
int limit,i,trendCCI,entryCCI;
static datetime prevtime=0;
//---- check for possible errors
int counted_bars=IndicatorCounted();
if(counted_bars<0) return(-1);
if(counted_bars>0) counted_bars--;
limit=Bars-counted_bars;
if(counted_bars==0) limit-=1+MathMax(1,Trend_period);
//----
/*SetIndexDrawBegin(0,Bars-CountBars);
SetIndexDrawBegin(1,Bars-CountBars);
SetIndexDrawBegin(2,Bars-CountBars);
SetIndexDrawBegin(3,Bars-CountBars);
SetIndexDrawBegin(4,Bars-CountBars);
SetIndexDrawBegin(5,Bars-CountBars);
SetIndexDrawBegin(6,Bars-CountBars);
SetIndexDrawBegin(7,Bars-CountBars);*/
//----
trendCCI=TrendCCI_Period;
entryCCI=EntryCCI_Period;
//----
IndicatorShortName("[CCI: "+trendCCI+"] [TCCI: "+entryCCI+"] [per LSMA: "+LSMAPeriod+"] [Trend: "+Trend_period+"] Values CCI|TCCI:");
int xSize=ArraySize(CCINoTrend);
ArrayResize(ZeroLine,xSize);
ArrayResize(LineLowEMA,xSize);
ArrayResize(LineHighEMA,xSize);
for(i=limit; i>=0; i--)
{
CCINoTrend[i]=0;
CCITrendDown[i]=0;
CCITimeBar[i]=0;
CCITrendUp[i]=0;
ZeroLine[i]=0;
TrendCCI[i]=iCCI(NULL, 0, trendCCI, PRICE_TYPICAL, i);
EntryCCI[i]=iCCI(NULL, 0, entryCCI, PRICE_TYPICAL, i);
//----
if(TrendCCI[i]>0 && TrendCCI[i+1]<0)
{
if(trendDown>Trend_period) trendUp=0;
}
if(TrendCCI[i]>0)
{
if(trendUp<Trend_period)
{
CCINoTrend[i]=TrendCCI[i];
trendUp++;
}
if(trendUp==Trend_period)
{
CCITimeBar[i]=TrendCCI[i];
trendUp++;
}
if(trendUp>Trend_period)
{
CCITrendUp[i]=TrendCCI[i];
}
}
if(TrendCCI[i]<0 && TrendCCI[i+1]>0)
{
if(trendUp>Trend_period) trendDown=0;
}
if(TrendCCI[i]<0)
{
if(trendDown<Trend_period)
{
CCINoTrend[i]=TrendCCI[i];
trendDown++;
}
if(trendDown==Trend_period)
{
CCITimeBar[i]=TrendCCI[i];
trendDown++;
}
if(trendDown>Trend_period)
{
CCITrendDown[i]=TrendCCI[i];
}
}
}
//---- Color Middle Line LSMA
double sum,lengthvar,tmp,wt;
int shift;
int Draw4HowLong,loopbegin;
//----
counted_bars=limit;
for(shift=0; shift<counted_bars; shift++)
{
LineLowEMA[shift]=-FromZero;
LineHighEMA[shift]=-FromZero;
//----
double EmaValue=iMA(NULL,0,EMAPeriod,0,MODE_EMA,PRICE_TYPICAL,shift);
if(Close[shift]>EmaValue) LineHighEMA[shift]=EMPTY_VALUE;
if(Close[shift]<EmaValue) LineLowEMA[shift]=EMPTY_VALUE;
}
loopbegin=limit-LSMAPeriod;
//----
for(shift=loopbegin; shift>=0; shift--)
{
sum=0;
for(i=LSMAPeriod; i>=1; i--)
{
lengthvar=LSMAPeriod+1;
lengthvar/=3;
tmp=0;
tmp=(i - lengthvar) * Close[LSMAPeriod-i+shift];
sum+=tmp;
}
wt=sum*6/(LSMAPeriod *(LSMAPeriod+1));
LSMABuffer1[shift]=0;
LSMABuffer2[shift]=0;
//----
if(wt>Close[shift]) LSMABuffer2[shift]=EMPTY_VALUE;
if(wt<Close[shift]) LSMABuffer1[shift]=EMPTY_VALUE;
}
//----
return(0);
}
//+------------------------------------------------------------------+
Comments
Markdown Formatting Guide
# H1
## H2
### H3
**bold text**
*italicized text*
[title](https://www.example.com)

`code`
```
code block
```
> blockquote
- Item 1
- Item 2
1. First item
2. Second item
---