Página 2 de 353 PrimerPrimer 123 ÚltimoÚltimo
Resultados 11 al 20 de 23

Tema: MQL4 Script - abrir en la nueva pregunta de la barra

  1. #11
    Inserted Code #property strict #property show_inputs input int ExtraTrades = 10; tiempo de tiempo estático T0;/ ----------------------------------------------- ------------------- void OnStart () {int contador = 0; T0 = ​​0; while (! IsStopped () counterlt; ExtraTrades) {if (T0! = Time # 91; 0 # 93 {T0 = Time # 91; 0 # 93 ;; RefreshRates (); Abrelo(); contador ; Sueño (1000); }}}/ -------------------------------------------- ----------------------

  2.                         
    Publicidad
  3. #12

    Cita Iniciado por ;
    Lo hice usando la función Bars, no estoy seguro de que sea a prueba de balas, pero creo que también funciona,
    Tenga en cuenta que este método no es confiable, ya que MT deja de actualizar el conteo de barras una vez que se alcanza la configuración de barras máximas. Entonces, ¡el único! método confiable es verificar el tiempo.

  4. #13

    Cita Iniciado por ;
    {quote} Tenga en cuenta que este método no es confiable, ya que MT deja de actualizar el conteo de barras una vez que se alcanza la configuración de barras máximas. Entonces, ¡el único! método confiable es verificar el tiempo.
    Sí, estoy de acuerdo, definitivamente no uses el método Bars. La forma más confiable de utilizar SeriesInfoInteger y llamarlo para LASBAR_DATE, verifique si hay errores y si hay errores en el bucle y vuelva a preguntar hasta que se agote el tiempo de espera de su función o obtenga un resultado limpio. Aquí hay un ejemplo de una función MTF isNewBar ... Inserted Code #include lt; Arrays \ ArrayObj.mqhgt; clase NewBars: public CObject {ENUM_TIMEFRAMES m_timeframe; datetime m_last_bar_time; public: NewBars (ENUM_TIMEFRAMES tf): m_timeframe (tf), m_last_bar_time (0) {} bool isNewBar () {uint ms = GetTickCount (); datetime curr; do {ResetLastError (); curr = (datetime) SeriesInfoInteger (_Symbol, m_timeframe, SERIES_LASTBAR_DATE); } while (_LastError! = ERR_NO_ERROR GetTickCount () - ms lt; 500); if (curr gt; 0 _LastError == ERR_NO_ERROR curr! = m_last_bar_time) {bool res = true; if (m_last_bar_time == 0) res = falso; m_last_bar_time = curr; devolver res; } falso retorno; } bool isMatching (ENUM_TIMEFRAMES tf) {return m_timeframe == tf? verdadero Falso;} }; bool isNewBar (const ENUM_TIMEFRAMES timeframe) {static CArrayObj tfs; for (int i = tfs.Total () - 1; igt; = 0; i--) {NewBars * tf = dynamic_castlt; NewBars * gt; (tfs.At (i)); if (tf.isMatching (timeframe)) devuelve tf.isNewBar (); } tfs.Add (new NewBars (timeframe)); falso retorno; }

  5. #14
    1 Adjunto (s)
    Cita Iniciado por ;
    {quote} Tenga en cuenta que este método no es confiable, ya que MT deja de actualizar el conteo de barras una vez que se alcanza la configuración de barras máximas. Entonces, ¡el único! método confiable es verificar el tiempo.
    No (detiene la actualización) Bars () excede el número máximo de barras en los casos en que se alcanza (y se excede) la configuración de barras máximas

  6. #15

    Cita Iniciado por ;
    {quote} Sí, acordó, definitivamente no use el método Bars. La forma más confiable de utilizar SeriesInfoInteger y llamarlo para LASBAR_DATE, verifique si hay errores y si hay errores en el bucle y vuelva a preguntar hasta que se agote el tiempo de espera de su función o obtenga un resultado limpio. Aquí hay un ejemplo de una función MTF isNewBar ... #include lt; Arrays \ ArrayObj.mqhgt; clase NewBars: public CObject {ENUM_TIMEFRAMES m_timeframe; datetime m_last_bar_time; public: NewBars (ENUM_TIMEFRAMES tf): m_timeframe (tf), m_last_bar_time (0) {} bool isNewBar () {uint ms = GetTickCount (); fecha y hora...
    Gracias, son muy amables al proporcionar estos ejemplos, aquí y en mis otros hilos. Entiendo lo que has hecho aquí, pero la lingüística me escapa aún, ya que aún tengo que aprender el lado OO del MQL4. Tampoco estoy completamente seguro de que tu código funcione dentro del contexto de un script, pero no estoy tan bien informado.

  7. #16
    Cita Iniciado por ;
    {quote} No (deja de actualizar) Bars () excede el número máximo de barras en los casos cuando se alcanza la configuración de barras máximas {image}
    Gracias por responder, ¿estoy en lo correcto al utilizar este método de barras o no? Se siente como que es más simple que el método Time y me gusta mantener las cosas simples

  8. #17
    Cita Iniciado por ;
    {quote} Gracias por responder, ¿estoy en lo cierto al usar este método de Bars o no? Se siente como que es más simple que el método Time y me gusta mantener las cosas simples
    Ninguno de los métodos es complicado: Código insertado static datetime _prevTime = 0; datetime _currTime = iTime (NULL, marco de tiempo deseado, 0); bool _isNewBar = (_prevTime! = _currTime); if (_isNewBar) _prevTime = _currTime;

  9. #18

    Cita Iniciado por ;
    {quote} Ninguno de los métodos es complicado: static datetime _prevTime = 0; datetime _currTime = iTime (NULL, marco de tiempo deseado, 0); bool _isNewBar = (_prevTime! = _currTime); if (_isNewBar) _prevTime = _currTime;
    Gracias, tenía algo similar en mi script pero no funcionó (publicado antes en la primera publicación) incluso cuando agregué RefreshRates (). Intentaré de nuevo con tu código, con ResreshRates () dentro y fuera del ciclo, para que la secuencia de comandos obtenga nueva información.

  10. #19
    Código insertado/--- Variable global ----------------------------------------- ------------------------- datetime ArrayTime # 91; # 93 ;, LastTime; void OnTick () {if (NewBar (PERIOD_CURRENT)) {//su código}} bool NewBar (int period) {bool firstRun = false, newBar = false; ArraySetAsSeries (ArrayTime, true); CopyTime (Símbolo (), punto, 0,2, ArrayTime); if (LastTime == 0) firstRun = true; if (ArrayTime # 91; 0 # 93; gt; LastTime) {if (firstRun == false) newBar = true; LastTime = ArrayTime # 91; 0 # 93 ;; } return newBar; }

  11. #20
    Además, verifique este código que es adecuado para marcos de tiempo arbitrarios (detectados con la primera cotización): Inserted Code #property strict void OnStart () {datetime seconds = _Period * 60;/declara cualquier cantidad en segundos datetime t_last_recorded = 0;/para demostración: D while (! IsStopped ()) {RefreshRates (); datetime t = TimeCurrent ();/hora de la última cita conocida datetime t_normalized = tseconds * seconds; if (t_normalized gt; t_last_recorded) {//nueva barra printf (¡nueva barra!); t_last_recorded = t_normalized; } Dormir (1); }}

