任何菜鸟问题,为了不给论坛添乱。专业人士,不要路过。没有你就无处可去 - 6. - 页 167

 
如何获得当前图表的Open[],但不是当前时间框架的 Open[]?
 

大家好!

感谢每一个帮助新人的人,尽管现在利他主义已经失去了价值,但他们不吝惜自己的时间。

我请求论坛用户的帮助,我已经阅读了Igor的所有主题,但没有找到我需要的东西,所以我决定在这里写。

而功能我怀疑并不复杂,某处已经是这样了,但是......。

如何计算当前(以前,...)每日(每周,...)蜡烛的最大值/最小值的MINUTE(5,15,30,60,...)备份

我将非常感谢利他主义的专业人士。

 
KAVrus:

大家好!

感谢每一个帮助新人的人,尽管现在利他主义已经失去了价值,但他们不吝惜自己的时间。

我请求论坛用户的帮助,我已经读了整个Igor主题,但我没有找到我需要的东西,所以我决定在这里写。

我怀疑这个功能并不复杂,而且已经存在于某个地方,但是......。

如何计算当前(以前,......)每日(每周,......)蜡烛的最大值/最小值的MINUTE(5,15,30,60,......)BACK

我将非常感谢利他主义的专业人士。


:))--这很有趣。

继续阅读--你会发现许多有趣的事情。:)))

 
boing9267:
如何获得当前图表的Open[],但不是当前时间框架的 Open[]?
iOpen()。
 
TarasBY:

:))-))-让我笑了。

继续阅读--你会发现很多有趣的事情。:)))


嘲笑是一种罪过,.....)))


我读了..."其他时间段的量没有被模拟"

那么我一定是错误地阐述了问题的重点......我试着把它简化一下。

你如何计算当前蜡烛的最大/最小值,一分钟

 
TarasBY:
iOpen()。


谢谢你
 
KAVrus:

嘲笑是一种罪过,.....)))


阅读..."其他时间段的量没有模拟"

那么我一定是错误地阐述了问题的重点......我试着把它简化一下。

你如何计算当前日线蜡烛的最大/最小值,一分钟

笑比读更容易(更不用说 "钻研")......:)))

让我们试着用代码来解决这个问题。

    //---- Находим последний расчётный бар на нужном нам тамфрейме
    int li_Shift = iBarShift (Symbol(), PERIOD_M1, iTime (Sumbol(), PERIOD_D1, 0)),
        //---- Ищем на нужном промежутке номер бара с High
        li_Bar = iHighest (Symbol(), PERIOD_M1, MODE_HIGH, li_Shift, 1);
    //---- Получаем значение High
    double ld_HIGH = iHigh (Symbol(), PERIOD_M1, li_Bar);

在图像和相似度最低的情况下,你能处理吗?;)

P.S. 因为在价格历史中,我们有一个最小尺寸为1分钟的离散性,所以说不是 "一分钟前",而是 "不计入最后一分钟 "是正确的。

 
TarasBY:

笑比读更容易(更不用说 "进入")......:)))

试图用代码解决这个问题。

在你的形象中,你能处理好最低限度的问题吗!?;)

P.S. 因为在价格历史中我们有一个离散性,最小的离散性是1分钟,所以说不是 "一分钟前",而是 "不算最后一分钟 "是正确的。


谢谢你!!!。
 
