Vous manquez des opportunités de trading :
- Applications de trading gratuites
- Plus de 8 000 signaux à copier
- Actualités économiques pour explorer les marchés financiers
Inscription
Se connecter
Vous acceptez la politique du site Web et les conditions d'utilisation
Si vous n'avez pas de compte, veuillez vous inscrire
#include <Expert\Signal\SignalMA.mqh>
CSignalMA SignalMA;
int TickCount;
string Str;
//+------------------------------------------------------------------+
//| Expert initialization function |
//+------------------------------------------------------------------+
int OnInit()
{
TickCount=0;
SignalMA.Symbol(Symbol());
SignalMA.Period(PERIOD_H1);
SignalMA.Weight(0.5);
SignalMA.PeriodMA(20);
SignalMA.Shift(0);
SignalMA.Method(MODE_SMA);
SignalMA.Applied(PRICE_CLOSE);
return(0);
}
//+------------------------------------------------------------------+
//| Expert deinitialization function |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
{
//---
}
//+------------------------------------------------------------------+
//| Expert tick function |
//+------------------------------------------------------------------+
void OnTick()
{
TickCount++;
Str = "LongCondition = " + IntegerToString(SignalMA.LongCondition())+"; "+IntegerToString(TickCount)+ "\n";
Str = Str + "ShortCondition = " + IntegerToString(SignalMA.ShortCondition())+"; "+IntegerToString(TickCount);
Comment(Str);
}
//+------------------------------------------------------------------+
2011.11.29 15:36:27 1234 (EURUSD,M1) CExpertBase::Period : le changement d'horizon temporel est interdit
2011.11.29 15:36:27 1234 (EURUSD,M1) CExpertBase::Symbol : le changement de symbole est interdit
Puis-je utiliser les modules de signaux de trading séparément des EAs Wizard ? À des fins de test, j'ai écrit
#include <Expert\Signal\SignalMA.mqh>
CSignalMA SignalMA;
int TickCount;
string Str;
//+------------------------------------------------------------------+
//| Expert initialization function |
//+------------------------------------------------------------------+
int OnInit()
{
TickCount=0;
SignalMA.Symbol(Symbol());
SignalMA.Period(PERIOD_H1);
SignalMA.Weight(0.5);
SignalMA.PeriodMA(20);
SignalMA.Shift(0);
SignalMA.Method(MODE_SMA);
SignalMA.Applied(PRICE_CLOSE);
return(0);
}
//+------------------------------------------------------------------+
//| Expert deinitialization function |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
{
//---
}
//+------------------------------------------------------------------+
//| Expert tick function |
//+------------------------------------------------------------------+
void OnTick()
{
TickCount++;
Str = "LongCondition = " + IntegerToString(SignalMA.LongCondition())+"; "+IntegerToString(TickCount)+ "\n";
Str = Str + "ShortCondition = " + IntegerToString(SignalMA.ShortCondition())+"; "+IntegerToString(TickCount);
Comment(Str);
}
//+------------------------------------------------------------------+
2011.11.29 15:36:27 1234 (EURUSD,M1) CExpertBase::Period : le changement d'horizon temporel est interdit
2011.11.29 15:36:27 1234 (EURUSD,M1) CExpertBase::Symbol : le changement de symbole est interdit
Le code suivant :
Appelle le constructeur de l'étiquette à chaque fois que la fonction est appelée.
Avec le code suivant : dans le premier cas, l'indicateur est activé, dans le second cas, il ne l'est pas (commutation avec des barres obliques).
La deuxième option de cette bibliothèque produit 0. Toutes les autres fonctions semblent fonctionner.
Pour le code suivant : dans le premier cas, l'indicateur est activé, dans le deuxième cas, il ne l'est pas (commutation avec des barres obliques).
D'après ce que j'ai compris, pour l'instant, les trois paramètres sont obligatoires.
Par conséquent, vous devez spécifier le numéro de la fenêtre (variantes : 0 - fenêtre principale, ChartIndicatorsTotal() - nouvelle fenêtre, 0 àChartIndicatorsTotal()-1 - une fenêtre existante).
Ce qui ne donne pas d'erreurs n'est pas bon.
Pour cette bibliothèque, la deuxième option imprime 0. Toutes les autres fonctions semblent fonctionner.
Avant d'obtenir le prix, vous devriez probablement utiliser les rafraîchissements (au moins les RefreshRates).
La bonne variante devrait ressembler à ceci
Merci. Cela a vraiment fonctionné avec Bid, après avoir spécifié le rafraîchissement.
Mais la sortie de l'indicateur, en utilisant la bibliothèque, nécessite 2 paramètres, une sous-fenêtre et un handle. Sinon, il est dit que le nombre de paramètres est incorrect, je n'arrive pas à comprendre, car la bibliothèque utilise le même ChartIndicatorAdd.
Merci. Cela a vraiment fonctionné avec Bid, après avoir spécifié le rafraîchissement.
Mais la sortie de l'indicateur, en utilisant la bibliothèque, nécessite 2 paramètres, une sous-fenêtre et un handle. Sinon, il est dit que le nombre de paramètres est incorrect, je n'arrive pas à comprendre, car la bibliothèque utilise le même ChartIndicatorAdd.
L'utilisation de la bibliothèque nécessite 2 paramètres. Graphique et sous-fenêtre.
Sans poignée ? Et comment le système saura-t-il quelle platine utiliser ? ... Jusqu'à présent, j'ai fait confiance à ce qui est écrit :) Le substrat et la poignée.
Sans poignée ? Comment le système saura-t-il quel indicateur utiliser ? J'ai fait confiance aux textes jusqu'à présent :) Sous-fenêtre et poignée.
À propos de la bibliothèque (extrait de l'aide de la classe)
IndicateurAjouter
Ajoute un indicateur avec la poignée spécifiée à la fenêtre graphique spécifiée.
En ce qui concerne le travail direct de ChartIndicatorAdd.
ChartIndicatorAdd
Ajoute un indicateur avec la poignée spécifiée à la fenêtre graphique spécifiée.
Quant à la classe CChart.
Afin d'éviter les questions inutiles, nous essayons de suivre trois règles de base :
1. Nous regardons le code source, si quelque chose n'est pas clair, nous nous référons à la documentation (le code source dira toujours la "vérité", mais la documentation peut aussi mentir) ;
2. Si l'implémentation de la POO est importante pour nous, nous partons de la description d'une classe particulière et allons jusqu'aux "implémenteurs directs". Si le "vrai travail" est important, la POO devrait être étudiée en dernier (examen du code de bas en haut) ;
3. si après avoir lu la documentation et les sources, quelque chose n'est pas clair, allez sur le forum.
Directement sur l'implémentation de la méthode IndicatorAdd dans une classe
Si vous regardez le code source, il est clair que la méthode obtient la sous-fenêtre et le handle (comme indiqué dans l'aide), et le troisième paramètre est pris dans les données stockées dans la classe elle-même (je veux dire l'identifiant du graphique).