错误、漏洞、问题 - 页 1580

 

网站的主页在文本中显示HTML字符。Chrome 64 Win 10 64。

 

编译错误

template<typename T>
class A {
public:
        A( T t1 ) : t( t1 ) {}
        T operator[]( int ) { return t; }
        T t;
};
typedef void (*fn)();
void OnStart()
{
        A<fn> a( OnStart );
        a.operator[]( 0 )(); //нормально
        a[            0 ](); // error: ')' - expression expected
}
 

ArrayIsSeries() 在这个脚本中总是产生错误。

//+------------------------------------------------------------------+
//|                                                     TestCopy.mq4 |
//|              Copyright 2016, Artem A. Trishkin, Skype artmedia70 |
//|                       https://login.mql5.com/ru/users/artmedia70 |
//+------------------------------------------------------------------+
#property copyright "Copyright 2016, Artem A. Trishkin, Skype artmedia70"
#property link      "https://login.mql5.com/ru/users/artmedia70"
#property version   "1.00"
#property strict
#property script_show_inputs

enum enumYN
  {
   enYes=1, // Да
   enNo=0,  // Нет
  };

//--- input parameters
input int Search_Period=10;   // Количество копируемых свечей
int searchPeriod=(Search_Period<1)?1:Search_Period;
input int Delta=2;            // Количество пунктов допуска
int delta=(Delta<0)?0:Delta;
input enumYN AsSeries=enYes;  // Массив array как таймсерия
MqlRates array[];             // Массив структур для копирования Open, High, Low, Close, Time
  
struct DataCandle             // Структура для хранения всех совпадений
  {
   int number_matched;           // Количество совпадений
   MqlRates reference_candle;    // Данные эталонной свечи
   MqlRates matched_candles[];   // Массив свечей, совпадающих с эталонной по нужному критерию 
  };
  DataCandle dataCandle[];    // Массив структур данных свечей и их совпадений
//+------------------------------------------------------------------+
//| Script program start function                                    |
//+------------------------------------------------------------------+
void OnStart()
  {
//---
   int copy_bars=(int)fmin(Search_Period,Bars(Symbol(),Period()));   // количество копируемых свечей
   int copied=CopyRates(Symbol(),PERIOD_CURRENT,1,copy_bars,array);  // копируем данные
   if(copied>0) {                                                    // если скопировали
      ArraySetAsSeries(array,AsSeries);                              // задаём массив как таймсерию или нет
      ArrayResize(dataCandle,copied);                                // задаём размер структуры равным числу скопированных данных
      ZeroMemory(dataCandle);                                        // Обнуляем данные в структуре
      //--- основной цикл по "эталонным" свечам в массиве array. Их параметры будем искать в доп. цикле
      for(int i=0; i<copy_bars-1; i++) {                             // цикл по скопированным данным от начала до "на один меньше размера массива"
         dataCandle[i].reference_candle.high=array[i].high;          // ищем этот high
         dataCandle[i].reference_candle.low=array[i].low;            // запомнили low для сравнения
         dataCandle[i].reference_candle.time=array[i].time;          // запомнили time для вывода в журнал
         //--- поиск совпадений с эталонной свечой, индексируемой индексом основного цикла i
         int size=0;                                                 // размер массива совпадающих свечей
         ArrayResize(dataCandle[i].matched_candles,size);            // Размер массива совпадений в ноль
         dataCandle[i].number_matched=size;                          // Инициализируем количество совпадений нулём
         //--- теперь ищем совпадения по high свечей в цикле j с high эталонной свечи с индексом i
         for(int j=0; j<copy_bars; j++) {                            // в цикле от i+1 до copy_bars
            if(j==i) continue;                                       // пропустим свечу "саму себя"
            //--- если совпадают high эталонной свечи (i) и свечи с индексом j (с допуском на величину Point)
            if(NormalizeDouble(delta*Point()-fabs(array[i].high-array[j].high),Digits())>=0) {
               size++;                                               
               ArrayResize(dataCandle[i].matched_candles,size);            // увеличим размер массива совпадающих свечей
               dataCandle[i].number_matched=size;                          // запишем количество совпадений
               dataCandle[i].matched_candles[size-1].high=array[j].high;   // запишем в массив high совпадающей свечи
               dataCandle[i].matched_candles[size-1].low=array[j].low;     // запишем в массив low совпадающей свечи
               dataCandle[i].matched_candles[size-1].time=array[j].time;   // запишем в массив время совпадающей свечи
               //Print("Время свечи ",i," :",TimeToString(dataCandle[i].reference_candle.time=array[i].time),", high=",DoubleToString(dataCandle[i].reference_candle.high=array[i].high,Digits()),". Совпадение со свечой ",TimeToString(dataCandle[i].matched_candles[size-1].time=array[j].time),", её high ",DoubleToString(dataCandle[i].matched_candles[size-1].high=array[j].high,Digits()),". Совпадений: ",(string)dataCandle[i].number_matched);
               }
            }
         }
      }

   //--- Посмотрим чего понаписали в массивы
   Alert("Array is series: ",ArrayIsSeries(array),
         "\ntime array[0]: ",TimeToString(array[0].time,TIME_DATE|TIME_MINUTES),
         "\ntime array[",string(searchPeriod-1),"]: ",TimeToString(array[ArraySize(array)-1].time,TIME_DATE|TIME_MINUTES));
   for(int i=0; i<ArraySize(dataCandle)-1; i++) {
      string refs_txt="";
      string matched_txt="";
      refs_txt="Свеча "+IntegerToString(i,2,'0')+": время "+TimeToString(dataCandle[i].reference_candle.time)+", high: "+DoubleToString(dataCandle[i].reference_candle.high,Digits())+" имеет совпадений: "+(string)dataCandle[i].number_matched+" шт. ";
      if(dataCandle[i].number_matched>0) {
         for(int j=0; j<ArraySize(dataCandle[i].matched_candles); j++) {
            matched_txt="Совпадение "+IntegerToString(j+1)+": "+TimeToString(dataCandle[i].matched_candles[j].time)+", high: "+DoubleToString(dataCandle[i].matched_candles[j].high,Digits());
            }
         }
      Print(refs_txt,matched_txt);
      }
  }
