MetaTrader 5新功能

桌面版,移动版和网页平台的更新历史

5 十月 2019
新版MetaTrader 5平台build 2170:MQL5作用域,全局策略测试和内置虚拟主机更新

程序端

  1. 重新设计了内置虚拟主机管理选项。关于租用程序端以及环境迁移、停止和启动功能的所有信息,现在都可以在“工具箱”窗口的单独选项卡中获得。

    在早期版本中,“虚拟主机”功能可以在“导航”窗口的快捷菜单中使用。现在所有必要的信息和控制命令都方便简捷地排列在“VPS”选项卡中:




    基本订阅信息显示在左侧:

    • 连接数据:比较您主机服务器和本地计算机上的客户端运行之间的网络延迟。
    • 租用主机的交易账户和付款计划。
    • 独特的订阅标识符。点击ID打开MQL5.community用户个人资料中的“主机”部分,也可以在这里管理订阅。
    • 注册日期和当前状态。如果主机服务停止,那么相应的状态将立即出现在这里。

    使用“启动/停止”按键,虚拟程序端可以快速启动或停止。

    有关主机服务器硬件和CPU使用图表的数据显示在右侧窗口区。根据显示的信息,如果您的EA交易或指标使用了过多的内存或CPU时间,您将可以及时作出响应。

    有关最后交易的环境迁移以及迁移命令的信息也在这里提供。这些命令可以在购买订阅后加快环境迁移的速度。

    虚拟平台可以从“VPS”选项卡租用。租用过程不变,仍旧可以快速轻松完成租用。您只需选择一个计划和一个合适的付款方式。将会自动选择连接您交易商的最佳服务器。




  2. 添加在交易商网站快速切换到入金/出金操作的能力。

    无需在交易商网站的交易者室中搜索对应的功能。可在程序端中直接获得快速导航命令:“导航”和“工具箱”中的账户菜单 > 交易选项卡:



    • 只有在交易商对交易账户启用对应的功能,才可以进行入金/出金操作。
    • 交易程序端不执行任何账户入金/出金操作。集成功能将用户重新定向到对应的交易商网站页面。
  3. 交易品种规格中的新字段:

    分类
    这个属性用于额外标记交易品种。例如,这可以是该交易品种所属的市场行业:农业、石油&天然气等。只有在交易商提供对应信息的情况下才显示分类。

    交易所
    进行证券交易的交易所名称。只有在交易商提供对应信息的情况下才显示分类。

    手续费
    有关交易商为成交交易品种所收取的手续费的信息。计算详细信息在这里显示:

    • 手续费包括单级手续费和多级手续费,即无论成交量/交易额是多少,手续费都是相同的,或者可以根据交易规模而定。对应的数据在程序端显示。
    • 手续费可以在交易完成后,或在交易日/交易月结束时立即收取。
    • 手续费可以依据成交方向进行收取:市场买入、市场卖出或两种都包括的操作类型。
    • 手续费可按照每手或每笔交易来收取。
    • 手续费能够以资金金额、百分比或点数来计算。

    例如,下面进入交易表示交易进入和退出时立即收取手续费。如果成交量为0 - 10手,那么每次操作收取1.2 USD手续费。如果成交量为11 - 20手,那么每笔交易每手收取1.1USD手续费。
    手续费 | 立即、交易量、进入/退出交易
    0  - 10  | 每笔交易1.2 USD
    11 - 20  | 每手交易1.1 USD



  4. 附加期权相关字段已添加到交易品种规格中:

    • 期权类型 — 买进或卖出
    • 标的 — 期权的标的交易品种
    • 执行价格 — 期权执行价格

  5. 添加对期权"Greeks"交付的支持:delta、gamma、vega、theta、rho。交易商可以提供与此类交易品种相关的其他信息。这些数据显示在“市场报价”窗口的“详细信息”部分并可用于高级交易分析:



  6. “十字光标”工具现在除了之前可用的信息之外,还表示以百分比计算的价格水平之间的距离。




  7. 添加显示在“市价”执行和“交易所”执行操作期间交易对话框中产生的价格,如果该价格在收到交易商的响应时可用:




  8. 修正由于“市场报价”窗口中的“全部显示”命令无法显示所有可用交易品种列表而产生的错误。

MQL5

  1. 作用域操作已得到修改,因此MQL5更加接近C++。这为MQL5程序员在使用第三方程序库时提供更广泛的可能性。此更新消除了修改程序库和统一标识符的需求。

    例如,代码包含两个同名结构的声明,即使它们属于不同的类。在早期版本中,这类声明会导致编译错误:“标识符已使用”。现在,这个代码将被成功编译并执行。要从作用域外正确地访问所需的变量/结构/函数,您应指定一个类(在本例中是CBar::Item)。
    class CFoo
      {
    public:
       struct Item { int x; };
      };
    //+------------------------------------------------------------------+
    class CBar
      {
    public:
       struct Item { int x; };
      };
      
    CBar::Item item;  // 正确声明Bar类的Item结构
    Item       item;  // 错误声明
    添加namespace支持,它可以在MQL5应用程序使用第三方代码/程序库时提供更多的可能性。

    #define PrintFunctionName() Print(__FUNCTION__)
    
    namespace NS
    {
    void func()
      {
       PrintFunctionName();
      }
    
    struct C
      {
       int               x;
                         C() { PrintFunctionName(); };
      };
    }
    
    struct C
      {
       int               x;
                         C() { PrintFunctionName(); };
      };
    
    //+------------------------------------------------------------------+
    //|                                                                 |
    //+------------------------------------------------------------------+
    void func()
      {
       PrintFunctionName();
      }
    //+------------------------------------------------------------------+
    //| 脚本程序起始函数                                                 |
    //+------------------------------------------------------------------+
    void OnStart()
      {
       func();
       NS::func();
    
       C c;
       NS::C ac;
      }
    执行时,输出以下结果:
    2019.09.18 13:39:35.947    TestScript (AUDCAD,H1)    func
    2019.09.18 13:39:35.949    TestScript (AUDCAD,H1)    NS::func
    2019.09.18 13:39:35.949    TestScript (AUDCAD,H1)    C::C
    2019.09.18 13:39:35.949    TestScript (AUDCAD,H1)    NS::C::C

  2. 新版本支持使用以下函数更快速地访问时间序列数据:iTime、 iOpen、iHigh、iLow、iClose、iVolume、iTickVolume、iSpread。

  3. 添加对"=delete"属性的支持。它可以禁止使用某些类方法。
    class A
      {
       void              operator=(const A &)=delete;    // 禁止对象复制操作符
      };
    
    class B : public A
      {
      };
    
    //+------------------------------------------------------------------+
    //| 脚本程序起始函数                                                 |
    //+------------------------------------------------------------------+
    void OnStart()
      {
       A a1,a2;
       B b1,b2; 
      
       a1=a2;
       b1=b2;
      }
    在这个示例中,编译器将返回错误"a1=a2"和"b1=b2":
    试图引用已删除函数'void A::operator=(const A&)'
       'void A::operator=(const A&)'函数在这里被明确删除

    试图引用已删除函数'void B::operator=(const B&)'
       'void B::operator=(const B&)'函数被隐式删除,因为它由已删除函数'void A::operator=(const A&)'产生

  4. 以下值已被添加到ENUM_SYMBOL_INFO_STRING枚举:

    • SYMBOL_CATEGORY — 交易品种分类。它用于额外标记交易品种。例如,这可以是该交易品种所属的市场行业:农业、石油&天然气等。
    • SYMBOL_EXCHANGE — 进行交易品种交易的交易所的名称。

  5. 添加对通过FIFO规则平仓的支持。

    • ACCOUNT_FIFO_CLOSE值已被添加到ENUM_ACCOUNT_INFO_INTEGER。它表示只能通过FIFO规则平仓。如果属性值为true,那么每个交易品种都将按照持仓的相同顺序进行平仓:最早的持仓应最先平仓,然后以此类推。如果试图以不同的顺序进行平仓,则将返回一个错误。没有锁仓管理的账户的属性值始终为'false' (ACCOUNT_MARGIN_MODE!=ACCOUNT_MARGIN_MODE_RETAIL_HEDGING)。
    • 新返回代码:MT_RET_REQUEST_CLOSE_ONLY — 请求被拒绝,因为交易品种已经设置“仅通过FIFO规则关闭现有持仓”规则

    主要有三种平仓方法:

    • 从客户端平仓:交易者使用EA,基于“信号”服务订阅等手动平仓。如果试图平仓,但不符合FIFO规则,那么交易者将收到一个对应的错误。
    • 在“止损”或“止盈”激活时平仓:这些订单在服务器端处理,因此不在交易者端(程序端)请求平仓,而是由服务器发起。如果一个持仓触发“止损”或“止盈”,且该持仓不符合FIFO规则(相同交易品种有一个更早的持仓),则该持仓将不会平仓。
    • 在“强平”触发时平仓:这些操作也在服务器端处理。在正常模式下(禁用基于FIFO平仓),“强平”时从亏损最大的持仓开始平仓。如果启用此选项,则将为亏损持仓额外检查开仓时间。服务器确定每个交易品种的亏损持仓,找出每个交易品种的最早持仓,然后在找到的持仓中关闭亏损最大的持仓。

  6. 添加通过“输入组”进行参数分组的选项。这可以根据参数的基本逻辑实现参数的可视化分离。

    在以下EA交易代码中,输入参数根据其用途进行分组:
    input group           "Signal"
    input int             ExtBBPeriod = 20;         // 布林带周期
    input double          ExtBBDeviation=2.0;       // 偏差
    input ENUM_TIMEFRAMES ExtSignalTF=PERIOD_M15;   // BB时间周期
    
    input group           "Trend"
    input int             ExtMAPeriod = 13;         // Moving Average period
    input ENUM_TIMEFRAMES ExtTrendTF=PERIOD_M15;    // MA 时间周期
    
    input group           "ExitRules"
    input bool            ExtUseSL      = true;     // 使用“止损”
    input int             Ext_SL_Points = 50;       // StopLoss in points
    input bool            ExtUseTP      = false;    // 使用“止盈”
    input int             Ext_TP_Points = 100;      // TakeProfit in points
    input bool            ExtUseTS      = true;     // 使用“追踪止损”
    input int             Ext_TS_Points = 30;       // 以点数计算“追踪止损”
    
    input group           "MoneyManagement"
    sinput double         ExtInitialLot =0.1;       // 初始手数值
    input bool            ExtUseAutoLot =true;      // 自动手数计算
    
    input group           "Auxiliary"
    sinput int            ExtMagicNumber =123456;   // EA幻数
    sinput bool           ExtDebugMessage=true;     // 打印调试信息
    当这种EA在“策略测试”中启动时,输入参数块可以通过双击组名来折叠或扩展,并且可以通过单个复选框选择组内的所有参数进行优化。




  7. 修正导入名称匹配MQL5函数名称的DLL函数。例如:
    #import "lib.dll"
    int func();
    #import
    //+------------------------------------------------------------------+
    //|                                                                  |
    //+------------------------------------------------------------------+
    int func()
      {
       return(0);
      }
    //+------------------------------------------------------------------+
    //| 脚本程序起始函数                                                 |
    //+------------------------------------------------------------------+
    void OnStart()
      {
       Print( func() );
      }
    在早期版本中,编译时会返回以下错误:
    'func' - 对具有相同参数的重载函数的模糊调用可以是2种函数之一
       int func()
       int func()
    现在,默认情况下将使用优先级更高的内置MQL5函数,来代替错误。导入的函数可以通过显式指定作用域来调用:
    void OnStart()
      {
       Print( lib::func() );
      }
  8. 修正经济日历新闻中的时间规格。现在,交付事件时考虑的是程序端所连接的交易服务器的时区,而不是本地计算机的时区。
  9. 修正CopyticksCopyTicksRange函数中的过多内存消耗。

信号

  1. 修正使用Wine(Mac OS和Linux)工作时信号图表的显示。

Tester

  1. 策略测试的大规模更新。全新开始页面、重新设计的设置页面、提高了可用性。

    开始页面
    现在,tester启动之后,用户看到的是一个标准任务列表,而不是多个设置,通过选择任务,用户可以快速开始测试。新设计主要是为没有经验的用户而准备的。

    我们选择最频繁的策略测试和优化任务,并将其添加到开始页面。此外,还可以从开始页面重新启动一个以前执行的任务。如果您运行了多个任务,且这些任务不适合开始页面,那么请使用搜索栏。您可以通过任何参数找到测试:程序名称、交易品种、时间周期、建模模式等。




    隐藏不相关的参数
    选择任务之后,用户继续进一步测试参数:选择EA交易、交易品种、测试周期等。所选任务不需要的所有无关参数都将从设置页面中隐藏。例如,选择数学计算,只需要指定两个参数:选择要测试的程序和优化模式。在测试期间,将会隐藏延迟和报价生成的设置。




    方便测试设置
    为了方便起见,设置页面上的一些参数已经重新排列。对延迟和可视化参数添加了扩展解释。此外,现在测试设置可以手动保存和加载,因此交易者可以快速返回到以前的设置。




    使用相同的选项卡,您可以在MetaEditor中快速打开程序进行编辑。

    以点数计算盈利
    使用这些设置,您可以启用以点数计算盈利。这种模式加快了测试速度,同时不需要使用转化率以入金货币重新计算盈利(因此没有必要下载对应的价格历史)。在此模式下,取消库存费和手续费的计算。




    请注意,当以点数计算盈利时,成交量并不重要。每笔交易只计算盈/亏点数。此外,在此模式下不执行预付款控制。只将其用于快速粗略的策略评估,然后使用更精确的模式检查得到的结果。

    一般改进
    测试启动/停止按键和进度条已经被移到选项卡栏。因此,用户可以控制任何“策略测试”部分的流程。测试启动/停止命令也被添加到设置和输入部分的快捷菜单中。




  2. 优化图表现在可以显示在程序端的主工作区,而不是显示在单独的策略测试区。这样,就可以为数据分析提供更多的空间。同时更新了3D可视化系统。




  3. 为“市场报价中全部交易品种”模式添加保存优化缓存
  4. 添加保存测试缓存。

    在早期版本中,只有在优化EA交易时才会将所执行任务的结果保存到文件中。现在,单个测试期间也保存缓存文件,通过它用户可以返回到之前的计算,并随时查看统计数据、结余、净值和入金加载图。在未来的版本中,这个选项将支持测试结果的比较。

    要加载之前的测试结果,请使用Tester新开始页面:点击“之前的结果”并选择想要的网站:




  5. 明显加快了测试和优化的速度,包括使用MQL5云网络执行的操作。
  6. 修正并优化了周期操作。

