//+------------------------------------------------------------------+ //| MACDTradeSignals.mq4 | //| * | //| * | //+------------------------------------------------------------------+ #property copyright "*" #property link "*" #property indicator_chart_window #property indicator_buffers 6 #property indicator_color1 Aqua #property indicator_color2 DeepPink #property indicator_color3 Aqua #property indicator_color4 DeepPink #property indicator_color5 LightSkyBlue #property indicator_color6 Pink #property indicator_width1 1 #property indicator_width2 1 #property indicator_width3 3 #property indicator_width4 3 #property indicator_width5 1 #property indicator_width6 1 //---- input parameters extern int FastMAPeriod = 5; // Ïåðèîä áûñòðîé ÌÀ extern int FastMAMethod = 0; // Ìåòîä ñãëàæèâàíèÿ: 0-SMA, 1-EMA, 2-SMMA, 3-LWMA extern int FastMAPrice = 0; // Öåíà: 0-Close, 1-Open, 2-High, 3-Low, 4-Median, 5-Typical, 6-Weighted extern int SlowMAPeriod = 35; // Ïåðèîä ìåäëåííîé ÌÀ extern int SlowMAMethod = 0; // Ìåòîä ñãëàæèâàíèÿ: 0-SMA, 1-EMA, 2-SMMA, 3-LWMA extern int SlowMAPrice = 0; // Öåíà: 0-Close, 1-Open, 2-High, 3-Low, 4-Median, 5-Typical, 6-Weighted extern int SmPeriod = 15; // Ïåðèîä ñãëàæèâàíèÿ ñèãíàëüíîé ëèíèè extern int SmMethod = 0; // Ìåòîä ñãëàæèâàíèÿ: 0-SMA, 1-EMA, 2-SMMA, 3-LWMA extern bool Alert_0 = false; // Îêíî ñîîáùåíèå î ñèãíàëå íà íóëåâîì (ôîðìèðóþùåìñÿ) áàðå extern bool Sound_0 = true; // Çâóê î ñèãíàëå íà íóëåâîì áàðå, ïðè ýòîì äåëàåòñÿ âûâîä ñîîáùåíèÿ â æóðíàë - ìîæíî óâèäèòü êòî ñèãíàëèë extern string File_0 = "alert"; // Çâóêîâîé ôàéë, èãðàåìûé ïðè ñèãíàëå íà íóëåâîì áàðå extern bool Alert_1 = false; // Îêíî ñîîáùåíèå î ñèãíàëå íà ïåðâîì (ñôîðìèðîâàííîì) áàðå extern bool Sound_1 = true; // Çâóê î ñèãíàëå íà ïåðâîì áàðå, ïðè ýòîì äåëàåòñÿ âûâîä ñîîáùåíèÿ â æóðíàë - ìîæíî óâèäèòü êòî ñèãíàëèë extern string File_1 = "news"; // Çâóêîâîé ôàéë, èãðàåìûé ïðè ñèãíàëå íà ïåðâîì áàðå //---- buffers double Up1[]; double Dn1[]; double Up2[]; double Dn2[]; double ClUp[]; double ClDn[]; double macd[]; double sig[]; double pt; //+------------------------------------------------------------------+ //| Custom indicator initialization function | //+------------------------------------------------------------------+ int init() { pt=Point*PTA(Period()); //---- indicators IndicatorBuffers(8); SetIndexStyle(0,DRAW_ARROW); SetIndexArrow(0,233); SetIndexBuffer(0,Up1); SetIndexEmptyValue(0,0.0); SetIndexStyle(1,DRAW_ARROW); SetIndexArrow(1,234); SetIndexBuffer(1,Dn1); SetIndexEmptyValue(1,0.0); SetIndexStyle(2,DRAW_ARROW); SetIndexArrow(2,159); SetIndexBuffer(2,Up2); SetIndexEmptyValue(2,0.0); SetIndexStyle(3,DRAW_ARROW); SetIndexArrow(3,159); SetIndexBuffer(3,Dn2); SetIndexEmptyValue(3,0.0); SetIndexStyle(4,DRAW_ARROW); SetIndexArrow(4,251); SetIndexBuffer(4,ClUp); SetIndexEmptyValue(4,0.0); SetIndexStyle(5,DRAW_ARROW); SetIndexArrow(5,251); SetIndexBuffer(5,ClDn); SetIndexEmptyValue(5,0.0); SetIndexStyle(6,DRAW_LINE); SetIndexBuffer(6,macd); SetIndexStyle(7,DRAW_LINE); SetIndexBuffer(7,sig); //---- return(0); } //+------------------------------------------------------------------+ //| Custom indicator deinitialization function | //+------------------------------------------------------------------+ int deinit() { //---- //---- return(0); } //+------------------------------------------------------------------+ //| Custom indicator iteration function | //+------------------------------------------------------------------+ int start(){ /* Value1 = Average(Close, Length1)-Average(Close, Length2); Value2 = XAverage(value1,length3)[1]; Value3 = 0; if value1 crosses over 0 then buy ("EL1") this bar at close; if value1>0 and value1 crosses over value2 then buy ("EL2") this bar at close; if value1>0 and value1 crosses under value2 then exitlong ("XL") this bar at close; if value1 crosses under 0 then sell ("ES1") this bar at close; if value1<0 and value1 crosses under value2 then sell ("ES2") this bar at close; if value1<0 and value1 crosses over value2 then exitshort ("XS") this bar at close; */ int limit=Bars-IndicatorCounted()-1; for(int i=limit;i>=0;i--){ double fast_ma=iMA(NULL,0,FastMAPeriod,0,FastMAMethod,FastMAPrice,i); double slow_ma=iMA(NULL,0,SlowMAPeriod,0,SlowMAMethod,SlowMAPrice,i); macd[i]=fast_ma-slow_ma; } for(i=limit;i>=0;i--){ Up1[i]=0; Dn1[i]=0; Up2[i]=0; Dn2[i]=0; ClUp[i]=0; ClDn[i]=0; sig[i]=iMAOnArray(macd,0,SmPeriod,0,SmMethod,i); if(macd[i]>0){ if(macd[i+1]<=0){ Up1[i]=Low[i]-pt; } } if(macd[i]<0){ if(macd[i+1]>=0){ Dn1[i]=High[i]+pt; } } if(macd[i]>0){ if(macd[i]>sig[i]){ if(macd[i+1]<=sig[i+1]){ Up2[i]=Low[i]-pt; } } if(macd[i]<sig[i]){ if(macd[i+1]>=sig[i+1]){ ClUp[i]=High[i]+pt; } } } if(macd[i]<0){ if(macd[i]<sig[i]){ if(macd[i+1]>=sig[i+1]){ Dn2[i]=High[i]+pt; } } if(macd[i]>sig[i]){ if(macd[i+1]<=sig[i+1]){ ClDn[i]=Low[i]-pt; } } } } if(Alert_0 || Sound_0){ i=0; static datetime lt01=0; static datetime lt02=0; static datetime lt03=0; static datetime lt04=0; static datetime lt05=0; static datetime lt06=0; if(Up1[i]!=0){ if(Time[0]!=lt01){ lt01=Time[0]; if(Alert_0){ Alert("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": EL1 (0)"); } if(Sound_0){ PlaySound(File_0); Print("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": EL1 (0)"); } } } if(Dn1[i]!=0){ if(Time[0]!=lt02){ lt02=Time[0]; if(Alert_0){ Alert("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": ES1 (0)"); } if(Sound_0){ PlaySound(File_0); Print("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": ES1 (0)"); } } } if(Up2[i]!=0){ if(Time[0]!=lt03){ lt03=Time[0]; if(Alert_0){ Alert("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": EL2 (0)"); } if(Sound_0){ PlaySound(File_0); Print("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": EL2 (0)"); } } } if(Dn2[i]!=0){ if(Time[0]!=lt04){ lt04=Time[0]; if(Alert_0){ Alert("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": ES1 (0)"); } if(Sound_0){ PlaySound(File_0); Print("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": ES1 (0)"); } } } if(ClUp[i]!=0){ if(Time[0]!=lt05){ lt05=Time[0]; if(Alert_0){ Alert("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": XL (0)"); } if(Sound_0){ PlaySound(File_0); Print("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": XL (0)"); } } } if(ClDn[i]!=0){ if(Time[0]!=lt06){ lt06=Time[0]; if(Alert_0){ Alert("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": XS (0)"); } if(Sound_0){ PlaySound(File_0); Print("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": XS (0)"); } } } } if(Alert_1 || Sound_1){ i=1; static datetime lt11=0; static datetime lt12=0; static datetime lt13=0; static datetime lt14=0; static datetime lt15=0; static datetime lt16=0; if(Up1[i]!=0){ if(Time[0]!=lt11){ lt11=Time[0]; if(Alert_0){ Alert("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": EL1 (1)"); } if(Sound_0){ PlaySound(File_1); Print("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": EL1 (1)"); } } } if(Dn1[i]!=0){ if(Time[0]!=lt12){ lt12=Time[0]; if(Alert_0){ Alert("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": ES1 (1)"); } if(Sound_0){ PlaySound(File_1); Print("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": ES1 (1)"); } } } if(Up2[i]!=0){ if(Time[0]!=lt13){ lt13=Time[0]; if(Alert_0){ Alert("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": EL2 (1)"); } if(Sound_0){ PlaySound(File_1); Print("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": EL2 (1)"); } } } if(Dn2[i]!=0){ if(Time[0]!=lt14){ lt14=Time[0]; if(Alert_0){ Alert("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": ES1 (1)"); } if(Sound_0){ PlaySound(File_1); Print("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": ES1 (1)"); } } } if(ClUp[i]!=0){ if(Time[0]!=lt15){ lt15=Time[0]; if(Alert_0){ Alert("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": XL (1)"); } if(Sound_0){ PlaySound(File_1); Print("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": XL (1)"); } } } if(ClDn[i]!=0){ if(Time[0]!=lt16){ lt16=Time[0]; if(Alert_0){ Alert("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": XS (1)"); } if(Sound_0){ PlaySound(File_1); Print("MACDTS "+Symbol()+" "+fTimeFrameName(Period())+": XS (1)"); } } } } return(0); } //+------------------------------------------------------------------+ string fTimeFrameName(int arg){ int v; if(arg==0){ v=Period(); } else{ v=arg; } switch(v){ case 0: return("0"); case 1: return("M1"); case 5: return("M5"); case 15: return("M15"); case 30: return("M30"); case 60: return("H1"); case 240: return("H4"); case 1440: return("D1"); case 10080: return("W1"); case 43200: return("MN1"); default: return("M"+arg); } } int PTA(int aPeriod){ switch(aPeriod){ case PERIOD_M1: return(4); case PERIOD_M5: return(6); case PERIOD_M15: return(8); case PERIOD_M30: return(13); case PERIOD_H1: return(17); case PERIOD_H4: return(40); case PERIOD_D1: return(70); case PERIOD_W1: return(150); case PERIOD_MN1: return(300); } return(5); }
Sample
Analysis
Market Information Used:
Series array that contains the lowest prices of each bar
Series array that contains the highest prices of each bar
Series array that contains open time of each bar
Indicator Curves created:
Implements a curve of type DRAW_ARROW
Implements a curve of type DRAW_LINE
Indicators Used:
Moving average indicator
Custom Indicators Used:
Order Management characteristics:
Other Features:
It issuies visual alerts to the screen
It plays sound alerts