Autor original:
RoboFx
O indicador Balance of Power (BOP) apresenta um histograma colorido que mostra a força e a direção da tendência atual, além de incluir alertas, envio de e-mails e notificações push para dispositivos móveis. As cores do histograma são determinadas pelos parâmetros de níveis de sobrecompra e sobrevenda, e pela direção do movimento do histograma.
Para implementar os alertas, mensagens por e-mail e notificações push, algumas alterações foram feitas no código do indicador:
- Novos parâmetros de entrada foram introduzidos:
//---- Variáveis de entrada para alertas
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 do sinal por e-mail
input bool PushON=false; //Ativar envio do sinal para dispositivos móveis - Três novas funções foram adicionadas 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-mails e mensagens push
double &ColorArray[],// buffer de índice de cor
int ColorIndex,// índice de cor no buffer de índice de cor para gerar um sinal
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
{
//---
static uint counter=0;
if(Rates_total!=Prev_calculated) counter=0;
bool BuySignal=false;
bool SeriesTest=ArrayGetAsSeries(ColorArray);
int index,index1;
if(SeriesTest)
{
index=int(NumberofBar);
index1=index+1;
}
else
{
index=Rates_total-int(NumberofBar)-1;
index1=index-1;
}
if(ColorArray[index1]!=ColorIndex && ColorArray[index]==ColorIndex) 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);
}
//---
}
//+------------------------------------------------------------------+
//| Função de Sinal de Venda |
//+------------------------------------------------------------------+
void SellSignal(string SignalSirname, // texto do nome do indicador para e-mails e mensagens push
double &ColorArray[], // buffer de índice de cor
int ColorIndex, // índice de cor no buffer de índice de cor para gerar um sinal
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
{
//---
static uint counter=0;
if(Rates_total!=Prev_calculated) counter=0;
bool SellSignal=false;
bool SeriesTest=ArrayGetAsSeries(ColorArray);
int index,index1;
if(SeriesTest)
{
index=int(NumberofBar);
index1=index+1;
}
else
{
index=Rates_total-int(NumberofBar)-1;
index1=index-1;
}
if(ColorArray[index1]!=ColorIndex && ColorArray[index]==ColorIndex) 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);
}
//---
}
//+------------------------------------------------------------------+
//| Obtendo o período como uma string |
//+------------------------------------------------------------------+
string GetStringTimeframe(ENUM_TIMEFRAMES timeframe)
{
//----
return(StringSubstr(EnumToString(timeframe),7,-1));
//----
} - Foram adicionadas chamadas para as funções BuySignal() e SellSignal() após os ciclos de cálculo do indicador no bloco OnCalculate():
//---
BuySignal("BalanceOfPower_Histogram_Alert",ColorIndBuffer,0,rates_total,prev_calculated,close,spread);
SellSignal("BalanceOfPower_Histogram_Alert",ColorIndBuffer,7,rates_total,prev_calculated,close,spread);
//---
A variável ColorIndBuffer é o nome do buffer de índice de cor que armazena a cor das velas na forma de um índice.
Supõe-se que haverá apenas uma chamada para as funções BuySignal() e SellSignal() no bloco OnCalculate() do código do indicador.
O indicador utiliza as classes da biblioteca SmoothAlgorithms.mqh (copie para <terminal_data_folder>\MQL5\Include). O uso das classes foi descrito detalhadamente no artigo "Média de Séries de Preços para Cálculos Intermediários sem Usar Buffers Adicionais".
Este indicador foi originalmente escrito em MQL5 e publicado pela primeira vez na Base de Código em 07.02.2013.

Fig1. O indicador BalanceOfPower_Histogram_Alert no gráfico
Fig.2. O indicador BalanceOfPower_Histogram_Alert gerando alertas.
Publicações relacionadas
- iMFISignAlert: O Indicador para MetaTrader 5 que Gera Alertas
- Informações da Conta: Indicador Essencial para MetaTrader 4
- i-Sessions: O Indicador Essencial para MetaTrader 5
- XMA_Keltner_Pivot_HTF: Um Indicador Essencial para MetaTrader 5
- iDeMarkerSignAlert: O Indicador de Sinalização para MetaTrader 5