MetaEditor

  1. 添加配置代码样式(styler)的功能。

    MetaEditor包含一个内置代码样式(styler),它可以根据所采用的标准自动格式化程序文本。现在除了常见样式外,您还可以使用其他流行的标准。为此,请打开MetaEditor设置并选择所需的样式:




    可以为样式(styler)额外设置以下参数:

    每个缩进空间
    设置用于对齐内嵌结构的空格数:
    if(condition)
      {
       //---
      }

    用空格代替制表符
    如果启用此选项,样式(styler)将用空格代替代码中的所有制表符。每个制表符的字符数在“一般”部分中设置。

    删除空行
    启用此选项后,样式(styler)将删除只有一个换行符的所有行。

    在逗号和分号之后插入空格
    启用此选项后,样式(styler)将使用元素枚举以可视方式分隔结构。示例:
    // 之前样式
    ParameterGetRange("InpX",enable,x_cur,x_start,x_step,x_stop);
    // 之后样式
    ParameterGetRange("InpX", enable, x_cur, x_start, x_step, x_stop);

    在声明操作符周围插入空格
    启用此选项后,样式(styler)将围绕赋值、等式、比较和其他操作符插入空格。示例:
    // 之前样式
    if(x==1&y!=2)
      {
       int a=0;
      }
    // 之后样式
    if(x == 1 & y != 2)
     {
      int a = 0;
     }

  2. “在导航中显示”命令已添加到文件书签的快捷菜单。因此,用户可以轻松地在编辑器文件夹结构中找到要编辑的打开文件。




  3. 修正在工具提示中显示'union'关键字。

用户界面翻译又添加了18种新语言:


  • 欧盟地区 — 瑞典语、立陶宛语、丹麦语、拉脱维亚语、爱沙尼亚语、塞尔维亚语、斯洛文尼亚语、斯洛伐克语、芬兰语、格鲁吉亚语
  • 亚洲地区 — 爪哇语、马拉地语、孟加拉语、旁遮普语、泰米尔语、泰卢固语
  • 非洲地区 — 斯瓦西里语、豪萨语

该平台界面现已支持50种语言,涵盖40多亿人使用的语言。

若要设置界面语言,请进入程序端顶部的“查看\语言”菜单。

文档已更新。

基于崩溃日志进行修复。

更新将通过实时更新系统提供。

12 六月 2019
MetaTrader 5平台build 2085:集成Python并改进策略测试

程序端

  1. 添加新API,使用Python语言通过应用程序,启用MetaTrader 5程序端数据请求。

    Python是一种用于开发脚本和应用程序的现代高水平编程语言。它包含用于机器学习、自动化处理以及数据分析和可视化的多个程序库。

    MetaTrader Python程序包是为有效快速地从MetaTrader 5程序端直接通过处理器通信获得交易所数据而设计的。通过这种途径接收的数据可以进一步用于统计计算和机器学习。



    连接

    1. https://www.python.org/downloads/windows下载最新版Python
    2. 安装Python期间,请检查“将Python X.X添加到PATH%”,以便能够从命令行启用Python脚本。
    3. 从命令行安装MetaTrader 5模块
      pip安装MetaTrader5
    4. 添加matplotlib和pytz包
      pip安装matplotlib
      pip安装pytz

    函数


  2. 优化了市场信号部分。现在,产品和信号展示的运行速度提高了7倍,从而提供了更好的浏览体验服务。




  3. 新增在Wine系统下支持“市场”、“信号”和“搜索”。LinuxMac OS用户现在可以访问最大的交易应用程序商店和复制交易服务。




  4. 内置学习程序已被翻译成30多种语言,包括西班牙语、中文、葡萄牙语和德语。若要查看所需语言的互动提示,请使用“查看”菜单切换界面语言。




  5. 新选项可以验证交易者在开设模拟账户和初始账户时指定的电话号码和电子邮箱。

    是否需要验证数据由交易商来决定。如果启用了这个选项,确认码会在账户请求时自动发送给交易者,对话框中会出现特殊代码字段:




    确认码在几分钟内有效。如果在这个时间段内没有将确认码输入到字段中,那么交易者将需要重复这个程序。

    发送确认码之前,系统将检查指定电话号码/电子邮箱是否之前已确认。如果交易者已在他或她的计算机上通过了验证,那么将无需额外确认即可开户。因此,交易者在请求账户时不会遇到额外的困难。

  6. 扩展了通过PayPal系统进行付款的MQL5.community付款选项。现在,使用该系统可实现一键购买。

    如何工作
    当您使用PayPal账户登录进行购买之后,您将被要求允许进一步付款给我们公司:





    确认此选项后,您只需点击之前保存的账户按键,即可一键执行进一步购买:




    如果您点击“取消并返回MetaQuotes Software Corp.”,您将以正常的方式进行付款,为每次购买手动输入PayPal账户详情。
    MQL5.com网站和MetaTrader 5平台不存储您的付款详情。当您存款购买“市场”产品或订阅“信号”时,在付款系统端将执行数据验证。
    您可以随时移除您的PayPal 账户链接。

  7. 策略测试器的改进和优化。

    我们引入了大量隐藏的改进和修正的错误来优化策略测试器操作。此更新可以更快地测试一些任务类型,使操作稳定性更高。主要改进包括:

    框架操作
    本地、网络和源代码的操作框架得到优化。这类操作现在处理速度更快,永远不会跳过。

    将任务分配给代理
    测试器现在可以在优化过程中将任务重新分配给代理。如果有新代理可用(或发布之前用过的一个代理),测试器会使用之前在其他代理中分配的任务包自动创建新的任务包。如果检测出代理速度慢,任务还可以重新分配。这类代理的任务被发送至其他代理,以便更快地完成优化。

    数学计算模式下的任务分配速度会更快。

    日志中的优化统计
    优化日志记录得以扩展:它包括与MQL5云网络使用相关的详细统计,启用和禁用云代理等。

    在全优化日志模式下运行
    为了获得最佳的资源消耗,并不是所有来自代理的消息都被记录到测试日志中。若要查看所有日志,您可以通过测试日志快捷菜单启用“完整优化日志”选项。此前,这个模式可以明显拖慢优化进程。而现在则不会影响计算时间。

    MQL5云网络
    优化云测试代理的运行。现在,计算任务的分配更加有效。

  8. 内置经济日历提供了18个全球大型经济体相关的900+指标,包括美国、欧盟、日本和英国等国家。相关数据都是从开放资源实时收集。通过定期查看此服务,交易者可以随时了解最新的全球新闻,并做出明智的交易决策。

    经济日历可在桌面版、网页版以及移动设备上使用。可以使用程序端的“日历”快捷菜单打开应用程序:




    选择您的平台并下载Tradays apps:


    除了桌面平台提供的日历功能之外,移动版还以图表和表格的形式提供事件提醒和访问指标的完整历史记录。

  9. 添加了在导入报价历史期间自动生成自定义交易品种柱形历史。现在,如果自定义交易品种的报价数据出现变化,对应的柱形图也自动重新计算。

    • 因此,统一的数据被保存在平台中。
    • 导入报价数据(假设有足够的数据)之后,因为由程序端自动计算,而无需导入柱形图。

    更改涉及通过程序端界面执行的报价导入,以及使用CustomTicks*函数从MQL5应用程序执行的报价更新。报价数据的任何变化都会导致重新计算对应的自定义交易品种的1分钟柱形图。

  10. 修正当在分离图表上使用十字光标时“数据窗口”中的数据更新。
  11. 修正报价历史保存。在早期版本中,一毫秒内的多个报价可能以错误的顺序保存。
  12. 修正基于服务器上过短的价格历史(少于一天)生成图表的问题。

MQL5

  1. 添加MQL5服务调试选项。现在可以对这些应用程序进行类似于EA交易和指标的测试。
  2. ENUM_SYMBOL_CALC_MODE枚举中,添加了全新的盈利和预付款计算模式:

    • SYMBOL_CALC_MODE_EXCH_BONDS — 适用于交易所债券的计算。
    • SYMBOL_CALC_MODE_EXCH_STOCKS_MOEX — 适用于莫斯科交易所股票交易的计算。
    • SYMBOL_CALC_MODE_EXCH_BONDS_MOEX — 适用于莫斯科交易所债券交易的计算。

  3. TesterDeposit函数支持在测试期间模拟入金操作。该函数适用于测试资金管理策略。
    bool  TesterDeposit(
       double money      //入金金额
       );
  4. OnDeinit方法执行期间,MQL5应用程序不会从程序端接收任何事件。以前,由于接收到其他事件,应用程序有时无法完成去初始化(例如,删除所有创建的对象)。
  5. 修正当日更改自定义交易品种报价历史后可能发生的偶然错误。
  6. 修正使用大量图形对象(数以万计)时应用程序偶尔出现的运行速度减慢的问题。
  7. 修正从MQL5程序频繁调用交易历史的情况下出现程序端冻结的问题。
  8. 修正iBarShift函数操作。通过"exact=false"标识和数据外的请求,该函数返回最早的柱数而不是最新柱数。

Tester

  1. 修正确定有多个NUMA节点的计算机处理器上的内核数。
  2. 添加使用零初始入金运行测试和优化的可能性,因为使用新TesterDeposit函数可以在测试期间模拟入金操作。

MetaEditor

  1. 现在,整码器命令可添加到工具栏以快速访问。
  2. 修正在函数和变量名称中使用非统一字符时切换到参数定义和查看相关数据。

文档已更新。

更新内容通过LiveUpdate系统提供。

21 二月 2019
MetaTrader 5平台build 2005:经济日历,MQL5应用程序服务以及R语言API