Permisos de publicación

  • No puedes crear nuevos temas
  • No puedes responder temas
  • No puedes subir archivos adjuntos
  • No puedes editar tus mensajes
  •  
Uso de cookies
Utilizamos cookies propias y de terceros para elaborar información estadística y mostrarle publicidad personalizada a través del análisis de su navegación. Si continúa navegando acepta su uso. Más información y política de cookies.
     

Aviso legal: Ni forosforex.com ni ninguna persona involucrada en forosforex.com aceptarán ninguna responsabilidad por cualquier pérdida o daño en el trading como resultado de la confianza en la información contenida en este sitio web, incluidos datos, cotizaciones, gráficos y señales de compra/venta. Por favor, infórmese plenamente de los riesgos y costes asociados a las operaciones en los mercados financieros, una de las formas de inversión que más riesgos entrañan.
forosforex.com le quiere recordar que los datos contenidos en este sitio web no son necesariamente en tiempo real ni exactos. forosforex.com no asume responsabilidad alguna por las pérdidas en que usted podría incurrir como resultado de la utilización de estos datos. Este acuerdo se rige por su versión en inglés, que prevalecerá siempre que haya alguna discrepancia entre la versión en inglés y la versión en español. Los CFD son un producto difícil de entender, varios organismos reguladores consideran que no es adecuado para inversores minoristas debido a su complejidad y riesgo.
Advertencia de riesgo: Los CFDs son un producto difícil de entender, y puede no ser adecuado para inversores minoristas debido a su complejidad y riesgo. Existe la posibilidad de sufrir una pérdida igual o superior a la inversión. Por lo tanto, no debe invertir o arriesgar dinero que no pueda permitirse perder. Debe asegurarse de que comprende todos los riesgos. Antes de abrir una cuenta en un broker por favor sea consciente e infórmese de los riesgos asociados con el trading. El contenido de este sitio web no debe interpretarse como asesoramiento personal. ForosForex recomienda que busque el consejo de un asesor financiero independiente.