Découvrez le PPO_SignAlert, un indicateur de signaux basé sur le taux de variation relative lissée des prix. Cet outil pratique inclut des alertes, envoi d'e-mails et notifications push directement sur vos appareils mobiles.
Pour mettre en place ces alertes, des modifications ont été apportées au code de l'indicateur. Voici les principaux changements :
- Ajout de nouveaux paramètres d'entrée :
input uint NumberofBar=1;// Nombre de barres pour le signal input bool SoundON=true; // Activer les alertes input uint NumberofAlerts=2;// Nombre d'alertes input bool EMailON=false; // Activer l'envoi d'e-mails input bool PushON=false; // Activer l'envoi de notifications push
- Ajout de trois nouvelles fonctions à la fin du code de l'indicateur : BuySignal(), SellSignal() et GetStringTimeframe()
//+------------------------------------------------------------------+ //| Fonction de signal d'achat | //+------------------------------------------------------------------+ void BuySignal(string SignalSirname, // Nom de l'indicateur pour les messages e-mails et push double &BuyArrow[], // Tampon de l'indicateur avec les signaux d'achat const int Rates_total, // Nombre actuel de barres const int Prev_calculated, // Nombre de barres sur le tick précédent const double &Close[], // Prix de clôture 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("Signal d'ACHAT Ask=",Ask," Bid=",Bid," Temps actuel=",text," Symbole=",Symbol()," Période=",sPeriod); if(EMailON) SendMail(SignalSirname+": Alerte signal d'ACHAT","Signal d'ACHAT à Ask="+sAsk+", Bid="+sBid+", Date="+text+" Symbole="+Symbol()+" Période="+sPeriod); if(PushON) SendNotification(SignalSirname+": Signal d'ACHAT à Ask="+sAsk+", Bid="+sBid+", Date="+text+" Symbole="+Symbol()+" Période="+sPeriod); } u//--- } //+------------------------------------------------------------------+ //| Fonction de signal de vente | //+------------------------------------------------------------------+ void SellSignal(string SignalSirname, // Nom de l'indicateur pour les messages e-mails et push double &SellArrow[], // Tampon de l'indicateur avec les signaux de vente const int Rates_total, // Nombre actuel de barres const int Prev_calculated, // Nombre de barres sur le tick précédent const double &Close[], // Prix de clôture 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("Signal de VENTE Ask=",Ask," Bid=",Bid," Temps actuel=",text," Symbole=",Symbol()," Période=",sPeriod); if(EMailON) SendMail(SignalSirname+": Alerte signal de VENTE","Signal de VENTE à Ask="+sAsk+", Bid="+sBid+", Date="+text+" Symbole="+Symbol()+" Période="+sPeriod); if(PushON) SendNotification(SignalSirname+": Signal de VENTE à Ask="+sAsk+", Bid="+sBid+", Date="+text+" Symbole="+Symbol()+" Période="+sPeriod); } u//--- } //+------------------------------------------------------------------+ //| Obtenir la période sous forme de chaîne | //+------------------------------------------------------------------+ string GetStringTimeframe(ENUM_TIMEFRAMES timeframe) { //---- return(StringSubstr(EnumToString(timeframe),7,-1)); //---- }
- Ajout d'appels aux fonctions BuySignal() et SellSignal() après les cycles de calcul de l'indicateur dans le bloc OnCalculate()
u//--- BuySignal("PPO_Sign",BuyBuffer,rates_total,prev_calculated,close,spread); SellSignal("PPO_Sign",SellBuffer,rates_total,prev_calculated,close,spread); u//---
Les tableaux BuyBuffer et SellBuffer sont utilisés pour stocker les signaux d'achat et de vente. Les valeurs vides dans les tampons de l'indicateur doivent être définies soit à zéro, soit à EMPTY_VALUE.
Il est prévu d'utiliser un seul appel aux fonctions BuySignal() et SellSignal() dans le bloc OnCalculate() du code de l'indicateur.
L'indicateur utilise les classes de la bibliothèque SmoothAlgorithms.mqh (copiez-la dans <terminal_data_folder>\MQL5\Include). L'utilisation de ces classes a été décrite en détail dans l'article "Averaging Price Series for Intermediate Calculations Without Using Additional Buffers".
À l'origine, cet indicateur a été écrit en MQL4 et a été publié pour la première fois dans la Base de Code le 08.03.2008.

Fig.1. L'indicateur PPO_SignAlert sur le graphique
Fig.2. L'indicateur PPO_SignAlert. Génération d'alertes.
Articles connexes
- iMAX3 : Détecteur de Tendances Rapides pour Traders
- Découvrez l'indicateur Tymen STARC Bands MTF pour MetaTrader 5
- Améliorez vos graphiques avec ClearView : Indicateurs et modèles pour MetaTrader 5
- Affichez la tendance actuelle sur tous les délais avec un indicateur pour MetaTrader 4
- Découvrez l'indicateur 3 en 1 Stochastic pour MetaTrader 5
