//+------------------------------------------------------------------+//| подготовить массив тикетов для закрытия |//+------------------------------------------------------------------+void PrepareTicketsToClose(int signal, bool Revers, int & ticketsClose[][2], double & lots[],double arrayTickets[][9])
{
int size=ArrayRange(arrayTickets,0);
//----if (size==0) return;
int i,type,ticket,closeSize;
for (i=0;i<size;i++)
{
type=arrayTickets[i][1];
// если тип ордера не рыночный, то пропускаемif (type>OP_SELL) continue;
if (Revers) // перевернем тип рыночного ордера
{
if (type==OP_BUY) type=OP_SELL; else type=OP_BUY;
}
// тут решаем для каждого открытого ордера его судьбу// оставить в рынке или добавить в массив на закрытиеif (type==OP_BUY)
{
//// код разрешающий оставить покупку// как примерif (signal==OP_BUY) continue;
}
if (type==OP_SELL)
{
//// код разрешающий оставить продажу// как примерif (signal==OP_SELL) continue;
}
closeSize=ArrayRange(ticketsClose,0);
ArrayResize(ticketsClose,closeSize+1);
ArrayResize(lots,closeSize+1);
ticketsClose[closeSize][0] = arrayTickets[i][0]; // # тикета
ticketsClose[closeSize][1] = arrayTickets[i][1]; // тип ордера// здесь укажем сколько лотов нужно закрыть
lots[closeSize] = arrayTickets[i][2]; // закрываемый объем// можно закрывать частично, тогда нужно переписать строку сверху
}
//----return;
}
//+------------------------------------------------------------------+//| Закрывает ордера с указанными тикетами |//+------------------------------------------------------------------+void CloseMarketOrders(int ticketsArray[][2], double lotsArray[])
{
//----int i,size=ArrayRange(ticketsArray,0);
if (size==0) return;
int ticket,type;
double lots;
bool res;
int total=OrdersTotal();
for (i=0;i<size;i++)
{
ticket = ticketsArray[i][0];
type = ticketsArray[i][1];
lots = lotsArray[i];
RefreshRates(); // на всякий случай обновим сведения о рыночном окружении// блок закрытия покупокif (type==OP_BUY)
{
res = OrderClose(ticket,lots,Bid,Slippage,Orange);
if (!res)
{
Print("Не удалось закрыть ордер в покупку #",ticket,"! Ошибка №",GetLastError());
// дальнейшая обработка ошибки, написать самостоятельно
}
}
// блок закрытия продажif (type==OP_SELL)
{
res = OrderClose(ticket,lots,Ask,Slippage,Orange);
if (!res)
{
Print("Не удалось закрыть ордер в продажу #",ticket,"! Ошибка №",GetLastError());
// дальнейшая обработка ошибки, написать самостоятельно
}
}
}
//----return;
}
尊敬的专业人员和有识之士!
我很茫然--BB指标给了我难以理解的信号(不是 "红-绿-红"!)。更准确地说,我设置了这样一个电话。
bolup = iBands(Symbol(), 0, 24, 0, 2, 0, 1, 1);
boln = iBands(Symbol(), 0, 24, 0, 2, 0, 2, 1);
bolmd = (bolup + boldn) / 2;
Print("Bands upper = ", bolup;)
Print("Bands lower = ", boldn);
Print("Bands media = ", bolmd);
其结果是,所有3个变量都给出了相同的值。>8-O
欧元对,TF - H1。有什么想法吗?
提前感谢...
为清晰起见,我试图 在 ,画出它的图片。
尊敬的专业人员和有识之士!
我很茫然--BB指标给了我难以理解的信号(不是 "红-绿-红"!)。更准确地说,我给下面的电话。
bolup = iBands(Symbol(), 0, 24,0, 2, 0, 1, 1);
boldn = iBands(Symbol(), 0, 24,0, 2, 0, 2, 1);
bolmd = (bolup + boldn) / 2;
Print("Bands upper = " , bolup);
Print("Bands lower = " , boldn);
Print("Bands media = " , bolmd);
结果,所有3个变量都给出了相同的值。>8-O
它是欧元,H1。有什么想法吗?
提前感谢...
我有一个问题,我不知道如何解决,我试着解释一下。
因此,在我发布的代码中,有两个函数
在 void PrepareTicketsToClose(int signal, bool Revers, int & ticketsClose[][2], double & lots[],double arrayTickets[][9])中,我们必须放一个条件,决定我们是否应该离开或关闭订单。
我试着设置条件,但没有任何效果....
谁能看一下,看看这些函数中是否有错误,或者我弄错了....。
在测试器中不需要,但在模拟或真实账户中,你会收到一条关于交易繁忙的信息。
下午好。该系统提供了三个买入和卖出的入口点。但当一个信号出现时,只要信号存在,就会在每个tick 上开仓。某个地方的标志出现了错误。请帮助我理解它。
下午好。该系统提供了三个买入和卖出的入口点。但当一个信号出现时,只要信号存在,就会在每个tick上开仓。某个地方的标志出现了错误。请帮助我理解它。
OrdersTotal()给出了已经开仓的数量,也就是说,我们可以用它来检查是否已经有一个开仓。