Inicio Indicador técnico Publicación

Waddah_Attar_Trend_Alert: El Indicador Perfecto para Alertas en MetaTrader 5

Archivos adjuntos
16832.zip (22.5 KB, Descargar 0 veces)

Autor Real: Ing. Waddah Attar

El indicador Waddah_Attar_Trend incluye alertas, correos electrónicos y notificaciones push para facilitar tu trading.

A continuación, te mostramos los cambios realizados en el código del indicador para implementar estas funcionalidades:

  1. Se añadieron nuevos parámetros de entrada:
    //---- Entradas para alertas 
    input uint NumberofBar=1;                    //Número de barra para la señal
    input bool SoundON=true;                    //Activar alertas
    input uint NumberofAlerts=2;                    //Número de alertas
    input bool EMailON=false;                    //Habilitar envío de correos electrónicos
    input bool PushON=false;                    //Habilitar envío de notificaciones a dispositivos móviles
    
  2. Se añadieron tres nuevas funciones al final del código del indicador: BuySignal(), SellSignal() y GetStringTimeframe().
    //+------------------------------------------------------------------+
    //| Función de señal de compra                                              |
    //+------------------------------------------------------------------+
    void BuySignal(string SignalSirname,// texto del nombre del indicador para mensajes de correo y push
    double &ColorArray[],// buffer de índice de color
    int ColorIndex,// índice de color en el buffer para generar una señal
    const int Rates_total, // número total de barras
    const int Prev_calculated, // número de barras en el tick anterior
    const double &Close[], // precio de cierre
    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+=_Point*Spread[index];
    string sAsk=DoubleToString(Ask,_Digits);
    string sBid=DoubleToString(Bid,_Digits);
    string sPeriod=GetStringTimeframe(ChartPeriod());
    if(SoundON) Alert("Señal de COMPRA Ask=",Ask," Bid=",Bid," hora actual=",text," Símbolo=",Symbol()," Period=",sPeriod);
    if(EMailON) SendMail(SignalSirname+": Alerta de señal de COMPRA","Señal de COMPRA en Ask="+sAsk+", Bid="+sBid+", Fecha="+text+" Símbolo="+Symbol()+" Period="+sPeriod);
    if(PushON) SendNotification(SignalSirname+": Se ha generado una señal de COMPRA en Ask="+sAsk+", Bid="+sBid+", Fecha="+text+" Símbolo="+Symbol()+" Period="+sPeriod);
    }

    //---
    }
    //+------------------------------------------------------------------+
    //| Función de señal de venta                                             |
    //+------------------------------------------------------------------+
    void SellSignal(string SignalSirname, // texto del nombre del indicador para mensajes de correo y push
    double &ColorArray[], // buffer de índice de color
    int ColorIndex, // índice de color en el buffer para generar una señal
    const int Rates_total, // número total de barras
    const int Prev_calculated, // número de barras en el tick anterior
    const double &Close[], // precio de cierre
    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+=_Point*Spread[index];
    string sAsk=DoubleToString(Ask,_Digits);
    string sBid=DoubleToString(Bid,_Digits);
    string sPeriod=GetStringTimeframe(ChartPeriod());
    if(SoundON) Alert("Señal de VENTA Ask=",Ask," Bid=",Bid," hora actual=",text," Símbolo=",Symbol()," Period=",sPeriod);
    if(EMailON) SendMail(SignalSirname+": Alerta de señal de VENTA","Señal de VENTA en Ask="+sAsk+", Bid="+sBid+", Fecha="+text+" Símbolo="+Symbol()+" Period="+sPeriod);
    if(PushON) SendNotification(SignalSirname+": Se ha generado una señal de VENTA en Ask="+sAsk+", Bid="+sBid+", Fecha="+text+" Símbolo="+Symbol()+" Period="+sPeriod);
    }
    //---
    }
    //+------------------------------------------------------------------+
    //| Obtención de un marco temporal como cadena                                  |
    //+------------------------------------------------------------------+
    string GetStringTimeframe(ENUM_TIMEFRAMES timeframe)
    {
    //----
    return(StringSubstr(EnumToString(timeframe),7,-1));
    //----
    }
  3. Se añadieron un par de llamadas a las funciones BuySignal() y SellSignal() después de los ciclos de cálculo del indicador en el bloque OnCalculate():
    //---
    BuySignal("Waddah_Attar_Trend_Alert",ColorIndBuffer,0,rates_total,prev_calculated,close,spread);
    SellSignal("Waddah_Attar_Trend_Alert",ColorIndBuffer,1,rates_total,prev_calculated,close,spread);
    //---

donde ColorIndBuffer es el nombre de un buffer de índice de color para almacenar el color de la línea como un índice, mientras que 0 y 1 son los números de colores en el buffer de índice de color.

Se asume que solo se usará una llamada a las funciones BuySignal() y SellSignal() en el bloque OnCalculate() del código del indicador.

El indicador utiliza las clases de la biblioteca SmoothAlgorithms.mqh (cópialo en <terminal_data_folder>\MQL5\Include). El uso de estas clases se describe exhaustivamente en el artículo "Promediando Series de Precios para Cálculos Intermedios Sin Usar Buffers Adicionales".

Fig.1. Indicador Waddah_Attar_Trend_Alert en el gráfico

Fig.1. Indicador Waddah_Attar_Trend_Alert en el gráfico

Fig.2. Indicador Waddah_Attar_Trend_Alert. Generando alertas

Fig.2. Indicador Waddah_Attar_Trend_Alert. Generando alertas

Publicaciones relacionadas

Comentarios (0)