//+------------------------------------------------------------------+ //| 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(trendUpTrend_period) { CCITrendUp[i]=TrendCCI[i]; } } if(TrendCCI[i]<0 && TrendCCI[i+1]>0) { if(trendUp>Trend_period) trendDown=0; } if(TrendCCI[i]<0) { if(trendDownTrend_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; shiftEmaValue) LineHighEMA[shift]=EMPTY_VALUE; if(Close[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