//+------------------------------------------------------------------+
 
是否可以在图表参数中找出PPI(每英寸像素)?我的小组真的需要它。WinAPI不是一个选项。
 
Andrey Voytenko:
是否可以通过图形参数知道PPI(每英寸像素)值?我的小组真的需要它。WinAPI不是一个选项。

在公告中发现。

MQL5:在ENUM_TERMINAL_INFO_INTEGER客户端终端属性列表中添加了TERMINAL_SCREEN_DPI值--屏幕输出的 分辨率以每线性英寸的点数(DPI)来衡量。知道了这个参数,你就可以确定图形对象的大小,使它们在不同分辨率的显示器上看起来一样。

会有帮助吗?
 
在写文章时,当试图插入图片 时,没有 "仅有图片 "的过滤器--选定的文件夹绝对显示所有的文件,甚至那些与图片完全无关的文件。
 
Karputov Vladimir:

在公告中找到了它: TERMINAL_SCREEN_DPI

这是否有帮助?

是的,这就是我需要的。谢谢你。
 
CHARTEVENT_MOUSE_MOVE在指标OnChartEvent中不起作用,直到你在图表上加载专家顾问。

请帮助解决这个错误。

关于交易、自动交易系统和测试交易策略的论坛

错误!!!。指标中的OnChartEvent在加载到EA图表之前,CHARTEVENT_MOUSE_MOVE不起作用。

Vladislav Andruschenko, 2016.05.13 12:29

OnChartEvent在指标CHARTEVENT_MOUSE_MOVE中不起作用,直到你把它加载到Expert Advisor的图表上。

实际的破坏行为。

2016.05.13:23:49.434 Windows 7 Ultimate (x64 based PC), IE 11.00, 8 x Intel Core i7-6700 @ 3.40GHz, RAM: 22784 / 32684 Mb, HDD: 16315 / 1498122 Mb, GMT+02:00

所以。

有一个检查指标

代码是最小的。

void OnChartEvent(const int id,

                  const long &lparam,

                  const double &dparam,

                  const string &sparam)

  {

   Comment(" MOVE \n id="+id+" \n lparam="+lparam+" \n dparam="+dparam+" \n sparam="+sparam
           );


  }

因此,当指标被附加 到图表上时--注释不显示鼠标指针的当前位置。

如果你点击图表--它显示最后的坐标,并且在移动时不会进一步改变它们,即CHARTEVENT_MOUSE_MOVE参数在这种情况下不起作用。

这个问题只能通过以下方式解决

当任何专家顾问被连接到一个图表上时--进一步说,该指标正常更新评论,即它跟随光标并显示其坐标。

即使你随后将专家顾问从图表中移除--指标通常显示光标坐标。

行动的顺序。

1. 打开一个新的图表

2.抛出测试指标

3.评论不显示CHARTEVENT_MOUSE_MOVE 标志(id=0

4.我把任何专家顾问放在图表上

5.指标开始正常显示CHARTEVENT_MOUSE_MOVE(id=10 动作。


 
Vladislav Andruschenko:
指标中的OnChartEvent,CHARTEVENT_MOUSE_MOVE不工作,直到你在图表上下载专家顾问。

请帮助解决这个错误。

开发人员会问你的第一个问题是,CHART_EVENT_MOUSE_MOVE是否启用?
 
Alexander Puzanov:
开发人员会问你的第一个问题是,CHART_EVENT_MOUSE_MOVE是否开启?

谢谢你。我不知道的事 ..... .......