程序端

    1. 完全修正了内置经济日历。

      经济日历是我们专有的解决方案。在这里,您将看到600+财经新闻和与美国、欧盟、日本、英国、加拿大、澳大利亚、中国等,全球13个大型经济体相关的指标。相关数据都是从开放资源实时收集。

      新版本具有更新的内容和高级的事件过滤器:按照时间、优先级、货币和国家来分类。

      现在可以从MQL5程序访问经济日历数据。请参阅以下内容了解详情。




    2. 新增一种全新的MQL5应用程序类型 —— 服务。这个新类型可以为程序端创建自定义价格源,即,可以实现实时交付来自外部系统的价格,如同直接在交易商交易服务器上实施。

      与EA交易、指标和脚本不同,服务并不链接特定的图表。这些应用程序在后台运行,当程序端启动时自动启动(除非被强制停止)。

      服务可以从“导航”窗口的一个新部分进行管理:





      如何创建服务
      若要创建服务模板,请使用对应的MQL5向导选项。服务有一个Onstart切入点,类似于脚本。在这个点,您可以使用网络函数来实现无限的数据接收和处理循环。

      如何启动服务
      要使用不同的参数运行多个EA交易或指标副本,您应该在不同图表上启动它们。在这种情况下,将创建不同的程序实例,然后彼此独立操作。服务没有链接到图表,因此形成了一种创建服务实例的特殊机制。

      从“导航”选择一个服务,并在快捷菜单中点击“添加服务”。这将打开一个标准的MQL5程序对话框,您可以在其中启用/禁用交易和对信号的访问,以及设置参数。




      可以使用对应的实例菜单启动和停止服务实例。要管理所有实例,请使用服务菜单。

    3. 学习方案已实施。

      这个新功能将帮助初学者学习如何与平台互动。我们已经添加了100+关于平台主要功能的互动提示。

      • 这些提示可以在工具栏的进度条上直接显示,因而并不会分散用户的注意力。
      • 这些提示仅针对您在平台上从未执行的操作显示。
      • 所有提示都包含交互式链接,使用这些链接您可以导航到相关的界面元素。例如,可以从提示直接启动带有所需程序的交易对话框或菜单。

      每当您执行对应操作以及继续学习时,进度条的填充区域将会增加。




    4. 交易账户历史记录可以显示为持仓。平台收集与持仓相关的成交数据(开仓、交易量增加、部分或全部平仓)并将这些信息组合成一条记录。因此,您可以访问持仓的详细信息:开仓时间和平仓时间、交易量、价格和结果。这种有效的显示方式现在可以在导出到文件的历史报告中使用。




    5. 通过使用R语言的应用程序,增加MetaTrader 5程序端数据的新API启用请求。

      我们准备了一个特殊的MetaTrader软件包。它包含用于R和MetaTrader 5程序端之间互动的DLL、文档和辅助r文件。我们正在CRAN存储库中完成软件包注册,之后就可以下载和安装。




      软件包可以使用特殊命令来安装:
      R CMD INSTALL --build MetaTrader

      可使用以下与数据请求有关的命令:

      • MT5Initialize初始化并建立与MetaTrader 5程序端的连接。如果需要,可在命令执行期间启动程序端。
      • MT5Shutdown 去初始化并与MetaTrader 5断开连接。
      • MT5Version获得MetaTrader 5程序端版本。
      • MT5TerminalInfo获得到交易商服务器的程序端连接的状态和参数(账号和服务器地址)。
      • MT5WaitTerminal用于等待MetaTrader 5程序端连接到交易商服务器。
      • MT5CopyTicksFrom(symbol, from, count, flags)从指定日期开始复制指定报价数。该日期从1970.01.01开始,以毫秒指定。
      • MT5CopyTicksRange(symbol, from, to, flags)从指定周期内复制报价。这些日期从1970.01.01开始,以毫秒指定。
      • MT5CopyRatesFrom(symbol, timeframe, from, count)从指定日期开始复制指定的一分钟柱数量。该日期从1970.01.01开始,以秒指定。
      • MT5CopyRatesFromPos(symbol, timeframe, start_pos, count)从相对于最后柱形图的指定持仓复制一分钟柱形图。
      • MT5CopyRatesFromRange(symbol, timeframe, date_from, date_to)从指定周期内复制柱形图。这些日期从1970.01.01开始,以秒指定。

      支持的命令列表将进一步扩展。

    6. 优化用于反向平仓的Close By对话框。现在,这个对话框即使您有大量持仓也不会变慢。
    7. 修正了导致偶尔跳过数据的合成交易品种的计算错误。
    8. 自定义交易品种被删除时,存储其报价和柱形图历史的文件也被删除。这可以避免在硬盘上积累不用的数据。
    9. 修正在高清屏幕上显示搜索结果。

    MQL5

    1. 实现从MQL5程序访问经济日历数据。

      新函数

      CalendarCountryById — 根据标识符获得国家描述。
      bool CalendarCountryById(
         const long           country_id,    // country ID
         MqlCalendarCountry&  country        //国家描述
         );
      CalendarEventById — 根据标识符获得事件描述。
      bool CalendarEventById(
         const long           event_id,      // 事件ID
         MqlCalendarEvent&    event          // 事件描述
         );
      CalendarValueById — 根据标识符获得事件值描述。
      bool CalendarValueById(
         const long           value_id,      // 值ID
         MqlCalendarValue&    value          // 值描述
         );
      CalendarEventByCountry — 获得国家可用事件的数组。
      bool CalendarEventByCountry(
         string               country_code,  // 国家代码
         MqlCalendarEvent&    events[]       // 事件数组
         );
      CalendarEventByCurrency — 获得受影响货币的可用事件数组。
      bool CalendarEventByCurrency(
         string               currency,      //货币
         MqlCalendarEvent&    events[]       // 事件数组
         );
      CalendarValueHistoryByEvent — 根据事件标识符,获取特定时期的值数组。
      bool CalendarValueHistoryByEvent(
         ulong                event_id,      // 事件ID
         MqlCalendarValue&    values[],      // 值数组
         datetime             datetime_from, // 特定时期开始日期
         datetime             datetime_to=0  // 特定时期结束日期
         );
      CalendarValueHistory — 根据国家和/或货币筛选,获取所有事件在特定时期的值数组。
      bool CalendarValueHistory(
         MqlCalendarValue&    values[],          // 值数组
         datetime             datetime_from,     // 特定时期开始
         datetime             datetime_to=0,     // 特定时期结束
         string               country_code=NULL, // 国家代码
         string               currency=NULL      // 货币
         );
      CalendarValueLastByEvent — 根据标识符获取最后时间值的数组。此函数可以请求自上一个请求出现的值。这个操作还使用了in/out参数"change_id"。

      每当日历数据库出现变化,"change_id"属性(最后更改的标识符)都会更新。数据请求期间,您指定"change_id"则程序端返回在此之后出现的事件,以及可用于下一个请求的"change_id"当前值。在第一个函数调用期间,指定"change_id"为零:该函数将不返回任何事件,但将为进一步请求返回当前"change_id"。
      bool CalendarValueHistory(
         ulong                event_id,          // 事件ID
         ulong&               change_id,         //最后一个日历更改 ID
         MqlCalendarValue&    values[]           // 值数组
         );
      CalendarValueLast — 根据国家和/或货币筛选,获取所有事件最后值的数组。此函数可以请求自上一个请求出现的值。类似于CalendarValueLastByEvent,请求使用"change_id"属性。
      bool CalendarValueHistory(
         ulong                event_id,          // 事件ID
         ulong&               change_id,         // 最后一个日历更改 ID
         MqlCalendarValue&    values[],          // 值数组
         string               country_code=NULL, // 国家代码
         string currency=NULL                    // 货币
         );

      新结构

      MqlCalendarCountry — 国家描述。
      struct MqlCalendarCountry
        {
         ulong             id;                        // ISO 3166-1中的国家ID
         string            name;                      // 国家文本名称
         string            code;                      // ISO 3166-1 alpha-2中的国家代码名称
         string            currency;                  // 国家货币代码
         string            currency_symbol;           // 国家货币符号/标志
         string            url_name;                  // mql5.com上URL中使用的国家名称
        };
      MqlCalendarEvent — 事件描述。
      struct MqlCalendarEvent
        {
         ulong                          id;           // 事件ID
         ENUM_CALENDAR_EVENT_TYPE       type;         // 事件类型
         ENUM_CALENDAR_EVENT_SECTOR     sector;       // 事件所属区
         ENUM_CALENDAR_EVENT_FREQUENCY  frequency;    // 事件发布频率
         ENUM_CALENDAR_EVENT_TIMEMODE   time_mode;    // 事件发布时间模式
         ulong                          country_id;   // 国家ID
         ENUM_CALENDAR_EVENT_UNIT       unit;         // 时间值单位
         ENUM_CALENDAR_EVENT_IMPORTANCE importance;   // 事件重要性
         ENUM_CALENDAR_EVENT_MULTIPLIER multiplier;   // 事件重要性的倍数
         uint                           digits;       // 事件值中的小数位数
         string                         source_url;   // 源URL
         string                         event_code;   // 事件代码
         string                         name;         // 事件在程序端语言中的文本名称
        };
      MqlCalendarValue — 事件值描述。
      struct MqlCalendarValue
        {
         ulong             id;                        // 值ID
         ulong             event_id;                  // 事件ID
         datetime          time;                      // 事件日期和时间
         datetime          period;                    // 事件发布期间
         int               revision;                  // 就报告所述期间发表的指标修正
         long              actual_value;              // 当前事件值
         long              prev_value;                // 之前事件值
         long              revised_prev_value;        // 修改之前事件值
         long              forecast_value;            // 预测事件值
         ENUM_CALENDAR_EVENT_IMPACRT impact_type;     // 对汇率的潜在影响
        };

      新枚举

      enum ENUM_CALENDAR_EVENT_FREQUENCY
        {
         CALENDAR_FREQUENCY_NONE            =0,   // 没有使用
         CALENDAR_FREQUENCY_WEEK            =1,   // 每周
         CALENDAR_FREQUENCY_MONTH           =2,   // 每月
         CALENDAR_FREQUENCY_QUARTER         =3,   // 每季度
         CALENDAR_FREQUENCY_YEAR            =4,   // 每年
         CALENDAR_FREQUENCY_DAY             =5,   // 每日
        };
      
      enum ENUM_CALENDAR_EVENT_TYPE
        {
         CALENDAR_TYPE_EVENT                =0,   // 事件(会议,演讲等)
         CALENDAR_TYPE_INDICATOR            =1,   // 指标
         CALENDAR_TYPE_HOLIDAY              =2,   // 假日
        };
      
      enum ENUM_CALENDAR_EVENT_SECTOR
        {
         CALENDAR_SECTOR_NONE               =0,   // 无
         CALENDAR_SECTOR_MARKET             =1,   // 市场
         CALENDAR_SECTOR_GDP                =2,   // GDP
         CALENDAR_SECTOR_JOBS               =3,   // 工作
         CALENDAR_SECTOR_PRICES             =4,   // 价格
         CALENDAR_SECTOR_MONEY              =5,   // 资金
         CALENDAR_SECTOR_TRADE              =6,   // 交易
         CALENDAR_SECTOR_GOVERNMENT         =7,   // 政府
         CALENDAR_SECTOR_BUSINESS           =8,   // 业务
         CALENDAR_SECTOR_CONSUMER           =9,   // 消费者
         CALENDAR_SECTOR_HOUSING            =10,  // 家庭
         CALENDAR_SECTOR_TAXES              =11,  // 税收
         CALENDAR_SECTOR_HOLIDAYS           =12,  // 假日
        };
        
      enum ENUM_CALENDAR_EVENT_IMPORTANCE
        {
         CALENDAR_IMPORTANCE_NONE           =0,   // 无
         CALENDAR_IMPORTANCE_LOW            =1,   // 低
         CALENDAR_IMPORTANCE_MODERATE       =2,   // 适中
         CALENDAR_IMPORTANCE_HIGH           =3,   // 高
        };
      
      enum ENUM_CALENDAR_EVENT_UNIT
        {
         CALENDAR_UNIT_NONE                 =0,   // 无
         CALENDAR_UNIT_PERCENT              =1,   // 百分比
         CALENDAR_UNIT_CURRENCY             =2,   // 本国货币
         CALENDAR_UNIT_HOUR                 =3,   // 小时数
         CALENDAR_UNIT_JOB                  =4,   // 工作数
         CALENDAR_UNIT_RIG                  =5,   // 钻井数
         CALENDAR_UNIT_USD                  =6,   // 美元
         CALENDAR_UNIT_PEOPLE               =7,   // 人口数
         CALENDAR_UNIT_MORTGAGE             =8,   // 抵押贷款数
         CALENDAR_UNIT_VOTE                 =9,   // 投票数
         CALENDAR_UNIT_BARREL               =10,  // 原油桶数
         CALENDAR_UNIT_CUBICFEET            =11,  // 立方英尺数量
         CALENDAR_UNIT_POSITION             =12,  // 工作职位数
         CALENDAR_UNIT_BUILDING             =13   // 建筑物数量
        };
        
      enum ENUM_CALENDAR_EVENT_MULTIPLIER
        {
         CALENDAR_MULTIPLIER_NONE           =0,   // 无
         CALENDAR_MULTIPLIER_THOUSANDS      =1,   // 数以千计
         CALENDAR_MULTIPLIER_MILLIONS       =2,   // 数百万
         CALENDAR_MULTIPLIER_BILLIONS       =3,   // 数十亿
         CALENDAR_MULTIPLIER_TRILLIONS      =4,   // 数万亿
        };
        
      enum ENUM_CALENDAR_EVENT_IMPACRT
        {
         CALENDAR_IMPACT_NA                 =0,   // 不可使用
         CALENDAR_IMPACT_POSITIVE           =1,   // 积极影响
         CALENDAR_IMPACT_NEGATIVE           =2,   // 消极影响
        };
      
      enum ENUM_CALENDAR_EVENT_TIMEMODE
        {
         CALENDAR_TIMEMODE_DATETIME         =0,   //消息来源发布确切时间
         CALENDAR_TIMEMODE_DATE             =1,   // 该事件花了一整天时间
         CALENDAR_TIMEMODE_NOTIME           =2,   //消息来源没有发布事件时间
         CALENDAR_TIMEMODE_TENTATIVE        =3,   // 消息来源只提供日期,但没有提前发布确切时间,确切时间在事件发生时添加
        };

      新错误代码

      ERR_CALENDAR_MORE_DATA             =5400,   // 低于整个结果,数组较小(传递数组中合适的值)
      ERR_CALENDAR_TIMEOUT               =5401,   // 等待经济日历数据请求的反应超时
      ERR_CALENDAR_NO_DATA               =5402,   // 数据没找到

    2. 有关报价和柱形图历史的修正和操作速度的改进。
    3. 有关自定义交易品种的报价和柱形图更改函数CustomTicks*CustomRates*的修正和操作速度显著提高。
    4. 新增数据转化漏斗模型。

      CharArrayToStruct将uchar数组复制到POD结构。
      bool  CharArrayToStruct(
         void&         struct_object,    //结构
         const uchar&  char_array[],     // 数组
         uint          start_pos=0       // 数组中的开始位置
         );
      StructToCharArray将POD结构复制到uchar数组。
      bool  StructToCharArray(
         const void&  struct_object,     //结构
         uchar&       char_array[],      //数组
         uint         start_pos=0        // 数组中的开始位置
         );

    5. 添加MathSwap函数,用于更改ushort、uint和ulong值中的字节顺序。
      ushort MathSwap(ushort value);
      uint   MathSwap(uint   value);
      ulong  MathSwap(ulong  value);

    6. 添加网络函数,用于通过系统套接创建TCP与远程主机的连接:

      • SocketCreate创建具有指定标识的套接并返回其句柄
      • SocketClose关闭套接
      • SocketConnect连接到服务器,使用超时控制
      • SocketIsConnected检查套接当前是否已连接
      • SocketIsReadable获得可以从套接读取的字节数
      • SocketIsWritable检查在当前时间是否可以将数据写入该套接
      • SocketTimeouts为系统套接对象设置数据接收和发送超时
      • SocketRead从套接读取数据
      • SocketSend将数据写入套接
      • SocketTlsHandshake使用TLS Handshake协议启动与指定主机的安全TLS (SSL)连接
      • SocketTlsCertificate接收有关用于安全网络连接的证书的信息
      • SocketTlsRead读取来自安全TLS连接的数据
      • SocketTlsReadAvailable读取来自安全TLS连接的所有可用数据
      • SocketTlsSend使用TLS连接发送数据

      使用网络函数建立连接的主机地址必须明确添加到程序端设置中的可允许地址列表中。

      为网络函数的操作添加了新错误代码

      • ERR_NETSOCKET_INVALIDHANDLE (5270):传递给函数的套接句柄无效
      • ERR_NETSOCKET_TOO_MANY_OPENED (5271):打开套接过多(最多128)
      • ERR_NETSOCKET_CANNOT_CONNECT (5272):连接远程主机时出错
      • ERR_NETSOCKET_IO_ERROR (5273):从套接发送/接收数据时出错
      • ERR_NETSOCKET_HANDSHAKE_FAILED (5274):安全连接建立错误 (TLS Handshake)
      • ERR_NETSOCKET_NO_CERTIFICATE (5275) — 没有用于安全连接的证书数据

    7. 添加用于字符串操作的新函数

      StringReserve为字符串保留指定大小的内存缓存区。
      bool  StringReserve(
         string&        string_var,          // 字符串
         uint           new_capacity         // 字符串的缓冲区大小
         );
      StringSetLength设置字符中指定的字符串长度。
      bool  StringSetLength(
         string&        string_var,          //字符串
         uint           new_length           //新字符串长度
         );

    8. 为数组操作添加新函数

      ArrayRemove从数组中移除从指定索引开始的指定元素数。
      bool  ArrayRemove(
         void&         array[],              // 任何类型的数组
         uint          start,                // 要开始移除的索引
         uint          count=WHOLE_ARRAY     // 元素数
         );
      ArrayInsert 从指定索引开始,向接收方数组插入源数组中指定元素数。
      bool  ArrayInsert(
         void&         dst_array[],          // 接收方数组
         const void&   src_array[],          // 源数组
         uint          dst_start,            // 在要插入的接收方数组位置的索引
         uint          src_start=0,          // 要开始复制的源数组索引
         uint          count=WHOLE_ARRAY     // 插入元素数
         );
      ArrayReverse从指定索引开始,在数组中反转指定元素数。
      bool  ArrayReverse(
         void&         array[],              // 任何类型的数组
         uint          start=0,              // 开始反转的索引
         uint          count=WHOLE_ARRAY     // 元素数
         );

    9. 新"uint count"参数已被添加到CustomRatesUpdateCustomRatesReplaceCustomTicksAddCustomTicksReplace函数中。它可以指定传递数组中将要用于这些函数的元素数量。WHOLE_ARRAY值默认用于参数。这意味着整个数组将被利用。
    10. 添加CustomBookAdd函数,以传递自定义交易品种的市场深度的状态。该函数可以推广市场深度,类似于价格从交易商服务器到达。
      int  CustomBookAdd(
         const string        symbol,            // 交易品种名称
         const MqlBookInfo&  books[]            // 带有DOM元素描述的数组
         uint                count=WHOLE_ARRAY  // 要使用的元素数
         );
    11. 添加CustomSymbolCreate函数重载。它可以基于现有交易品种创建一个自定义交易品种。创建之后,可以使用对应的函数编辑任何交易品种的属性。
      bool  CustomSymbolCreate(
         const string        symbol_name,       //自定义交易品种名称
         const string        symbol_path="",    // 将在其中创建交易品种的组名
         const string        symbol_origin=NULL // 将基于其创建自定义交易品种的交易品种名称
         );
      自定义交易品种属性的复制源的交易品种名称在"symbol_origin"参数中指定。

    12. 将带有日期/时间的字符串转换为datetime值的StringToTime函数已经更新。现在,它支持以下日期格式:

      • yyyy.mm.dd [hh:mi]
      • yyyy.mm.dd [hh:mi:ss]
      • yyyymmdd [hh:mi:ss]
      • yyyymmdd [hhmiss]
      • yyyy/mm/dd [hh:mi:ss]
      • yyyy-mm-dd [hh:mi:ss]

    13. ENUM_TERMINAL_INFO_INTEGER枚举中的TERMINAL_VPS新属性;它显示程序端正在MetaTrader虚拟主机服务器上运行 (MetaTrader VPS)。如果应用程序在主机服务器上运行,您可以禁用其所有可视化功能,因为虚拟服务器没有图形用户界面。
    14. ENUM_SYMBOL_INFO_INTEGER枚举中的SYMBOL_EXIST新属性,意味着同名交易品种已存在。
    15. 修正使用模板函数预声明时的输入。
    16. 添加更改交易账户时重新初始化指标的功能。
    17. 优化StringSplit函数。
    18. 修正标准程序库操作中的错误。

    Tester

    1. 新增TesterStop函数 — 测试代理上EA交易的例行早期关闭。现在,达到指定数量的亏损交易、预设的下跌水平或任何其他标准后,您可以强制停止测试。

      使用此函数完成的测试被视为成功测试。函数调用之后,测试期间获得的交易历史和所有交易统计数据将被传递到程序端。

    2. 禁止在实时报价模式下通过MQL5云网络测试和优化EA交易的功能。这个模式只能在本地代理和本地网络上使用。
    3. 改进了可视化测试过程中的指标使用。现在,价格图表和指标线同步绘制,甚至包括最大的可视化速度。
    4. 优化并显著增加了测试和优化的速度。
    5. 修正了关于历史数据的指标调试。现在,可以正确地调试OnInit和OnDeinit指标函数。
    6. 在测试多货币EA交易时,更快访问历史数据。
    7. 修正在调试历史数据期间可视化测试器的偶尔冻结问题。
    8. 当通过代理处理任务包时,更快启动优化传递。
    9. 更改了向测试代理分发任务包的策略。任务包大小增加,从而大大减少网络操作上的资源损耗。
    10. 更改了选项行为,允许使用本地、网络和云代理。现在,当您关闭这些选项时,代理将完成接收任务的处理,且不再向其提供新任务。在早期版本中,该行为类似于“禁用”命令,该命令可以立即停止代理操作。




    MetaEditor

    1. 在调试器中添加了对非ANSI字符的支持。现在,即使使用斯拉夫字母指定变量名称,表达式仍可以正确显示。
    2. 修正在高清屏幕上显示搜索结果。

    添加克罗地亚语的用户界面翻译。

    文档已更新。

26 十月 2018
新版MetaTrader 5平台build 1930:浮动窗口图表和MQL5中的.Net程序库

程序端

  1. 现在,您可以在交易程序端窗口之外使用交易品种图表。

    这个功能的便利性在使用多个显示器进行操作时非常明显。因此,您可以在一个显示器上设置平台的主窗口来管理您的账户状态,并将您的图表移动到另一个显示器上以观察市场动向。若要将图表从程序端分离,请在快捷菜单中禁用“固定”选项。然后,将图表移动到所需的显示器。





    通过分离图表的独立工具栏可以应用分析对象和指标,而无需在显示器间进行切换。使用工具栏快捷菜单来管理可用命令集或将命令隐藏。

  2. 完全更新的嵌入式聊天功能。现在,该功能支持群组聊天和频道交流。可以在一个环境内与一个群组的人们进行私人讨论,而不需要在不同的对话之间切换,您还可以根据您的兴趣和语言创建频道。在MQL5.community与同业和好友进行交流,而不需要访问网站。

    群组聊天和频道交流既可以是公开的,也可以设为私人状态。由创建者来决定是否可以自由加入群聊或是只能通过邀请加入。您还可以为频道和聊天分派版主/群主,为了进一步进行交流管理。




  3. 新增对数字加密货币交易提高交易量精确性的支持。现在,交易操作可允许的最小交易量为0.00000001手数。现在,市场深度,成交时间和交易量,以及其他界面元素都能够精确显示到小数点后8位。

    最小交易量及其变动幅度取决于交易商的交易品种设置。




  4. 在工具箱窗口,添加了MQL5.community网站发布的文章的选项卡。现在,在程序端可以直接获得600多篇关于使用MQL5开发交易策略的详细材料。每周都会发布新文章。




  5. 新增在Wine系统下操作时,支持使用证书进行扩展认证
  6. 修正了市场深度被限定在一个水平时的显示。
  7. 将“另存为图片”的命令添加到标准工具栏中。现在,保存图表图片并将其分享在社区中会更加容易。




  8. 修正导入柱形图和报价时,应用时间切换。之前,在某些情况下无法使用时间切换。




  9. 修正大量经济日历新闻情况下的程序端冻结。

MQL5

  1. 添加了通过"smart"导入函数对.NET程序库的本机支持。现在,.NET程序库可以在无需编写特殊包装样式的情况下使用 — MetaEditor可以独立完成。

    若要使用.NET程序库函数,只需导入DLL本身,而不必定义特定的函数。MetaEditor自动导入所有可以使用的函数:
    • 简单结构(POD,普通旧数据) — 仅包含简单数据类型的结构。
    • 有参数的公共静态函数,在这里只有简单类型和POD结构或其数组可被使用

    若要从程序库调用函数,简单导入即可:
    #import "TestLib.dll"
    
    //+------------------------------------------------------------------+
    //| 脚本程序起始函数                         |
    //+------------------------------------------------------------------+
    void OnStart()
      {
       int x=41;
       TestClass::Inc(x);
       Print(x);
      }
    TestClass的Inc函数C#代码如下:
    public class TestClass
    {
       public static void Inc(ref int x)
       {
        x++;
       }
    }
    作为执行结果,脚本返回值为42。

    对.NET程序库的支持工作仍继续。其功能将在未来得到扩展。

  2. 添加了支持使用标准程序库的WinAPI函数。现在,不需要手动导入程序库和描述函数签名来在MQL5程序中使用操作系统函数。只需包括来自MQL5\Include\WinAPI目录的头文件。

    WinAPI函数按其用途在单独的文件中分组:

    • libloaderapi.mqh — 使用资源
    • memoryapi.mqh — 使用内存
    • processenv.mqh — 使用环境
    • processthreadsapi.mqh — 使用流程
    • securitybaseapi.mqh — 使用OS安全系统
    • sysinfoapi.mqh — 获取系统信息
    • winbase.mqh — 常用函数
    • windef.mqh — 常量、结构和枚举
    • wingdi.mqh — 使用图形对象
    • winnt.mqh — 处理异常
    • winreg.mqh — 使用注册表
    • winuser.mqh — 窗口和界面管理
    • errhandlingapi.mqh — 处理错误
    • fileapi.mqh — 使用文件
    • handleapi.mqh — 使用句柄
    • winapi.mqh — 包含所有函数(WinAPI头文件)

    绑定仅适用于64位架构。

  3. 在解析代码时,新增对inline, __inline和 __forceinline描述符的支持。代码中的描述符不会导致错误,也不会影响编译。目前,该特性简化了将С++ 代码转为MQL5。
    MSDN中了解关于描述符的更多信息。

  4. 显著优化了MQL5程序的执行。在某些情况下,性能改进可以达到10%。在新版MetaEditor重新编译您的程序,使其运行得更快。
    遗憾的是,由于这个额外的优化功能,新程序将无法与以前的程序端版本兼容。使用MetaEditor 1910版本编译的程序之后无法在1880版本及更低的程序端中启用。使用早期的MetaEditor版本编译的程序则可以在新版程序端中运行。

  5. 显著优化了MQL5函数集。
  6. 新增向程序端主窗口附加图表/从程序端主窗口分离图表并管理图表位置的新属性。

    添加以下属性到ENUM_CHART_PROPERTY_INTEGER枚举:

    • CHART_IS_DOCKED — 图表窗口固定。如果设为'false',图表可被拖拽到程序端区域之外。
    • CHART_FLOAT_LEFT — 相对于虚拟屏幕的未固定的图表窗口的左坐标。
    • CHART_FLOAT_TOP — 相对于虚拟屏幕的未固定的图表窗口的顶部坐标。
    • CHART_FLOAT_RIGHT — 相对于虚拟屏幕的未固定的图表窗口的右坐标。
    • CHART_FLOAT_BOTTOM — 相对于虚拟屏幕的未固定的图表窗口的底部坐标。

    添加以下函数到ENUM_TERMINAL_INFO_INTEGER枚举:

    • TERMINAL_SCREEN_LEFT — 虚拟屏幕的左坐标。虚拟屏幕是覆盖所有监视器的长方形。如果系统从右至左有两个监视器,那么虚拟屏幕的左坐标可以在两个监视器的边界上。
    • TERMINAL_SCREEN_TOP — 虚拟屏幕的顶部坐标。
    • TERMINAL_SCREEN_WIDTH — 程序端宽度。
    • TERMINAL_SCREEN_HEIGHT — 程序端高度。
    • TERMINAL_LEFT — 相对于虚拟屏幕的程序端的左坐标。
    • TERMINAL_TOP — 相对于虚拟屏幕的程序端的顶部坐标。
    • TERMINAL_RIGHT — 相对于虚拟屏幕的程序端的右坐标。
    • TERMINAL_BOTTOM — 相对于虚拟屏幕的程序端的底部坐标。

  7. 将volume_real字段添加到MqlTick和MqlBookInfo结构。其设计目的在于提高交易量准确性。volume_real值的优先级要高于'volume'。如果该值已指定,那么服务器将会优先使用。

    struct MqlTick
      {
       datetime         time;          // 最后价格更新时间
       double           bid;           // 当前卖价
       double           ask;           // 当前买价
       double           last;          // 最后一笔交易的当前价格
       ulong            volume;        // 当前最后价格的交易量
       long             time_msc;      // 以毫秒计算的最后价格更新时间
       uint             flags;         // 报价标识
       double           volume_real;   // 准确性更高的当前最后价格的交易量
      };

    struct MqlBookInfo
      {
       ENUM_BOOK_TYPE   type;            //ENUM_BOOK_TYPE枚举的订单类型
       double           price;           // 价格
       long             volume;          // 交易量
       double           volume_real;     //准确度更高的交易量
      };

  8. 添加新属性到ENUM_SYMBOL_INFO_DOUBLE枚举:

    • SYMBOL_VOLUME_REAL — 最后已执行成交的交易量;
    • SYMBOL_VOLUMEHIGH_REAL — 当日已执行成交的最高交易量;
    • SYMBOL_VOLUMELOW_REAL — 当日已执行成交的最低交易量。

    使用SymbolInfoDouble函数来获得这些属性。

  9. 添加MQL_FORWARD属性到ENUM_MQL_INFO_INTEGER枚举 — 前测模式标识。
  10. 为结构添加了( integer_value )属性包。它可以使您设置结构中字段排列的对齐方式,这是在使用DLL时要求的。1、2 、4、8和16可用于integer_value。
    如果属性没有定义,则默认为1字节对齐方式——pack(1).

    使用示例:
    //+------------------------------------------------------------------+
    //| 默认包装                             |
    //+------------------------------------------------------------------+
    struct A
      {
       char              a;
       int               b;
      };
    //+------------------------------------------------------------------+
    //| 指定包装                             |
    //+------------------------------------------------------------------+
    struct B pack(4)
      {
       char              a;
       int               b;
      };
    //+------------------------------------------------------------------+
    //| 脚本程序起始函数                         |
    //+------------------------------------------------------------------+
    void OnStart()
      {
       Print("sizeof(A)=",sizeof(A));
       Print("sizeof(B)=",sizeof(B));
      }
    //+------------------------------------------------------------------+
    结论:
    sizeof(A)=5
    sizeof(B)=8
    MSDN中了解关于结构中对齐方式的更多信息。

  11. 降低转换枚举的需求。在隐式转换的情况下,编译器会自动替换正确的枚举值并显示警告。

    以下代码:
    enum Main
      {
       PRICE_CLOSE_,
       PRICE_OPEN_
      };
    
    input Main Inp=PRICE_CLOSE;
    //+------------------------------------------------------------------+
    //| 起始函数                             |
    //+------------------------------------------------------------------+
    void OnStart()
      {
      }
    编译器显示警告:
    从'enum ENUM_APPLIED_PRICE'隐式转换到'enum Main'
    'Main::PRICE_OPEN_'将替换'ENUM_APPLIED_PRICE::PRICE_CLOSE'并被使用
    早期,在该情况下生成以下错误:
    'PRICE_CLOSE' - 不能转换枚举
    如果在函数参数中错误地使用枚举,编译器将仍显示该错误。

  12. 修正编译模板函数。现在,当使用重载模板函数时,只重载必要的函数,而不是所有现有函数都被重载。
    class X {  };
    
    void f(int)  {  }
      
    template<typename T>
    void a(T*) { new T(2); }  // 以前,编译器在这里生成错误
      
    template<typename T>
    void a()  { f(0); }
      
      
    void OnInit()  { a<X>(); }  

  13. 通过CopyTicks* 函数优化了一些访问报价历史的情况。
  14. 添加了新TesterStop函数,可以使您提前完成测试/优化过程。当调用该函数时,整个交易统计信息和OnTester结果都会像完成常规测试/优化一样被传递到客户端。
  15. 为自定义指标添加新属性 #property tester_everytick_calculate。它用于策略测试,允许在每次报价时强制计算指标。

Tester

  1. 现在,对于非可视化测试/优化,使用的所有指标(标准指标和自定义指标)只在数据请求期间计算。包含EventChartCustom函数调用和应用OnTimer处理程序的指标排除在外。在此之前,在每次报价进入时,所有指标在策略测试中都无条件计算。这项新功能显著增加了测试和优化的速度。

    若要在每次报价时启用强制指标计算,请为该程序添加#property tester_everytick_calculate属性。
    通过之前版本的编译器编译的指标将按照之前的规则计算 —— 在每次报价时计算。

  2. 修正当测试/优化和生成相关报告时计算入金货币的准确性。
  3. 优化并加速策略测试操作。
  4. 修正多个测试和优化的错误。

MetaEditor

  1. 修正搜索整个单词。现在,搜索时,下划线被记为常规字符,而不是单词分隔符。
  2. 更新文档。

更新将通过实时更新系统提供。

6 七月 2018
MetaTrader 5平台build 1880:计算合成交易品种的完整历史

程序端

  1. 程序端:为整个可用的数据深度添加了合成交易品种价格历史的计算。

    平台根据公式中使用的工具的一分钟柱来计算一分钟柱的历史记录。以前,只能计算最近两个月的历史记录。根据一个明确的请求可以创建更深入的历史(当将图表滚动到左侧或调用Copy函数时)。现在,可以无条件使用所有可用数据来计算历史。




    在合成公式中使用的每一个交易品种都可以有不同深度的价格历史。合成历史计算是对最短的可用周期来执行。例如,公式使用三个交易品种:

    • EURUSD 历史最早可以追溯回2009.01.01
    • USDJPY历史最早可以追溯回2012.06.01
    • EURJPY历史最早可以追溯回2014.06.01

    这种情况下,合成交易品种历史的计算周期将从2014.06.01到现在。从这个日期开始将额外排除100分钟,来确保计算的完整性(如果有任何分钟柱不可用在历史中,那么计算中会使用前一分钟柱)。

    如果所用交易品种的深度历史可以使用,那么合成交易品种历史计算可能需要相当长的时间。为了确保合成交易品种图表即时查看,则首先计算最近两个月的历史(类似于之前版本的计算)。然后再开始计算较早期的历史。

MQL5

  1. ACCOUNT_CURRENCY_DIGITS新属性 — 在账户入金货币中的小数位数。使用AccountInfoInteger函数来获得属性。您可以在自己计算利润的时候使用这个属性,使所获得的值标准化。
  2. 修正周时间周期操作期间执行Copy函数i-函数的延迟。
  3. 修正WebRequest函数的操作。

Tester

  1. 添加了下载缓存文件的优化结果之后执行单独EA交易测试的功能。
  2. 新版本提供了通过本地代理加快价格历史初步下载的功能。

文档已更新。

26 六月 2018
MetaTrader 5 build 1870:通过ISIN在市场报价中添加交易品种

程序端

  1. 在市场报价窗口中添加了通过ISIN(国际证券识别码)搜索交易品种。现在,您可以使用三种方式搜索并添加交易品种:名称、描述和ISIN。



  2. 修正更改交易账户密码时用户界面反应迟缓的问题。
  3. 修正由客户端导致的偶尔CPU负载增加的问题。

MQL5

  1. 修正在WebRequest函数中自定义HTTP标题的传递。
  2. 修正在开始和结束日期范围相同的情况下,Bars函数的行为。现在,如果有一个柱形图,则函数返回1。在早期版本中,函数无条件返回0。

Tester

  1. 修正在前测优化之后开始在可视模式下单点测试
  2. 修正排序优化结果。现在,排序过程会考虑到错误输入参数(INIT_INCORRECT_PARAMETERS)和没有利润因子的传递。
  3. 修正在改变优化准则后,对遗传优化图形进行重新计算。

文档已更新。

15 六月 2018
MetaTrader 5平台build 1860:改进MQL5柱形图操作和策略测试功能