大家好,请帮助解决指标sAccelerator.mq4 的问题。 我想在0线被越过时发出警报,并把着色警报去掉,它不起作用,在mql中坦白说我不明白。
//+------------------------------------------------------------------+
//|                                                 sAccelerator.mq4 |
//|                      Copyright © 2005, MetaQuotes Software Corp. |
//|                                       http://www.metaquotes.net/ |
//+------------------------------------------------------------------+
#property  copyright "Copyright © 2005, MetaQuotes Software Corp."
#property  link      "http://www.metaquotes.net/"
//---- indicator settings
#property  indicator_separate_window
#property  indicator_buffers 3
#property  indicator_color1  Black
#property  indicator_color2  Lime
#property  indicator_color3  Red
//---- indicator buffers
double ExtBuffer0[];
double ExtBuffer1[];
double ExtBuffer2[];
double ExtBuffer3[];
double ExtBuffer4[];
// Номер бара, по которому будет искаться сигнал
#define SIGNAL_BAR 1
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int init()
  {
//---- 2 additional buffers are used for counting.
   IndicatorBuffers(5);
//---- drawing settings
   SetIndexStyle(0, DRAW_NONE);
   SetIndexStyle(1, DRAW_HISTOGRAM);
   SetIndexStyle(2, DRAW_HISTOGRAM);
   IndicatorDigits(Digits + 2);
   SetIndexDrawBegin(0, 38);
   SetIndexDrawBegin(1, 38);
   SetIndexDrawBegin(2, 38);
//---- 4 indicator buffers mapping
   SetIndexBuffer(0, ExtBuffer0);
   SetIndexBuffer(1, ExtBuffer1);
   SetIndexBuffer(2, ExtBuffer2);
   SetIndexBuffer(3, ExtBuffer3);
   SetIndexBuffer(4, ExtBuffer4);
//---- name for DataWindow and indicator subwindow label
   IndicatorShortName("sAC");
   SetIndexLabel(1, NULL);
   SetIndexLabel(2, NULL);
//---- initialization done
   return(0);
  }
//+------------------------------------------------------------------+
//| Accelerator/Decelerator Oscillator                               |
//+------------------------------------------------------------------+
int start()
  {
   int    limit;
   int    counted_bars = IndicatorCounted();
   double prev, current;
//---- last counted bar will be recounted
   if(counted_bars > 0) 
       counted_bars--;
   limit = Bars - counted_bars;
//---- macd counted in the 1-st additional buffer
   for(int i = 0; i < limit; i++)
       ExtBuffer3[i] = iMA(NULL, 0, 5, 0, MODE_SMA, PRICE_MEDIAN, i) - 
                       iMA(NULL, 0, 34, 0, MODE_SMA, PRICE_MEDIAN, i);
//---- signal line counted in the 2-nd additional buffer
   for(i = 0; i < limit; i++)
       ExtBuffer4[i] = iMAOnArray(ExtBuffer3, Bars, 5, 0, MODE_SMA, i);
//---- dispatch values between 2 buffers
   bool up = true;
   for(i = limit - 1; i >= 0; i--)
     {
       current = ExtBuffer3[i] - ExtBuffer4[i];
       prev = ExtBuffer3[i+1] - ExtBuffer4[i+1];
       if(current > prev) 
           up = true;
       if(current < prev) 
           up = false;
       if(!up)
         {
           ExtBuffer2[i] = current;
           ExtBuffer1[i] = 0.0;
         }
       else
         {
           ExtBuffer1[i] = current;
           ExtBuffer2[i] = 0.0;
         }
       ExtBuffer0[i] = current;
     }
//---- done
    //---- Статические переменные, в которых хранятся
    //---- время последнего бара и направление последнего сигнала
    static int PrevSignal = 0, PrevTime = 0;
 
    //---- Если баром для анализа выбран не 0-й, нам нет смысла проверять сигнал
    //---- несколько раз. Если не начался новый бар, выходим.
    if(SIGNAL_BAR > 0 && Time[0] <= PrevTime ) 
        return(0);
    //---- Отмечаем, что этот бар проверен
    PrevTime = Time[0];
          if(PrevSignal <= 0)
      {
        if(MainBuffer[SIGNAL_BAR] - 0.0 > 0 && 
           0.0 - MainBuffer[SIGNAL_BAR+1] >= 0)
          {
            PrevSignal = 1;
            Alert("sAC (", Symbol(), ", ", Period(), ")  -  BUY!!!");
          }
      }
    if(PrevSignal >= 0)
      {
        if(0.0 - MainBuffer[SIGNAL_BAR] > 0 && 
           MainBuffer[SIGNAL_BAR+1] - 0.0 >= 0)
          {
            PrevSignal = -1;
            Alert("sAC (", Symbol(), ", ", Period(), ")  -  SELL!!!");
          }
      } 
   return(0);
  }
//+------------------------------------------------------------------+

 

先生们,请告知如何在一个条形图中找到平均刻度线。我假设如下。

Average[i] = (bar[i]的ticks总量)/Volume[i]; 如何找到所需的bar的ticks总量?

原因: