Новая функция "FileSave" сохраняет файл только в бинарном виде?
Предложение по классу CGraphic.mqh.
Для того, чтобы иметь возможность удалять объект - график, нужно изменить методы GraphPlot:
//| Create graphic of one curve and return resource name |
//+------------------------------------------------------------------+
string GraphPlot(const double &y[],ENUM_CURVE_TYPE type=CURVE_POINTS)
{
string name="Graphic"+(string)(GetTickCount()+MathRand());
ulong width = ChartGetInteger(0,CHART_WIDTH_IN_PIXELS);
ulong height= ChartGetInteger(0,CHART_HEIGHT_IN_PIXELS);
CGraphic graphic;
//--- create graphic and add curves
graphic.Create(0,name,0,65,45,(int)(0.6*width),(int)(0.65*height));
graphic.CurveAdd(y,type);
//--- plot curves
graphic.CurvePlotAll();
graphic.Update();
//--- return resource name
//return graphic.ResourceName();
return graphic.ChartObjectName();
}
Например сейчас на чарте есть объект с именем "Graphic27489614", метод graphic.ResourceName() возвращает "::Graphic2748961427502758", а метод graphic.ChartObjectName() возвращает "Graphic27489614". И если внести изменение, то можно вызывать ObjectDelete с указанием имени объекта и удалить объект-график.
Предложение по классу CGraphic.mqh.
Для того, чтобы иметь возможность удалять объект - график, нужно изменить методы GraphPlot:
Например сейчас на чарте есть объект с именем "Graphic27489614", метод graphic.ResourceName() возвращает "::Graphic2748961427502758", а метод graphic.ChartObjectName() возвращает "Graphic27489614". И если внести изменение, то можно вызывать ObjectDelete с указанием имени объекта и удалить объект-график.
Так эта возможность ведь и так уже есть. Как раз вызывая метод CGraphic::ChartObjectName() получаем имя объекта, который нужно удалить.
P.S. Или даже метод CGraphic::Destroy().
Предложение по классу CGraphic.mqh.
Так эта возможность ведь и так уже есть. Как раз вызывая метод CGraphic::ChartObjectName() получаем имя объекта, который нужно удалить.
P.S. Или даже метод CGraphic::Destroy().
Нет. Не работают оба метода (CGraphic::ChartObjectName() возвращает "NULL"), CGraphic::Destroy() вообще получается не для удаления графика.
У меня работают оба. Протестируйте этот скрипт и покажите свой вариант. Интересно, почему не получалось у Вас.
В скрипте два метода можно протестировать.
//| Test.mq5 |
//| Copyright 2016, MetaQuotes Software Corp. |
//| http://www.mql5.com |
//+------------------------------------------------------------------+
#property copyright "Copyright 2016, MetaQuotes Software Corp."
#property link "http://www.mql5.com"
#property version "1.00"
//---
#include <Math/Stat/Binomial.mqh>
#include <Graphics/Graphic.mqh>
//--- Размер массива
#define ARRAY_SIZE 50
//---
double array_values[ARRAY_SIZE];
double array_results[ARRAY_SIZE];
//+------------------------------------------------------------------+
//| Script program start function |
//+------------------------------------------------------------------+
void OnStart(void)
{
string name ="Graphic";
ulong width =::ChartGetInteger(0,CHART_WIDTH_IN_PIXELS);
ulong height =::ChartGetInteger(0,CHART_HEIGHT_IN_PIXELS);
//---
CGraphic graphic;
//--- create graphic
graphic.Create(0,name,0,65,45,(int)(0.6*width),(int)(0.65*height));
//---
InitArray();
CCurve *curve1=graphic.CurveAdd(array_values,CURVE_POINTS);
//---
graphic.CurvePlotAll();
graphic.Update();
//---
for(int i=0; i<10; i++)
{
InitArray();
curve1.Update(array_values);
//---
graphic.CurvePlotAll();
graphic.Update();
//---
Sleep(500);
}
//---
graphic.Destroy();
//---
::Print(__FUNCTION__," > graphic.ChartObjectName(): ",graphic.ChartObjectName());
if(!::ObjectDelete(0,graphic.ChartObjectName()))
Print(__FUNCTION__," > Объект уже удалён!");
}
//+------------------------------------------------------------------+
//| Генерация значений |
//+------------------------------------------------------------------+
void InitArray(void)
{
for(int j=0; j<ARRAY_SIZE; j++)
array_values[j]=j;
Shuffle(array_values);
}
//+------------------------------------------------------------------+
//| Тасование значений массива |
//+------------------------------------------------------------------+
void Shuffle(double &array[])
{
for(uint i=0; i<ARRAY_SIZE; i++)
RandomSwap(array_values,i);
}
//+------------------------------------------------------------------+
//| Случайно поменять элементы местами |
//+------------------------------------------------------------------+
void RandomSwap(double &array[],uint i)
{
//--- Случайный индекс для замены
uint j=::rand()%ARRAY_SIZE;
//--- Меняем местами
double temp =array[i];
array[i] =array[j];
array[j] =temp;
}
//+------------------------------------------------------------------+
Я изначально мучил вот этот пример (взят из Новая версия платформы MetaTrader 5 build 1485: дополнительные режимы тестирования и графика в стандартной библиотеке)
//| Test_1.mq5 |
//| Copyright 2016, MetaQuotes Software Corp. |
//| http://www.mql5.com |
//+------------------------------------------------------------------+
#property copyright "Copyright 2016, MetaQuotes Software Corp."
#property link "http://www.mql5.com"
#property version "1.00"
#include <Math/Stat/Binomial.mqh>
#include <Graphics/Graphic.mqh>
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
void OnStart(void)
{
double vars[101];
double results[101];
const int N=2000;
//---
MathSequence(0,N,20,vars);
MathProbabilityDensityBinomial(vars,N,M_PI/10,true,results);
GraphPlot(results);
//---
}
#include <Math\Stat\Normal.mqh>
#include <Graphics\Graphic.mqh>
void OnStart()
{
//---
double random_values[];
double pdf[];
double cdf[];
double x[];
if(MathRandomNormal(0,1,1000000,random_values))
{
if(MathProbabilityDensityEmpirical(random_values,200,x,pdf))
{
GraphPlot(x,pdf,CURVE_LINES);
//---
DebugBreak();
}
if(MathCumulativeDistributionEmpirical(random_values,200,x,cdf))
{
GraphPlot(x,cdf,CURVE_LINES);
//---
DebugBreak();
}
}
}
Я изначально мучил вот этот пример (взят из Новая версия платформы MetaTrader 5 build 1485: дополнительные режимы тестирования и графика в стандартной библиотеке)
//| Test_1.mq5 |
//| Copyright 2016, MetaQuotes Software Corp. |
//| http://www.mql5.com |
//+------------------------------------------------------------------+
#property copyright "Copyright 2016, MetaQuotes Software Corp."
#property link "http://www.mql5.com"
#property version "1.00"
#include <Math/Stat/Binomial.mqh>
#include <Graphics/Graphic.mqh>
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
void OnStart(void)
{
double vars[101];
double results[101];
const int N=2000;
//---
MathSequence(0,N,20,vars);
MathProbabilityDensityBinomial(vars,N,M_PI/10,true,results);
GraphPlot(results);
//---
}
В общем удаление пока делаю так:
ChartRedraw();
Как узнать, что сработал SL/TP в OnTradeTransaction()?
Вот что сделал, не помогает:
const MqlTradeRequest &request, // структура запроса
const MqlTradeResult &result) // структура ответа
{
if(trans.type == TRADE_TRANSACTION_HISTORY_ADD)
{
datetime date = TimeCurrent ();
MqlDateTime dateT;
TimeToStruct (date, dateT);
dateT.hour += 1;
date = StructToTime (dateT);
if(HistorySelect (TimeCurrent (), date))
{
int dealsTotal = HistoryDealsTotal ();
ulong ticketD = HistoryDealGetTicket (dealsTotal - 1);
if(HistoryDealGetString (ticketD, DEAL_SYMBOL) == Symbol ())
{
ENUM_DEAL_ENTRY entry = (ENUM_DEAL_ENTRY)HistoryDealGetInteger (ticketD, DEAL_ENTRY);
if(entry == DEAL_ENTRY_OUT)
{
int ordersTotal = HistoryOrdersTotal ();
ulong ticketO = HistoryOrderGetTicket (ordersTotal - 1);
if(HistoryOrderGetString (ticketO, ORDER_SYMBOL) == Symbol ())
{
double orderPrice = HistoryOrderGetDouble (ticketO, ORDER_PRICE_OPEN);
double orderSL = HistoryOrderGetDouble (ticketO, ORDER_SL);
double orderTP = HistoryOrderGetDouble (ticketO, ORDER_TP);
if(orderPrice == orderSL)
Print ("Сработал SL");
if(orderPrice == orderTP)
Print ("Сработал TP");
}
}
}
}
}
}
И вообще, неужели нельзя никак попроще?!
- Бесплатные приложения для трейдинга
- 8 000+ сигналов для копирования
- Экономические новости для анализа финансовых рынков
Вы принимаете политику сайта и условия использования
Новая функция "FileSave" сохраняет файл только в бинарном виде?
//| Scripts_Test.mq5 |
//| Copyright 2012, CompanyName |
//| http://www.companyname.net |
//+------------------------------------------------------------------+
//--- входные параметры
input int rates_to_save=1000; // количество
//+------------------------------------------------------------------+
//| Script program start function |
//+------------------------------------------------------------------+
void OnStart()
{
string filename=_Symbol+"_ticks.csv";
MqlRates rates[];
//---
int copied=CopyRates(Symbol(),Period(),0,rates_to_save,rates);
if(copied!=-1)
{
PrintFormat(" CopyRates(%s) copied %d rates",Symbol(),copied);
//--- запишем тики в файл
if(!FileSave(filename,rates,FILE_COMMON))
PrintFormat("FileSave() failed, error=%d",GetLastError());
}
else
PrintFormat("Failed CopyRates(%s), Error=",_Symbol,GetLastError());
}
//+------------------------------------------------------------------+
Что хотел сделать: сохранить файл в формате "csv" Для открытия в Excel.