程序端

  1. 重新设计了开户对话框。现在,您可以从列表中选择一个交易商,然后选择想要的账户类型。这一更新使交易商列表更加集中,因为现在它只显示公司名,而不会显示所有可用的服务器。

    公司logo也在列表中显示,使搜索更加轻松,更有效率。如果想要的交易商没有显示在列表中,请在搜索框中输入公司名或服务器地址,然后点击“查找交易商”。




    在对话框中还添加了账户类型的描述,帮助初级投资者选择正确的账户。此外,为了与一般数据保护条例(GDPR)保持一致,更新后的对话框可能包含交易商协议和数据保护政策的链接:




    明显提高了开设真实账户的可能性。之前只存在于移动端的上传ID和地址确认文档的功能,现在也可以在桌面版中使用了。现在,MiFID监管的交易商可以要求所需的任何客户身份识别数据,包括关于就业、收入、交易经验等信息。新功能将帮助交易者更快更容易地开设真实账户,而无需不必要的繁琐程序。




  2. 交易历史现在显示了止损值和止盈值。根据发起这些交易的订单的止损和止盈来设置进入和逆转交易的止损值和止盈值。平仓时对应持仓的止损值和止盈值被用于退出交易。后者可以保存和显示平仓时持仓的止损和止盈信息。这个信息并没有存储在早期版本中,因为平仓之后持仓会消失,而程序端的持仓历史则根据交易产生。




  3. 持仓历史现在显示了止损值和止盈值。打开和关闭相应持仓的交易的止损值和止盈值是为这种持仓指定的。




  4. 现在,图表上显示挂单的当前交易量,而不是最初请求的交易量。




  5. 更新后的程序端优化并快速渲染了扩展模式下的市场深度特性,并启用了点差显示。
  6. 对交易请求执行结果进行了优化。这种优化在某些情况下可以实现更快处理。
  7. 修正追踪止损操作中的错误,该错误偶尔可能导致对同一持仓发送多个止损更改的请求。
  8. 修正最小和最大交易量的设置,以及自定义交易品种设置中的交易量步骤。
  9. 修正了在将模板应用到交易品种图表时,忽略“修正比例”选项可能导致的错误。
  10. 修正了报价历史的偶尔错误积累。

MQL5

  1. 由于在编译过程中实行的额外的源代码优化,MQL5应用程序的速度也得到了大幅度提升。在新版MetaEditor重新编译您的程序,使其运行得更快。
    遗憾的是,由于这个额外的优化功能,新程序将无法与以前的程序端版本兼容。使用MetaEditor 1860版本编译的程序,之后无法在低于1860版本的程序端中启用。使用早期的MetaEditor版本编译的程序则可以在新版程序端中运行。

  2. 新函数:iTime、iOpen、iHigh、iLow、iClose、iVolume、iBars、iBarShift、iLowest、iHighest、iRealVolume、iTickVolume、iSpread等。这些函数类似于MQL4中使用的函数。这些函数提供了更轻松地将交易应用程序代码传输到第五代交易平台。

    在此之前,通过这些函数执行的大部分任务都可以使用Copy*函数实行。但是,用户不得不执行他们自己的函数以便在图表上找到最高/最低值,和根据他们的时间搜索柱形图。现在,这些任何可以使用iHighest、iLowest和iBarShift函数来轻松执行。

    iTime
    返回对应的图表上柱形图的开盘时间(通过'shift'参数表示)。
    datetime  iTime(
       string       symbol,    //交易品种
       ENUM_TIMEFRAMES  timeframe,  // 周期
       int         shift     //转移
       );

    iOpen
    返回对应的图表上柱形图的开盘价(通过'shift'参数表示)。
    double  iOpen(
       string       symbol,    // 交易品种
       ENUM_TIMEFRAMES  timeframe,  // 周期
       int         shift     // 转移
       );

    iHigh
    返回对应的图表上柱形图的最高价(通过'shift'参数表示)。
    double  iHigh(
       string       symbol,    // 交易品种
       ENUM_TIMEFRAMES  timeframe,   // 周期
       int         shift     // 转移
       );

    iLow
    返回对应的图表上柱形图的最低价(通过'shift'参数表示)。
    double  iLow(
       string       symbol,    // 交易品种
       ENUM_TIMEFRAMES  timeframe,   // 周期
       int         shift     // 转移
       );

    iClose
    返回对应的图表上柱形图的收盘价(通过'shift'参数表示)。
    double  iClose(
       string       symbol,    // 交易品种
       ENUM_TIMEFRAMES  timeframe,   // 周期
       int         shift     // 转移
       );

    iVolume
    返回对应的图表上柱形图的报价量(通过'shift'参数表示)。
    long  iVolume(
       string       symbol,     // 交易品种
       ENUM_TIMEFRAMES  timeframe,   // 周期
       int         shift      // 转移
       );

    iBars
    返回在历史记录中可用的对应交易品种和周期的柱形图数量。
    int  iBars(
       string       symbol,     // 交易品种
       ENUM_TIMEFRAMES  timeframe    // 周期
       );

    iBarShift
    根据时间搜索柱形图。这个函数返回与指定时间对应的柱形图指数。
    int  iBarShift(
       string       symbol,     // 交易品种
       ENUM_TIMEFRAMES  timeframe,   // 周期
       datetime      time,      // 时间
       bool        exact=false   // 模式
       );

    iLowest
    返回在对应图表上找到的最小值的指数(相对于当前柱形图的转移)。
    int  iLowest(
       string       symbol,     // 交易品种
       ENUM_TIMEFRAMES  timeframe,   // 周期
       int         type,      // 时间序列标识符
       int         count,     // 元素数量
       int         start      // 指数
      );

    iHighest
    返回在对应图表上找到的最大值的指数(相对于当前柱形图的转移)。
    int  iHighest(
       string       symbol,     // 交易品种
       ENUM_TIMEFRAMES  timeframe,   // 周期
       int         type,      // 时间序列标识符
       int         count,     // 元素数量
       int         start      // 指数
      );

    iRealVolume
    返回对应的图表上柱形图的真实交易量(通过'shift'参数表示)。
    long  iRealVolume(
       string       symbol,     // 交易品种
       ENUM_TIMEFRAMES  timeframe,   // 周期
       int         shift      // 转移
       );

    iTickVolume
    返回对应的图表上柱形图的报价量(通过'shift'参数表示)。
    long  iTickVolume(
       string       symbol,     // 交易品种
       ENUM_TIMEFRAMES  timeframe,   // 周期
       int         shift      // 转移
       );

    iSpread
    返回对应的图表上柱形图的点差值(通过'shift'参数表示)。
    long  iSpread(
       string       symbol,     // 交易品种
       ENUM_TIMEFRAMES  timeframe,    // 周期
       int        shift      // 转移
       );


  3. 添加了新的TesterHideIndicators函数。该函数设置了EA交易中使用的指标的显示/隐藏模式。这个函数仅用于在测试期间管理已用指标的可见性。如果您需要隐藏已创建的指标,请设置为true。否则,使用false。
    void  TesterHideIndicators(
       bool      hide         //标识
       );
  4. 添加了在图表上单击交易价位时生成CHARTEVENT_CLICK事件。
  5. 修正和优化CopyTicks函数的操作。
  6. 修正SYMBOL_PROP_LIQUIDITY_RATE属性,SymbolInfoDouble函数返回的值。
  7. 复制带有叠加内存的字符串数组。
  8. 修正在FileReadArray数组中分配字符串数组。
  9. 修正MQL5标准程序库中的错误。

Tester

  1. 已经更新用于处理优化缓存的系统。这个缓存存储了关于以前计算的优化传递的数据。策略测试存储了暂停之后恢复优化和避免重新计算已经计算的测试传递的数据。

    优化缓存存储格式的更改
    在早期版本中,优化缓存存储为XML文件。包含指定测试设置的所有EA交易优化传递都被添加到这个文件中。因此,相同的文件也存储了不同输入参数的优化结果。

    现在,优化缓存为每组优化参数存储为单独的二进制文件。由于使用了新格式及更小的文件大小,优化缓存的策略测试操作变得更快。当您恢复暂停的优化传递时,加速情况会更加明显。

    查看早期优化的结果
    现在,早期优化的结果可以在策略测试中直接查看,所以不再需要使用第三方软件来分析巨大的XML文件。打开“优化结果”选项卡,选择一个EA交易和带有优化缓存的文件:



    列表中包含了磁盘上现有的可供被选择的EA使用的所有优化缓存文件。每个文件都显示了优化日期、测试设置(交易品种、时间周期、间隔)和输入参数。您还可以通过获得结果的交易服务器过滤优化结果。

    动态重新计算优化准则
    优化准则是一个特定的变量参数,其值决定了输入测试组的质量。优化准则的值越高,所考虑的给定参数集就越好。

    在此之前,优化期间只计算在优化开始之前选择的一个准则。现在,您可以在查看结果时动态改变优化准则,并且策略测试将自动重新计算所有值。




    手动使用优化缓存
    在早期版本中,优化缓存存储为需要使用第三方软件打开和分析的XML文件。现在,它存储在封闭的二进制文件中。若要获得XML格式的数据,请使用“优化结果”选项卡的快捷菜单将其导出。

  2. 添加了手动设置入金货币和测试与优化杠杆的可能性。在早期版本中,货币是根据连接的账户进行设置的。因此,必须切换到其他账户才能改变这个货币。杠杆大小只能从预定义列表中选定,而现在则可以指定任何值。

    请注意,将利润和预付款转换为指定入金货币的汇率必须在账户上可用,以确保适当的测试。




  3. 移除在测试代理中禁止使用OpenCL的禁令。早些时候,只有在对本地代理进行测试时才允许使用OpenCL设备。现在,当在本地网络和MQL5云网络工作时,代理可以使用所有可用的OpenCL设备(例如处理器、视频卡)。

MetaEditor

  1. 优化和加速MQL5存储
  2. 修正在MQH文件暂停之后修复调试过程。
  3. 修正editor中突出显示的源代码。
  4. 修正通过搜索结果的导航。
  5. 修正大量文本替换功能。在某些情况下,只有第一次出现的情况被替换,而不是全部情况。

文档已更新。

18 一月 2018
MetaTrader 5平台Build 1755

程序端

  1. 修正导致程序端和MetaEditor阻止Windows关机和重新启动的错误。
  2. 修正应用模板时的图表切换。

MQL5

  1. 修正在某些情况下减慢编译速度的错误。

修正崩溃日志中报告的错误。

12 一月 2018
MetaTrader 5平台Build 1745

MetaTrader 5 build 1745将是最后一个支持Microsoft Windows XP/2003/Vista操作系统的平台版本。

几个月以前,我们曾经发布未来将停止对旧版本操作系统的支持的公告。Windows 2003,Windows Vista,尤其是Microsoft Windows XP都已经是过时的操作系统。微软在三年前就已经停止对Windows XP的支持,因为由于技术上的限制,在这个操作系统上可能无法实现硬件的潜在性能。

MetaTrader 5 build 1745和之前的版本将可以继续在以上操作系统上运行,但是却不能再接收任何更新。此外,安装程序也将无法在这些操作系统上运行。

现在运行MetaTrader 5所需的最低操作系统版本为Windows 7。然而,我们仍强烈建议您使用64位版本的Windows 10。

程序端

  1. /auto键已经添加到安装包,可以在自动模式下安装程序而无需用户的额外操作。当通过这个键启动安装包时,安装设置不会显示给用户,程序端将安装在标准开始菜单的标准路径下,以程序名命名的文件夹中。这种启动示例为:
    C:\mt5setup.exe /auto
  2. 修正操作系统用户没有适当权限时的安装包操作。
  3. 修正在程序端不执行任何操作时(没有打开的图表,用户不执行任何操作),对CPU资源的过度消耗。
  4. 新版本还具有自动压缩文件系统级别*.log文件的特点。这项新功能可以减少日志对磁盘空间的占用率。

Tester

  1. 增加了在单个测试运行期间的缓存量。这可以为64位操作系统提供更快的测试。
  2. 通过MQL5云网络修正了EA交易的优化。这种优化可能体现在从MetaTrader市场上购买的产品中。
  3. 修正在“每个报价”测试模式下生成的柱的点差计算。
  4. 修正策略测试下OpenCL设备的选择。可见的测试器现在可以访问所有可用的OpenCL设备。
  5. 新版本还具有自动压缩文件系统级别*.log文件的特点。这项新功能可以减少日志对磁盘空间的占用率。
  6. MQL5:使用CustomRatesDelete类函数,修正自定义交易品种柱的删除。

修正崩溃日志中报告的错误。
文档已更新。
20 十二月 2017
MetaTrader 5 Build 1730: MetaEditor项目和合成金融工具

停止对旧版程序端的支持

新版平台发布后,将停止对旧版本的桌面版和移动版的支持:

  • 客户端:2012年11月23日发布的730之前的版本
  • iPhone移动版:2015年11月11日发布的1171之前的版本
  • Android移动版:2016年8月5日发布的1334之前的版本
不再提供支持的程序端版本将不能继续连接新的服务器版本。我们强烈建议您提前更新您的程序端。

MQL5 存储操作协议发生变更

为了支持新的共享项目,我们更新了MQL5存储的操作协议。因此,平台更新后,您将需要检查核对来自存储的所有数据。更新过程中,MQL5存储中的所有数据都不会丢失或受到影响。

更新到新版平台之前,我们建议您执行提交操作,将所有本地更改发送到MQL5存储。

