Autor original: Wellx
O wlxBW5ZoneAlert é um indicador de sinais de semáforo que utiliza os valores do Oscilador Acelerador e do Oscilador Maravilhoso, ambos de Bill Williams. Este indicador é uma mão na roda para traders, pois oferece alertas, além de enviar e-mails e notificações push para dispositivos móveis.
Para implementar essas funcionalidades, algumas modificações foram feitas no código do indicador:
- Novos parâmetros de entrada foram introduzidos:
input uint NumberofBar=1;//Número da barra para o sinal input bool SoundON=true;//Ativar alertas input uint NumberofAlerts=2;//Número de alertas input bool EMailON=false;//Ativar envio de e-mail do sinal input bool PushON=false;//Ativar envio de sinal para dispositivos móveis
- Adicionadas três novas funções ao final do código do indicador: BuySignal(), SellSignal() e GetStringTimeframe()
//+------------------------------------------------------------------+ //| Função de sinal de compra | //+------------------------------------------------------------------+ void BuySignal(string SignalSirname, // texto do nome do indicador para e-mail e mensagens push double &BuyArrow[], // buffer do indicador com sinais de compra const int Rates_total, // número atual de barras const int Prev_calculated, // número de barras no tick anterior const double &Close[], // preço de fechamento const int &Spread[]) // spread { u//--- static uint counter=0; if(Rates_total!=Prev_calculated) counter=0; bool BuySignal=false; bool SeriesTest=ArrayGetAsSeries(BuyArrow); int index; if(SeriesTest) index=int(NumberofBar); else index=Rates_total-int(NumberofBar)-1; if(NormalizeDouble(BuyArrow[index],_Digits) && BuyArrow[index]!=EMPTY_VALUE) BuySignal=true; if(BuySignal && counter<=NumberofAlerts) { counter++; MqlDateTime tm; TimeToStruct(TimeCurrent(),tm); string text=TimeToString(TimeCurrent(),TIME_DATE)+" "+string(tm.hour)+":"+string(tm.min); SeriesTest=ArrayGetAsSeries(Close); if(SeriesTest) index=int(NumberofBar); else index=Rates_total-int(NumberofBar)-1; double Ask=Close[index]; double Bid=Close[index]; SeriesTest=ArrayGetAsSeries(Spread); if(SeriesTest) index=int(NumberofBar); else index=Rates_total-int(NumberofBar)-1; Bid+=Spread[index]; string sAsk=DoubleToString(Ask,_Digits); string sBid=DoubleToString(Bid,_Digits); string sPeriod=GetStringTimeframe(ChartPeriod()); if(SoundON) Alert("Sinal de COMPRA Ask=",Ask," Bid=",Bid," currtime=",text," Símbolo=",Symbol()," Período=",sPeriod); if(EMailON) SendMail(SignalSirname+": alerta de sinal de COMPRA","Sinal de COMPRA em Ask="+sAsk+", Bid="+sBid+", Data="+text+" Símbolo="+Symbol()+" Período="+sPeriod); if(PushON) SendNotification(SignalSirname+": Sinal de COMPRA em Ask="+sAsk+", Bid="+sBid+", Data="+text+" Símbolo="+Symbol()+" Período="+sPeriod); } u//--- } //+------------------------------------------------------------------+ //| Função de sinal de venda | //+------------------------------------------------------------------+ void SellSignal(string SignalSirname, // texto do nome do indicador para e-mail e mensagens push double &SellArrow[], // buffer do indicador com sinais de venda const int Rates_total, // número atual de barras const int Prev_calculated, // número de barras no tick anterior const double &Close[], // preço de fechamento const int &Spread[]) // spread { u//--- static uint counter=0; if(Rates_total!=Prev_calculated) counter=0; bool SellSignal=false; bool SeriesTest=ArrayGetAsSeries(SellArrow); int index; if(SeriesTest) index=int(NumberofBar); else index=Rates_total-int(NumberofBar)-1; if(NormalizeDouble(SellArrow[index],_Digits) && SellArrow[index]!=EMPTY_VALUE) SellSignal=true; if(SellSignal && counter<=NumberofAlerts) { counter++; MqlDateTime tm; TimeToStruct(TimeCurrent(),tm); string text=TimeToString(TimeCurrent(),TIME_DATE)+" "+string(tm.hour)+":"+string(tm.min); SeriesTest=ArrayGetAsSeries(Close); if(SeriesTest) index=int(NumberofBar); else index=Rates_total-int(NumberofBar)-1; double Ask=Close[index]; double Bid=Close[index]; SeriesTest=ArrayGetAsSeries(Spread); if(SeriesTest) index=int(NumberofBar); else index=Rates_total-int(NumberofBar)-1; Bid+=Spread[index]; string sAsk=DoubleToString(Ask,_Digits); string sBid=DoubleToString(Bid,_Digits); string sPeriod=GetStringTimeframe(ChartPeriod()); if(SoundON) Alert("Sinal de VENDA Ask=",Ask," Bid=",Bid," currtime=",text," Símbolo=",Symbol()," Período=",sPeriod); if(EMailON) SendMail(SignalSirname+": alerta de sinal de VENDA","Sinal de VENDA em Ask="+sAsk+", Bid="+sBid+", Data="+text+" Símbolo="+Symbol()+" Período="+sPeriod); if(PushON) SendNotification(SignalSirname+": Sinal de VENDA em Ask="+sAsk+", Bid="+sBid+", Data="+text+" Símbolo="+Symbol()+" Período="+sPeriod); } u//--- } //+------------------------------------------------------------------+ //| Obtendo o período como string | //+------------------------------------------------------------------+ string GetStringTimeframe(ENUM_TIMEFRAMES timeframe) { //---- return(StringSubstr(EnumToString(timeframe),7,-1)); //---- }
- Chamadas para as funções BuySignal() e SellSignal() foram adicionadas após os ciclos de cálculo do indicador no bloco OnCalculate():
u//--- BuySignal("wlxBW5ZoneAlert",BuyBuffer,rates_total,prev_calculated,close,spread); SellSignal("wlxBW5ZoneAlert",SellBuffer,rates_total,prev_calculated,close,spread); u//---
Os buffers BuyBuffer e SellBuffer são os nomes dos buffers do indicador que armazenam os sinais de compra e venda. Os valores vazios nos buffers do indicador devem ser definidos como zeros ou EMPTY_VALUE.
É importante ressaltar que apenas uma chamada para as funções BuySignal() e SellSignal() deve ser feita no bloco OnCalculate() do código do indicador.
O indicador utiliza classes da biblioteca SmoothAlgorithms.mqh (copie para <terminal_data_folder>\\MQL5\Include). O uso das classes foi detalhadamente descrito no artigo "Média de Séries de Preço para Cálculos Intermediários sem Usar Buffers Adicionais".
Originalmente, este indicador foi escrito em MQL4 e foi publicado pela primeira vez na Base de Códigos em 08.03.2008.

Fig.1. O indicador wlxBW5ZoneAlert no gráfico
Fig.2. O indicador wlxBW5ZoneAlert. Gerando alertas.
Publicações relacionadas
- AllAverages v4.9 MT5: O Indicador Imperdível para Traders
- Buffers Horários para Coleta de Dados no MetaTrader 5
- Como Copiar e Colar Objetos Gráficos no MetaTrader 5 com o ChartObjectsCopyPaste
- EquiPeak Drawdown Tracker: Controle Eficiente para Seus EAs no MetaTrader 5
- Padrão de Negociação Crash Spike: Indicador para MetaTrader 5
