Está perdiendo oportunidades comerciales:
- Aplicaciones de trading gratuitas
- 8 000+ señales para copiar
- Noticias económicas para analizar los mercados financieros
Registro
Entrada
Usted acepta la política del sitio web y las condiciones de uso
Si no tiene cuenta de usuario, regístrese
#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::Periodo: el cambio de marco temporal está prohibido
2011.11.29 15:36:27 1234 (EURUSD,M1) CExpertBase::Símbolo: el cambio de símbolo está prohibido
¿Puedo utilizar los módulos de señales de trading por separado de los Wizard EAs? A modo de prueba, escribí
#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::Periodo: el cambio de marco temporal está prohibido
2011.11.29 15:36:27 1234 (EURUSD,M1) CExpertBase::Símbolo: el cambio de símbolo está prohibido
El siguiente código:
Llama al constructor de la etiqueta cada vez que se llama a la función.
Con el siguiente código: en el primer caso el indicador está activado, en el segundo no (cambiado con barras).
La segunda opción de esta biblioteca da como resultado 0. Todas las demás funciones parecen funcionar.
Para el siguiente código: en el primer caso el indicador está puesto, en el segundo no (se cambia con barras).
Según tengo entendido, por el momento los tres parámetros son obligatorios.
Por lo tanto, debe especificar el número de ventana (variantes: 0 - ventana principal,ChartIndicatorsTotal( ) - nueva ventana, 0 a ChartIndicatorsTotal()-1 - una ventana existente).
Eso es lo que no da errores no es bueno.
Para esta biblioteca, la segunda opción da como resultado 0. Todas las demás funciones parecen funcionar.
Probablemente antes de obtener el precio de refresco debe ser utilizado (al menos RefreshRates).
La variante correcta debería tener el siguiente aspecto
Gracias. Ha funcionado con Bid, después de especificar el refresco.
Pero la salida del indicador, usando la librería, requiere 2 parámetros, una subventana y un handle. De lo contrario, dice que el número de parámetros es incorrecto. No puedo entenderlo, porque la librería usa el mismo ChartIndicatorAdd, por lo que funciona directamente, pero llamando a través de la librería no.
Gracias, realmente funcionó con Bid, después de especificar refrescar.
Pero la salida del indicador, usando la librería, requiere 2 parámetros, una subventana y un handle. Si no es así, dice que el número de parámetros es incorrecto, no puedo averiguarlo, porque la librería usa el mismo ChartIndicatorAdd.
El uso de la biblioteca requiere 2 parámetros. Gráfico y subventana.
¿Sin asa? ¿Y cómo sabrá el sistema qué plataforma giratoria utilizar? ... Hasta ahora he confiado en lo que está escrito :) El sustrato y el mango.
¿Sin asa? ¿Cómo sabrá el sistema qué indicador utilizar? Hasta ahora he confiado en los textos :) Subventana y asa.
Sobre la biblioteca (de la ayuda de la clase)
IndicadorAdd
Añade un indicador con el asa especificada a la ventana del gráfico especificada.
En cuanto al trabajo directo de ChartIndicatorAdd.
ChartIndicatorAdd
Añade un indicador con el asa especificada a la ventana del gráfico especificada.
En cuanto a la clase CChart.
Para evitar preguntas innecesarias, intentamos seguir tres reglas básicas:
1. Miramos el código fuente, si algo no está claro nos remitimos a la documentación (el código fuente siempre dirá la "verdad", pero la documentación también puede mentir);
2. Si la implementación OOP es importante para nosotros, empezamos con una descripción de una clase particular y llegamos hasta los "implementadores directos". Si el "trabajo real" es importante, la POO debería estudiarse en último lugar (examen descendente/superior del código);
3. si después de leer la documentación y las fuentes algo no está claro, acude al foro.
Directamente en la implementación del método IndicatorAdd en una clase
Si miras el código fuente queda claro que el método obtiene la subventana y el handle (como se indica en la ayuda), y el tercer parámetro se toma de los datos almacenados en la propia clase (me refiero al ID del gráfico).