程序端

  1. 现在,交易平台允许创建合成金融工具,即基于一个或多个现有工具的交易品种。用户可以设置计算报价的公式,之后平台将会实时生成合成工具的报价并创建分钟历史记录。

    如何工作

    • 您创建合成工具并设置价格计算公式。
    • 如果公式中使用的工具至少有一个的价格发生变化,那么平台会以每秒10次的频率计算报价。
    • 平台还可以根据公式中使用的工具一分钟柱来计算一分钟柱的历史记录(最近两个月)。根据生成的合成工具报价,所有新柱都将实时绘制(当前柱和后面的柱)。

    例如,您可以创建一个工具显示美元指数(USDX)。它使用下面的公式:

    50.14348112 * pow(ask(EURUSD),-0.576) * pow(USDJPY,0.136) * pow(ask(GBPUSD),-0.119) * pow(USDCAD,0.091) * pow(USDSEK,0.042) * pow(USDCHF,0.036)

    注意:USDEUR和USDGBP货币对在源美元指数公式中使用。因为平台中仅可以使用反向货币对,因此合成交易品种公式中使用的是负能量和买价,而不是卖价。

    平台将根据您交易商提供的其他六个交易品种报价来计算新工具的实时价格。价格变化将在市场报价窗口和图表上显示:




    若要创建一个新的自定义交易品种,请打开其规格窗口并指定公式:




    出于方便考虑,公式编辑器在键入交易品种和函数名称时显示了可能的选项列表。

    当合成工具添加到市场报价时,开始计算这个工具的报价和1分钟柱。同时,所有需要计算合成价格的交易品种都会自动添加到市场报价。有关开始计算的条目也将被添加到平台的日志:合成交易品种USDX:处理已开始。
    • 合成工具从市场报价移除后,计算停止。
    • 当前用于计算合成交易品种价格的交易品种不可以在市场报价中隐藏。

    实时计算报价
    每100毫秒检查一次计算中使用的交易品种价格(即每秒10次)。如果至少一次发生变化,那么就会计算合成交易品种的价格并且生成新报价。计算在三个线程中并行执行:卖价,买价和最后价。例如,如果计算公式是EURUSD*GBPUSD,那么合成交易品种的价格将按照以下规则计算:

    • Bid = bid(EURUSD)*bid(GBPUSD)
    • Ask = ask(EURUSD)*ask(GBPUSD)
    • Last = last(EURUSD)*last(GBPUSD)

    并分别针对每个价格检查更改的有效性。例如,如果源工具只更改了卖价,那么也只会计算合成工具相应的价格。

    创建分钟柱的历史记录
    除了收集实时报价之外,这个平台还会创建合成工具的1分钟历史记录。使交易者能够查看与正常图表类似的合成交易品种图表,并使用对象和指标进行技术分析。

    当交易者向市场报价添加合成工具时,平台将检查计算的分钟历史记录是否存在。如果不存在,那么将会创建最近60天的历史记录,其中包含50, 000个柱形图。如果平台设置中图表允许最多柱参数指定的值较低,那么将会应用相应的限制。

    如果这个周期内一些柱形图创建的时间较早,那么该平台将会额外生成新柱形图。如果用户想要查看图表上较早时期的记录(向后滚动或从MQL5程序访问),更进一步的历史记录就会被创建。

    合成工具的一分钟柱历史记录还可以根据公式中使用工具的一分钟柱(不是报价)进行计算。例如,若要计算合成交易品种1分钟柱的开盘价,平台会使用其公式中使用的交易品种的开盘价。最高价,最低价和收盘价也是以相同的方式进行计算。

    如果所需的柱形图不适用于任何工具,那么平台将使用之前柱形图的收盘价。例如,EURUSD,USDJPY和GBPUSD这三个工具被使用。如果计算12:00对应的柱形图时USDJPY所需的柱形图不能使用,那么下面的价格将会用于计算:

    • Open: EURUSD Open 12:00, USDJPY Close 11:59, GBPUSD Open 12:00
    • High: EURUSD High 12:00, USDJPY Close 11:59, GBPUSD High 12:00
    • Low: EURUSD Low 12:00, USDJPY Close 11:59, GBPUSD Low 12:00
    • Close: EURUSD Close 12:00, USDJPY Close 11:59, GBPUSD Close 12:00

    如果分钟柱不能用于公式中使用的所有工具,那么合成工具对应的分钟柱也不会被计算。

    绘制新的分钟柱形图
    所有合成工具的新柱都将根据生成的报价进行创建(当前柱和后面的柱)。用于创建柱形图的价格取决于规格中的“图表模式”参数:




    交易品种公式中可以使用哪些操作
    价格数据和交易商提供的现有交易品种的一些属性可以用于计算合成价格。指定下面信息:

    • 交易品种名称 — 取决于要被计算的合成价格,要使用的指定工具的卖价,买价或最后价。例如,如果工具指定EURUSD*GBPUSD,那么卖价计算为bid(EURUSD)*bid(GBPUSD),买价= ask(EURUSD)*ask(GBPUSD)。
    • 卖价(交易品种名称)— 指定交易品种的卖价将被强制用于计算合成工具的卖价。这个选项与之前选项类似(在之前没有指定价格类型)。
    • 买价(交易品种名称)— 指定交易品种的买价将被用于计算合成工具的买价。指定工具的卖价将被用于计算买价。指定交易品种的最后价将被用于计算最后价。如果ask(EURUSD)*GBPUSD被指定,那么下面计算将被使用:
      • Вid = ask(EURUSD)*bid(GBPUSD)
      • Ask = bid(EURUSD)*ask(GBPUSD)
      • Last = last(EURUSD)*last(GBPUSD)
    • 最后价(交易品种名称) — 指定交易品种的最后价将被用于合成工具所有价格的计算(卖价,买价和最后价)。如果last(EURUSD)*GBPUSD被指定,那么下面计算将被使用:
      • Вid = last(EURUSD)*bid(GBPUSD)
      • Ask = last(EURUSD)*ask(GBPUSD)
      • Last = last(EURUSD)*last(GBPUSD)
    • 交易量(交易品种名称) — 公式中将要使用的指定工具的报价交易量。请确保交易量信息与交易商提供的该交易品种相符。
    • 点差(交易品种名称)— 计算时将会使用的指定工具的最小价格变化。
    • 小数位(交易品种名称) — 公式中将要使用的指定交易品种价格的小数位数。

    如果交易品种名称复杂(包含连字符,点等等),请一定要以引号标记。例如:“RTS-6.17”。
    下面的算术运算可以在公式中使用:加法 (+),减法 (-),乘法(*),除法(/) 和除法余数 (%)。例如,EURUSD+GBPUSD意味着这个价格的计算是EURUSD 和GBPUSD价格总和。您也可以使用减号来改变符号,例如:-10*EURUSD。

    请注意数学运算的优先规则:

    • 首先执行的是乘法运算,除法运算和余数运算,然后执行加法运算和减法运算。
    • 运算顺序为自左向右。如果这个公式使用了多个且优先级相同的运算符号(例如,乘法和除法),那么将先从左边开始执行运算。
    • 您可以使用括号来改变运算的优先规则。括号内的运算是数学运算的最高级别。同样也是按照自左向右的顺序来执行:左侧括号内的运算优先执行。

    您可以在公式中使用常数:

    • 数字类型(整型和浮点型)。例如:EURUSD*2+GBPUSD*0.7。
    • 交易品种属性 _Digits 和 _Point。它们在公式中加入了来自规格的自定义交易品种的适当属性。_Digits意味着工具价格的小数位数;_Point 意味着交易品种价格的最小变化。

    您还可以在公式中使用除了MathSrand,MathRand和MathIsValidNumber以外,MQL5中支持的所有其他数学函数:所有函数仅使用短名称,例如fabs(),acos(),asin()等等。

  2. 已经实施允许实时添加自定义工具报价的新选项。现在,开发为指定自定义交易品种提供报价的MQL5 EA交易已经成为可能。为此可以使用CustomTicksAdd函数。
    int  CustomTicksAdd(
       const string           symbol,       // 交易品种名称
       const MqlTick&         ticks[]       // 可以用于自定义交易品种的报价数据数组
       );
    CustomTicksAdd函数允许提供报价,如同从交易商服务器接收这些报价。数据被发送至市场报价窗口,而不是直接写入报价数据库。然后,程序端将报价从市场报价窗口保存至数据库。如果在一次调用中传递了大量的数据,那么函数行为就会发生变化来节省资源。如果传送的报价数超过256个,那么数据会被分成两个部分。较大的部分直接记录到报价数据库(类似CustomTicksReplace)。第二部分由最近的128个报价组成,被发送到市场报价,程序端从这里将报价保存到数据库。

  3. 市场报价窗口现在还提供了最高价和最低价。这两个价格列默认是隐藏状态。可以通过快捷菜单来启用显示这两列:




    如果交易品种图表使用卖价来构建(依据规格设置),则会显示这个交易品种的最高卖价和最低卖价。如果交易品种图表使用最后价来构建,则会显示这个交易品种的最高最后价和最低最后价。

    如果市场报价至少包含一个基于最后价绘制图表的交易品种,那么除了最高价/最低价以外,最后价的列也会自动启用。

  4. 现在可以编辑自定义金融工具的报价历史记录。在市场报价快捷菜单中点击“交易品种”,选择自定义交易品种并在报价标签请求所需的数据间隔。

    • 双击来改变值。
    • 使用快捷菜单来添加或删除条目。
    • 如果您需要立刻删除多个柱形图/报价,请用鼠标选择并同时按住Shift或Ctrl+Shift。




    为了方便起见,更改的条目会按照以下规则突出显示:

    • 绿背景色表示修改后的条目
    • 灰背景色表示已删除的条目
    • 黄背景色表示已添加的条目

    若要保存更改,请在窗口底部点击“应用更改”。

  5. 在导航树中添加初步账户的显示。
    交易者可以向交易商发送请求,从桌面程序端直接开立一个真实账户。用户需要填写一份简单的请求表格和联系方式。在此之后,将为交易者创建一个特定的初步账户。然后,交易商联系交易者确定正式关系并将真实账户从初步账户转出。




  6. 在报价窗口增加毫秒时间显示。




  7. 在新账户打开对话框中扫描可用服务器的速度更快。
  8. 修正了趋势线图形对象的显示,启用了左射线和右射线的选项。
  9. 优化操作大量内部电子邮件(数十万邮件)。
  10. 优化大量交易工具的程序端操作(50,000或更多)。
  11. 在编辑历史记录之后,对自定义金融工具的报价历史添加了优化,并进行扩展。

MetaEditor

  1. 功能全面的项目现在已可以在MetaEditor中使用。程序开发过程已变得更加方便。

    现在主要的MQL5程序文件不会呈现为项目文件。项目是独立的"MQPROJ"文件,它可以存储程序设置,编译所有已用文件的参数和信息。主要的项目设置可以从独立的对话框访问,所以,现在无需通过#property在源代码中指定项目设置。

    为了便于进行项目工作,还提供了独立的导航标签。全部文件,例如包含文件,资源文件,标题文件和其他文件都被安排到这个标签类别中。所有文件都会自动添加到项目导航中。例如,如果您包括了一个新的MQH文件,那么它将自动出现在导航的“相关性”部分。

    在更新的MQL5存储在线库中也实现了对新项目的支持。现在,通过与MQL5.community其他成员的协作,开发大型项目变得更加方便。

    为组项目提供了新的共享项目部分。在这部分创建的项目会即时发送到存储中:您可以授予其他用户的权限并立即开始协作。




    当您在共享项目中编译一个项目时,根据程序类型,可执行文件EX5会自动复制到本地专家,指标或脚本目录。您可以轻松地在图表上启动程序,而无需手动复制文件。


    MQL5存储操作中的新功能

    为了实现对新共享项目的支持,我们已经更改了MQL5存储的操作协议。因此,平台更新后,您将需要检查核对来自存储的所有数据。更新过程中,MQL5存储中的所有数据都不会丢失或受到影响。

    更新到新版平台之前,我们建议您执行提交操作,将所有本地更改发送到MQL5存储。

    “检查存储”命令现在已经不可用。而是使用“激活MQL5存储”和“更新存储文件”命令来接收数据:

    • 如果在当前MetaEditor实例中您没有使用MQL5存储,那么请在导航窗口的快捷菜单中点击“激活MQL5存储”。您的存储中所有可用的类别和文件将被上传至您的本地电脑。
    • 如果您已经使用存储服务,请在某个项目或导航窗口中MQL5元素根目录的快捷菜单中单击“更新存储文件”,以便接收存储中的数据。

    新项目:创建和操作细节的示例

    新项目版块已被添加到MetaEditor。项目是一个mqproj文件,可以存储普通程序属性和有关所有已用文件的信息。现在,程序属性可以通过独立的MetaEditor对话框方便地管理,不必在源代码中手动更改属性(使用#property指令)。

    如果您有可用代码,您可以通过使用“来自源代码的新项目”命令来轻松地测试新项目。




    在已选文件所在的目录中,将会创建一个具有相同名称和mqproj为扩展名的新项目文件。通过#property在源代码中指定的主要程序属性将被自动添加到项目,包括名称,版权,版本,链接到开发者网站和程序描述。

    项目文件中程序属性会被设置高于程序代码中指定属性的优先级。如果项目和源文件中都指定了属性,那么项目属性将被使用。




    编译MQL5程序的两个新选项已被添加到项目属性:

    • 启用额外优化:禁用优化的应用程序编译速度更快,但执行速度较慢。
    • 检查浮点分隔:检查禁用的应用程序速度稍快,因为在执行代码过程中,不检查除数为零的错误。

    若要使用项目服务,请使用导航窗口独立的项目标签。项目服务中使用的所有文件都以方便的形式展示在这个标签。当项目从源文件生成时,所有使用的包含文件(在主MQ5文件及其包含文件中通过#include目录指定)都会自动添加到相关性部分。

    当新的包含文件添加到源代码时,它也出现在项目导航中。已用的标题文件添加到标题版块;在项目中用作资源的图片,声音和其他MQL5程序也被添加到资源版块。带有源代码的MQ5文件显示在资源版块。在“设置和文件”版块,您可以添加其他文件,例如用于测试的set文件和图表模板。

    使用快捷菜单命令向项目添加现有文件或从项目中删除文件。删除文件时请注意,因为您不但可以从项目中移除文件(解除绑定)还可以从硬盘中彻底删除文件:




    创建一个新项目犹如创建普通MQL5程序一样简单。单击“新项目”,选择新程序类型并指定MQL5向导中的属性(例如名称,事件处理程序)。

    若要获得可执行文件EX5,您可以打开这个项目并按下F7(编译命令)或打开程序的主MQ5文件并编译它。

    MQL5存储中的共享项目:操作细节

    共享项目是由一个单独的共享项目版块来管理。如果您还没有连接存储库,请在所需文件夹的快捷菜单执行“激活MQL5存储”命令。MetaEditor将检查您的存储库是否包含任何保存数据以及是否有任何共享项目可供您使用。所有可用的数据都将从存储库中恢复并上传到您的电脑(检验操作)。可用的组项目出现在共享项目版块。若要恢复项目,请在快捷菜单中执行“在存储库检查”。

    若要创建新组项目,请选择共享项目文件夹并点击“新项目”:




    然后完成标准的MQL5步骤:设置所需程序的类型,名称和属性。对于组项目,您应该使用清晰易懂的名称,以便其他参与者能够轻松地找到它们。项目名称中只可以使用没有空格的拉丁字符和数字。

    创建的对象会立刻添加到MQL5存储库中。项目中使用的标准程序库文件不会添加到存储库中,您可以手动添加它们。

    若要允许其他参与者使用项目,请打开项目属性。在这里,您可以通过指定MQL5.community登录名,以及为组工作设定公共参数,来向选定用户授予权限:

    • 私人项目
    • 免费加入项目
    • 通过请求项目加入




    当您编译一个组项目时,根据程序类型,可执行文件EX5会自动复制到本地专家,指标或脚本目录。它允许您在程序端立即运行程序而不必手动复制到适当的目录。


    MQL5存储中的公共项目:参与开发

    如上所述,MQL5存储中的每个组项目都有公共设置:项目可以是私人的,也可以是对其他人公开的。现在,您可以免费加入的所有项目都显示在单独的“公共项目”标签。

    每个人都可以找到心仪的项目并加入其开发过程。仅需单击加入,接收存储项目。




    每个加入的用户都获得了只读权限。联系项目作者,提交您的更改。若要了解他或她的登录名,请通过快捷菜单打开项目属性。

  2. 添加了能够轻松插入属性和资源到程序代码的能力。例如,您可以迅速地将包含文件加入代码。使用命令“插入—MQH 为 #incude”,并选择所需的包含文件。对所选文件正确路径的#include指令将被插入到程序代码。




    相同菜单允许以二进制或文本数组的形式添加到程序代码文件。另外,您还可以使用EA交易或指标转移图表模板:将您的模板插入到程序代码作为数组,然后使用FileSave函数将其保存到磁盘。然后,可以使用ChartApplyTemplate函数将模板从EA交易直接应用到所需的图表上。
    //+------------------------------------------------------------------+
    //| 脚本程序起始函数                          |
    //+------------------------------------------------------------------+
    void OnStart()
      {
    //--- 作为二进制数组的模板文件
       unsigned char my_template[]=
         {
          0xFF,0xFE,0x3C, ... ,0x00 // 本例中数据数组被缩短
         };
    //--- 保存和应用模板
       if(FileSave("my_template.tpl",my_template))
         {
          Print("Custom template saved in \\MQL5\\Files");
          if(ChartApplyTemplate(0,"\\Files\\my_template.tpl"))
             Print("Custom template applied to the current chart");
          else
             Print("Failed to apply custom template");
         }
       else
          Print("Failed to save custom template");
      }

  3. 添加了在ASCII,HEX和Base64格式之间转换字符串的选项。在源代码中选择一行并在编辑——转换菜单中单击所需的命令:




  4. 修正文件搜索不区分大小写。
  5. 修正计算类似x.y[0][1].z表达式时可能发生的调试错误。
  6. 使用前进和后退按键修正代码导航。

MQL5

  1. 添加了新的线上服务——MQL5云保护,用于为MQL5程序提供额外保护。这种保护类似于MetaTrader市场——最大的交易应用程序商店所使用的选项,另外,卖家提交的EX5产品文件也被编译为本地代码。

    现在,平台所有用户都可以使用这种类型的保护。若要保护您的文件,请在MetaEditor中执行以下命令:工具—MQL5云保护。MQL5云保护与市场中使用的机制的唯一不同点在于该文件与用户的电脑没有关联。通过MQL5云保护服务的保护,文件可以在任何电脑上运行,类似于普通的EX5文件。
    MQL5云保护是一种安全服务。额外保护只应用于已编译的文件。源代码没有传递到该服务。第一步,程序被编译到用户电脑上的EX5文件;然后,编译后的文件通过一个加密通道发送到服务,在该服务中,文件得到保护并返回给用户。



  2. 添加使用自定义金融工具的新函数。

    函数 行为
    CustomSymbolCreate 在指定组以指定名称创建一个自定义交易品种
    CustomSymbolDelete 删除指定名称的自定义交易品种
    CustomSymbolSetInteger 为自定义交易品种设置整型属性值
    CustomSymbolSetDouble 为自定义交易品种设置真实型属性值
    CustomSymbolSetString 为自定义交易品种设置字符串类型属性值
    CustomSymbolSetMarginRate 根据订单类型和方向为自定义交易品种设置预付款比例
    CustomSymbolSetSessionQuote 为指定交易品种和工作日设置指定报价期的起止时间
    CustomSymbolSetSessionTrade 为指定交易品种和工作日设置指定交易时期的起止时间
    CustomRatesDelete 在指定时间间隔内从自定义交易品种的价格历史记录中删除所有柱形图
    CustomRatesReplace 在指定时间间隔内用MqlRates类型数组的数据完全替换自定义交易品种的价格历史记录
    CustomRatesUpdate 将缺失的柱形图添加到自定义交易品种的历史记录并用MqlRates类型数组的数据替换现有的数据
    CustomTicksAdd 将MqlTick类型的数组数据添加到自定义交易品种的价格历史记录。自定义交易品种必须在市场报价窗口中选择。
    CustomTicksDelete 在指定时间间隔内从自定义交易品种的价格历史记录中删除所有报价
    CustomTicksReplace 在指定时间间隔内用MqlTick类型数组的数据完全替换自定义交易品种的价格历史记录

  3. 通用数据集合 添加到标准程序库。它们包含基于模板定义数据集合的类和接口。这种新型数据集合提供了更加方便的应用程序开发和高速的数据处理表现。

    程序库位于程序端工作目录的Include\Generic文件夹。

  4. 添加了对union数据类型模板的支持。
  5. SYMBOL_VISIBLE 交易工具属性已被添加。如果指定交易品种在市场报价中不可见,那么调用SymbolInfoInteger(交易品种,SYMBOL_VISIBLE)返回false。
  6. 添加新的CHARTEVENT_MOUSE_WHEEL属性。当鼠标滚轮被滚动或在图表上按下时调用该事件(如果图表CHART_EVENT_MOUSE_WHEEL=true)。
  7. 以下图表属性已被添加:

    • CHART_EVENT_MOUSE_WHEEL — 启用/禁用生成CHARTEVENT_MOUSE_WHEEL(在图表上滚动鼠标并点击事件)。可能值:0 和 1。
    • CHART_CROSSHAIR_TOOL — 启用/禁用单击中键将光标切换到十字光标的可能性。可能值:0 和 1。
    • CHART_CONTEXT_MENU — 启用/禁用右击显示图表快捷菜单。可能值:0 和 1。

  8. 现在,在计算指标窗口比例时不必考虑绘制DRAW_NONE 类型缓冲区。
  9. 在为图表设置CHART_SCALEFIX (固定比例)属性时添加CHARTEVENT_CHART_CHANGE事件生成。
  10. ArraySwap函数已被添加,允许快速交换动态数组的内容。
    bool  ArraySwap(
       void&  array1[],      // 第一数组
       void&  array2[]       // 第二数组
       );
    这个函数接受相同类型和相同维度的动态数组。对于多维数组,除了第一元素以外,所有维度中的元素数量都应该匹配。

  11. 新增新属性TERMINAL_RETRANSMISSION — 对于所有在指定计算机上运行应用程序和服务的TCP/IP协议 中的现有网络数据包的百分比(重新传输)。即使在最快且配置正确的网络中也可能发生数据包的丢失。这种情况下,在接收方与发送方之间没有确认数据包的交付。因此,丢失的数据包会重新发送。

    程序端并不会计算该值。而是每分钟从操作系统请求一次。并不表示特定程序端和交易服务器之间的连接质量,因为这个百分比是为整个网络活动而计算,包括系统和后台活动。

    TERMINAL_RETRANSMISSION属性添加到ENUM_TERMINAL_INFO_DOUBLE枚举,使用TerminalInfoDouble函数来获得它。
  12. 通过交易历史记录优化工作。

信号

  1. 修正了在强制关闭一个根据信号持仓的情况下的订单成交类型的指示。信号复制选项中提供了“账户低于XXX美元时止损”的选项:如果净值跌落了指定水平,交易信号复制将自动终止,所有持仓关闭。以前,如遇强制平仓的情况,平仓订单可能会设置一个不正确的成交类型。现在程序端会检查交易品种设置中允许的成交类型并指示适当的选项。

Tester

  1. 策略测试中HistoryOrderSelect函数的行为现在对应客户端中相同的函数。
  2. 策略测试中CopyTicksCopyTicksRange函数的行为现在对应客户端中相同的函数。
  3. 在视觉测试过程中优化显示图形对象。
  4. 修正显示交易所工具的测试结果(交易所风险管理模式)。现在,图表只能显示净值,而结余和入金负载无法显示。这种账户的交易状况是基于净值水平来进行评估。结余仅显示了账户上的金额而忽略了交易者的资产和负债。入金负债(预付款/净值)不显示,因为在交易所计算模式,预付款等于资产/负债的当前贴现值,它是随着净值的改变而改变。

  • 用户界面现已支持荷兰语。
  • 更新文档。
  • 23 八月 2017
    MetaTrader 5 iOS build 1649:支持查看金融工具市场统计信息

    新版本中可以查看交易所执行模式下进行交易的金融工具市场统计信息。打开市场报价(Market Watch)中任何交易品种的菜单,选择“统计”,来查看市场统计信息。


    此外,新版本中交易标签的持仓操作也更加便捷。现在,单击持仓或订单将会显示详细信息和可用操作,例如平仓,更改或增加持仓交易量,以及打开持仓交易品种的图表。

    2 八月 2017
    MetaTrader 5 Android build 1642:简化真实账户申请流程

    MetaTrader 5 Android版,现在能够轻松创建初始真实交易账户。从菜单选择“开立真实账户”并在服务器列表中找到您的交易商。您只需附加两份文件,包括您的身份证明文件和银行账户账单。然后您的请求将被转发至交易商,同时开立账户时您可能会被要求提供其他信息。


    21 七月 2017
    MetaTrader 5 Build 1640:创建和测试自定义交易品种

    程序端

    1. 现在可以在程序端创建自定义的金融品种。使用该新选项,您可以创建任何交易品种,配置其设置,导入您的价格数据到交易品种并查看其图表。

      创建自定义交易品种
      通过“市场报价”窗口的快捷菜单打开交易品种管理窗口并点击“创建自定义交易品种”:



      大量的交易品种参数可以被配置。完整的参数列表及其描述在文档中可以查询。您可以通过复制任何类似品种的参数并修改它们来配置您的自定义交易品种。在“复制自”字段选择现有的交易品种。
      自定义交易品种的名称不可与交易商提供的交易品种名称相同。如果您连接到存在同名交易品种的服务器,那么自定义交易品种将被删除。
      这里还提供了导入和导出参数的命令。您可以在您的程序端之间轻松地分享自定义交易品种或转移交易品种。设置会被导出到JSON文本文件。

      管理自定义交易品种
      所有交易品种都显示在独立的自定义组。如果您需要更改或删除一个交易品种,请使用列表的快捷菜单:




      导入价格历史
      您可以从任何文本文件以及MetaTrader 历史文件HST和HCC导入价格数据到您的自定义交易品种。选择一个交易品种并转到“柱形图”标签。


      在导入对话框,指定到文件的路径并设置所需的参数:

      • 分隔符 — 文本文件中的元素分隔符。
      • 跳过列和行 — 导入过程中将要跳过的列数(从左向右)和行数(从上到下)。
      • 迁移 — 时间迁移小时数。导入不同时区保存的数据时使用的选项。
      • 仅使用选定 — 仅导入在行查看区域突出显示的行。您可以按住 Ctrl 或 Shift 并用您的鼠标突出标记行。

      1分钟柱文件有以下格式:日期 时间 开盘价 最高价 最低价 收盘价 报价量 交易量 点差。例如;
      2016.06.27    00:01:00    1.10024    1.10136    1.10024    1.10070    18    54000000    44
      2016.06.27    00:02:00    1.10070    1.10165    1.10070    1.10165    32    55575000    46
      2016.06.27    00:03:00    1.10166    1.10166    1.10136    1.10163    13    13000000    46
      2016.06.27    00:04:00    1.10163    1.10204    1.10155    1.10160    23    51000000    41
      您可以使用任何现有品种的数据应用于您的自定义交易品种。导出数据(该选项已添加到之前的平台版本),必要情况下进行修改再将其导回。
      价格历史以一分钟柱的形式存储在MetaTrader 5中。其他所有时间周期都基于这些柱来创建。您也可以导入较高时间周期的数据,但这种情况下较低周期的图表将会出现差别。例如,如果您导入一小时数据,按小时显示的柱形图将会出现在M1图表上。
      自定义交易品种的价格数据保存在独立的自定义目录中(不在交易服务器数据存储的目录中):
      C:\Users\[windows account]\AppData\Roaming\MetaQuotes\Terminal\[instance id]\bases\Custom

      使用自定义交易品种
      自定义交易品种的用法类似于使用交易商提供的品种。自定义交易品种显示在市场报价窗口;您可以打开这种交易品种的图表并在这里使用指标和分析对象。自定义交易品种不可以进行交易。

      测试自定义交易品种的策略
      自定义交易品种可以在策略测试中测试自动交易和指标。以此来优化交易策略,甚至包括交易商目前尚未提供的金融品种。您只需要正确导入历史数据并配置自定义交易品种的属性。





      当计算预付款和利润时,策略测试会自动使用可用的交叉汇率。假设我们在外汇预付款计算类型创建AUDCAD.custom交易品种而我们账户的货币为美元。那么,测试器会根据外汇交易品种名称按照下面顺序搜索所需的交易品种:
      1.     首先,会搜索AUDUSD.custom(计算预付款)和USDCAD.custom(计算交易利润)格式的交易品种
      2.     如果其中一些交易品种不存在,那么会搜索第一个与所需货币对名称(AUDUSD和USDCAD分别进行)相对应的交易品种。例如,找到了AUDUSD.b 和 NZDUSD.b 交易品种。这意味着可以使用它们的汇率计算预付款和利润。

      其他预付款计算类型的工具(期货和 股票交易)则需要一种货币对把工具货币兑换成入金货币。假设我们创建了一个利润和预付款货币为GBP的自定义交易品种而入金货币是CHF。这种情况下,会依照以下顺序搜索测试交易品种:
      1. 检查是否存在GBPCHF (GBP vs CHF) 对应的交易品种。
      2. 如果这种交易品种不存在,那么会搜索第一个与GBPCHF名称相对应的交易品种,例如GBPCHF.b或GBPCHF.def。

      当通过自定义工具测试应用程序时,要确保交易账户包含全部所需的货币对。否则,测试期间将无法计算金融结果和预付款需求。

      在MetaTrader 5平台未来的版本中将会提供更多的可能性
      自定义交易品种的开发尚未完成,在接下来的平台版本中将会添加更多的功能。您将可以从EA交易直接导入历史记录到自定义交易品种,以及实时放送该交易品种的数据(添加报价)。

    2. 添加通过交易量过滤成交时间&交易量功能。

      少于指定交易量的实际交易量可以从成交时间&交易量表格中隐藏。如果使用这个过滤器,那么将只有大额交易才会显示在成交时间&交易量窗口。

      双击成交时间&交易量窗口的第一行,指定最小交易量手数,然后点击市场深度的任何其他区域。交易将被过滤,而当前过滤值将会出现在交易量列的标题。



      您还可以使用成交时间&交易量的快捷菜单指定最小交易量。

    3. 添加绑定市场深度和活动图表的选项。每次您切换到金融品种的图表时,在市场深度窗口都会自动启用相同品种。所以,您无需为每个新交易品种打开市场深度窗口。





    4. 修正程序端窗口最小化和最大化后的工具栏刷新。
    5. 修正交易单和持仓单重复情况下生成的持仓交易历史。

    MQL5

    1. 添加在价格历史分析MQL5程序的选项。该选项无需等候新报价就可以检查程序性能。

      当基于真实数据进行分析时,可以在程序端标准图表中启用程序。许多程序,尤其是指标,只有在收到新报价(OnTickOnCalculate)时才会执行计算。因此,若要评估程序表现,您必须等候实时新报价。如果您使用历史数据测试程序,您可以立即提供所需的负载。分析在策略测试中以可视化模式启动,您可以一次性接收许多新报价事件。



    2. 添加支持union。Union是一种特殊的数据类型,由几个共享相同内存区的变量组成。因此,union提供了以两种(或更多)不同的方式讲解相同位序列的能力。Union声明从'union'关键字开始。
      union LongDouble
      {
        long   long_value;
        double double_value;
      };
      与结构不同,不同的union成员属于同一个内存区。在该示例中,LongDouble函数的union是通过共享同一个内存区的long和double类型值来声明。请注意,由于long_value 和 double_value 变量重复(在内存中),所以union不可以同时存储long整型值和double真实型值(不同于结构)。 换句话说,MQL5程序随时都可以将union的数据处理为整型(long)或真实型(double)值。因此,union允许接收表示相同数据序列的两种(或更多种)选项。

      union声明期间,编译器会自动分配足够的内存区以便在变量union存储最大的类型(交易量)。同样的语法也用于访问关于结构的union元素,例如,点操作符
      union LongDouble
      {
        long   long_value;
        double double_value;
      };
      //+------------------------------------------------------------------+
      //| 脚本程序起始函数                                                        |
      //+------------------------------------------------------------------+
      void OnStart()
        {
      //---
         LongDouble lb;
      //--- 获得并显示无效 -nan(ind) 数字
         lb.double_value=MathArcsin(2.0);
         printf("1.  double=%f                integer=%I64X",lb.double_value,lb.long_value);
      //--- 最大的标准化数值 (DBL_MAX)
         lb.long_value=0x7FEFFFFFFFFFFFFF;
         printf("2.  double=%.16e  integer=%I64X",lb.double_value,lb.long_value);
      //--- 最小的正标准化 (DBL_MIN)
         lb.long_value=0x0010000000000000;    
         printf("3.  double=%.16e  integer=%.16I64X",lb.double_value,lb.long_value);
        }
      /*  Execution result
          1.  double=-nan(ind)                integer=FFF8000000000000
          2.  double=1.7976931348623157e+308  integer=7FEFFFFFFFFFFFFF
          3.  double=2.2250738585072014e-308  integer=0010000000000000
      */

    3. 为结构和类对象添加自动生成隐式复制操作符。现在,编译器可以自动创建复制操作符,它可以为对象编写简单的条目,例如b=a:
      class Foo
        {
         int               value;
      public:
         string Description(void){return IntegerToString(value);};
         //--- 默认构造函数
                           Foo(void){value=-1;};
         //--- 参数化构造函数   
                           Foo(int v){value=v;};
        };
      //+------------------------------------------------------------------+
      //|  包括 Foo 类型对象的结构                           |
      //+------------------------------------------------------------------+
      struct MyStruct
        {
         string            s;
         Foo               foo;
        };
      //+------------------------------------------------------------------+
      //| 脚本程序起始函数                                    |
      //+------------------------------------------------------------------+
      void OnStart()
        {
      //---
         MyStruct a,b;
         Foo an_foo(5);
         a.s="test";
         a.foo=an_foo;
         Print("a.s=",a.s," a.foo.Description()=",a.foo.Description());
         Print("b.s=",b.s," b.foo.Description()=",b.foo.Description());
      //---
         Print("b=a");
         b=a;
      //---
         Print("a.s=",a.s," a.foo.Description()=",a.foo.Description());
         Print("b.s=",b.s," b.foo.Description()=",b.foo.Description());
      /*
         Execution result;
         a.s=test a.foo.Description()=5
         b.s= b.foo.Description()=-1
         b=a
         a.s=test a.foo.Description()=5
         b.s=test b.foo.Description()=5
      */
        }
      在隐式操作符中执行对象的成员逐一复制。

      • 如果成员是一个对象,那么该对象对应的复制操作符将会被调用。
      • 如果成员是一个对象数组,那么调用每个元素对应的复制操作符之前就会使用ArrayResize增加或减少接收数组到所需的大小。
      • 如果成员是简单类型数组,ArrayCopy函数将用于复制。
      • 如果成员是一个对象指针,那么将会复制指针而不是它指向的对象。

      必要的情况下,您可以使用重载覆盖这个行为然后创建您自己的选项来替代隐式复制操作符。

    4. 当使用Copy* 函数访问来自EA交易的价格历史时,优化内存使用。当处理大量数据将会大幅降低内存消耗。

    5. 现在,TimeToStruct函数返回一个布尔值,允许检查datetime到MqlDateTime转换的成功率。
    6. 添加禁止在结构使用FileWriteStructFileReadStruct函数的禁令,包括字符串,动态数组,对象和指针。
    7. 已添加以下返回代码:

      • TRADE_RETCODE_REJECT_CANCEL — 激活挂单的请求被拒绝,订单被取消
      • TRADE_RETCODE_LONG_ONLY — 由于交易品种设置了“仅允许买入持仓”的规则,所以请求被拒绝
      • TRADE_RETCODE_SHORT_ONLY — 由于交易品种设置了“仅允许卖出持仓”的规则,所以请求被拒绝
      • TRADE_RETCODE_CLOSE_ONLY — 由于交易品种设置了“仅允许关闭现有持仓”的规则,所以请求被拒绝

    8. 通过SYMBOL_ORDER_MODE参数添加SymbolInfoInteger函数的新返回值。SYMBOL_ORDER_CLOSEBY — Close By操作的权限,例如,通过反向持仓来平仓。
    9. SYMBOL_CUSTOM布尔属性已添加到ENUM_SYMBOL_INFO_INTEGER枚举。该属性可以了解交易品种是否为自定义。使用SymbolInfoInteger函数来获得属性。
    10. 现在有可能获得创建一个订单,交易或持仓的原因。

      新属性


      订单,交易和持仓的创建原因
      已添加三个变量用来获得创建交易操作的原因:

      ENUM_POSITION_REASON ENUM_DEAL_REASON ENUM_ORDER_REASON 原因描述
      POSITION_REASON_CLIENT DEAL_REASON_CLIENT ORDER_REASON_CLIENT 激活从桌面程序端下单的订单而执行该操作
      POSITION_REASON_MOBILE DEAL_REASON_MOBILE ORDER_REASON_MOBILE 激活从手机应用下单的订单而执行该操作
      POSITION_REASON_WEB DEAL_REASON_WEB ORDER_REASON_WEB 激活从网页平台下单的订单而执行该操作
      POSITION_REASON_EXPERT DEAL_REASON_EXPERT ORDER_REASON_EXPERT 激活从MQL5程序下单的订单而执行该操作,例如EA交易或脚本
      - DEAL_REASON_SL ORDER_REASON_SL 激活止损而执行该操作
      - DEAL_REASON_TP ORDER_REASON_TP 激活止赢而执行该操作
      - DEAL_REASON_SO ORDER_REASON_SO 由于Stop out 事件而执行该操作
      - DEAL_REASON_ROLLOVER - 由于展期交割而执行交易
      - DEAL_REASON_VMARGIN - 收取变动预付款后执行交易
      - DEAL_REASON_SPLIT - 股票或其他资产分割(价格减少)后执行交易,宣布分割期间拥有持仓

    11. 优化同步和访问报价历史。
    12. CopyTicksRange函数中,修正返回报价到统计数组。在早期版本中,这种情况下经常返回0报价。
    13. 模糊逻辑库完成了多种修正。

    信号

    1. 修正无交易账户连接的情况下从网站打开的信号。

    Tester

    1. 优化并加速处理订单和交易历史。当处理大量数据时(数万条历史条目)将大幅度提高操作速度。
    2. 修正测试报告中计算的持仓时间。

    MetaEditor

    1. 修正了调试程序中静态类成员数组的显示内容。
    2. 在调试程序中添加了一个断点列表。该列表可以使用Debug标签的快捷菜单来打开:



      若要跳转到断点,请双击它。
    更新文档。
    22 六月 2017
    MetaTrader 5 iOS build 1605:开立初始交易账户
    新版MetaTrader 5 iOS build 1605提供了轻松开立初始交易账户的可能性。请从菜单选择“开立真实账户”并在服务器列表寻找您的交易商。填写您的个人详细资料,附加两份可以确认您身份和地址的文档并提交请求。您的交易商将会为您开立一个真实账户,必要情况下您还需要提供其他信息。


    新版MetaTrader 5 iOS还具有优化和重新设计邮箱版块的特性:

    • 现在相关邮件都绑定在一起并在邮件列表中显示为一项。
    • 添加预览邮件附件。
    • 现在一封邮件最多可以发送五个附件(文件大小不能超过8Mb)。
    26 四月 2017
    MetaTrader 5 Build 1596:访问价格历史

    程序端

    1. 添加访问柱形图和报价历史的功能。现在,不仅仅使用MQL5语言,还可以通过交易平台界面从服务器直接下载完整的1分钟柱形图和报价历史。访问价格历史已经扩展成为推出定制数据源功能准备工作的一部分。不久的将来,平台将提供可以基于用户价格数据建立图表,以及创建综合交易品种和使用离线图表。
      若要下载数据,请通过“市场报价”窗口的快捷菜单打开交易品种管理对话框:


      对话框显示两个新标签:“柱形图”和“报价”。选择交易品种,想要的时间间隔并点击“请求”。平台将从服务器请求全部可用数据,如果已被下载则将会立即显示数据。已保存的价格数据可以导出为CSV文件。

    2. 添加持仓,交易和订单时间的毫秒精确显示。




    3. 在交易对话框,修正拒绝执行Close By请求的通知。

    MQL5

    1. 修正PositionSelect函数。该函数可以偶尔选择不同于最低单号的持仓。
    2. 修正请求深度报价历史数据时的CopyTicksCopyTicksRange函数的操作。

    信号

    1. 修正复制增加现有持仓大小的操作。单边账户可能偶尔出现这个错误。

    Tester

    1. 修正处理交易所模式的限价单。优于市价单(买价低于市场价或卖价高于市场价)的限价单可以无滑点的执行。不如市价单的限价单以下单时的市场价立即执行。

    更新文档。


    8 四月 2017
    MetaTrader 5 Android build 1576:以持仓的形式显示交易历史

    MetaTrader 5 Android的交易历史现在能够以持仓的形式显示。在此之前,历史标签仅仅包含订单和交易信息,然而现在,可以根据持仓信息来分析交易。持仓相关的全部交易数据都集中显示在一条记录,显示如下:

    • 持仓和平仓时间(取决于第一笔交易和最后一笔交易)
    • 持仓交易量(如果部分平仓,记录会包括已平仓交易量和初始交易量)
    • 加权平均持仓开盘价和收盘价
    • 与持仓相关的全部金融交易结果

    30 三月 2017
    新版MetaTrader 5 iOS build 1547显示持仓历史记录

    现在交易历史能够以持仓的形式显示。在此之前,历史标签仅仅包含订单和交易数据。现在,它还包括了持仓数据。交易平台收集持仓相关的交易数据,然后将数据合并为一个记录。该记录包括:

    • 由第一笔交易和最后一笔交易决定的持仓和平仓时间
    • 持仓交易量。部分平仓情况下,记录包括平仓和初始交易量
    • 加权平均持仓开盘价和收盘价
    • 与持仓相关的金融交易的全部结果

    24 三月 2017
    MetaTrader 5 Build 1570:改进市场展示,扩展MQL5模板函数

    程序端

    1. 更新MetaTrader 市场商店的应用程序展示。现在,您可以更加方便的浏览EA交易和技术指标。我们更新了界面设计并添加了产品选择:

      • 现在,主界面可以显示最受欢迎的EA交易,指标,新的市场产品以及热门的免费应用程序。
      • EA交易,指标和实用工具版块还有其分版块:网格和锁仓EA交易,趋势和多货币指标以及更多内容。




    2. 修正当使用有权限限制的Windows账户时的客户端更新和市场、信号及虚拟主机的内置购买。
    3. 修正偶然发生的持仓历史的错误分类。
    4. 优化和修正展示标签的显示。

    MQL5:

    1. 添加支持使用参数重载模板函数。例如,我们有一个通过类型转换将第二个参数的值写入第一个参数的模板函数。MQL5不允许string到bool的类型转换。但是,我们可以自己完成。让我们创建一个模板函数的重载:
      //+------------------------------------------------------------------+
      //| 模板函数                                     |
      //+------------------------------------------------------------------+
      template<typename T1,typename T2>
      string Assign(T1 &var1,T2 var2)
        {
         var1=(T1)var2;
         return(__FUNCSIG__);
        }
      //+------------------------------------------------------------------+
      //|  bool+string的特殊重载                            |
      //+------------------------------------------------------------------+
      string Assign(bool &var1,string var2)
        {
         var1=(StringCompare(var2,"true",false) || StringToInteger(var2)!=0);
         return(__FUNCSIG__);
        }
      //+------------------------------------------------------------------+
      //| 脚本起始函数                                        |
      //+------------------------------------------------------------------+
      void OnStart()
        {
         int i;
         bool b;
         Print(Assign(i,"test"));
         Print(Assign(b,"test"));
        }
      代码执行后,我们可以看到Assign() 模板函数已被用于int+string组,而重载版也已在第二次调用时用于bool+string组。
      string Assign<int,string>(int&,string)
      string Assign(bool&,string)

    2. 新增模板函数的显式规范。因此,在调用函数列表之前,请先指定代表参数:
      template<typename T>
      T Func() { return (T)0; }
        
        
      void OnInit()
        {
         Func<double>();   // 模板函数显式规范
        }
      因此,类型的显式规范将会执行代表参数而非调用参数。

    3. 优化DRAW_ZIGZAG 绘制类型的自定义指标的显示。
    4. 添加新值到ENUM_DEAL_TYPE交易类型枚举:

      • DEAL_DIVIDEND — 股息操作。
      • DEAL_DIVIDEND_FRANKED — 税务减免(免税)股息操作(公司缴纳税费,而非客户)。
      • DEAL_TAX — 收税。

    5. 修正DRAW_FILLING绘制类型的自定义指标的显示。如果上下线坐标一致,绘制细线。
    6. 修正CHART_SHOW参数设置为'false'时计算位图标签对象坐标。参数通过ChartSetInteger函数来设置并允许隐藏全部价格图表元素来创建一个自定义程序界面。
    7. 修正将24位图像置于MQL5应用程序资源时的重新编码。
    8. 修正使用ArrayPrint函数的印刷结构。
    9. 更新MQL5标准程序库。

    MetaEditor

    1. 新增马来语的用户界面翻译。

    信号

    1. 修正在MQL5.community网站移动但没有连接交易账户时打开程序端的信号页面的问题。

    Tester

    1. 修正策略测试中的CopyTicks函数操作。
    2. 修正生成报告时排序出金交易。
    3. 修正更改挂单。

    主机

    1. 修正超高清屏幕(4К)上虚拟主机向导的显示。

    更新文档。

    17 二月 2017
    MetaTrader 5 平台Build 1545:通过鼠标滚动快速切换窗口和改变价格

    程序端

    1. 在'工具箱'和'策略测试'窗口之间快速切换。



    2. 提供了可以通过鼠标滚动编辑价格和订单交易量的新选项:




    3. 现在,当您切换到下载移动程序端时,将会记录您的交易服务器列表。然后,当您在iPhone或Android设备上安装MetaTrader时,将会向您显示一份准备好的服务器列表。 您就可以迅速连接您现有的交易账户。而当前连接账户的服务器将会第一时间显示在移动程序端。




    4. 显著降低隐形(最小化)图表和对象产生的程序端负载。
    5. 修正偶尔错误触发追踪止损水平。
    6. 修正在账户交易历史中通过交易品种筛选交易。
    7. 修正持仓历史中'类型'字段的显示。
    8. 修正以持仓形式展示交易历史。
    9. CLR_NONE用于颜色的情况下,修正绘制类型为DRAW_COLOR_LINE,DRAW_COLOR_ZIGZAG和DRAW_COLOR_SECTION的自定义指标的显示。

    MQL5

    1. 修正使用常量指针打印模板。
    2. 修正管理访问私有和受保护的类成员。

    Tester

    1. 当订单触发价格不如当前市场价时(买价高于或卖价低于市场价),修正激活交易所品种的限价订单。
    2. 移除具有64种输入参数的自定义指标测试的连接限制。
    3. 添加印地语的UI 翻译。

    更新文档。

    9 二月 2017
    MetaTrader 5 iOS build 1509:通过Facebook登录MQL5.com
    • 添加通过Facebook注册和登录您的MQL5.com账户的功能。如果您拥有该群组网络的账户,只需几次点击您就可以访问聊天功能及全套的MetaTrader 5服务。

    • 进一步改进及修正。
    上一页12345678910111213