//+------------------------------------------------------------------+ //| Expert tick function | //+------------------------------------------------------------------+
//+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ voidOnTick () { { if ( Bars < 801 || ( IsTradeAllowed ()== false )) //--- Проверим достаточна ли в истории баров для анализа и разрешение торговли return ; } //+----------------------------------------------------------------
Artyom,我扔了上面的代码。
复制你上面抛出的代码链接,当你提到任何参与者的帖子时,把它粘贴到你的帖子中。还是你认为你在不知道它在哪里和它的内容的情况下,就这么想找到它?
这里有我回复的你的帖子的链接:#1170。它就在你的昵称旁边的股票区。
复制你上面抛出的代码的相同链接,并在提及任何参与者的信息时将其粘贴到你的信息中。还是你认为你在不知道它在哪里和它的内容的情况下如此想找到它?
https://www.mql5.com/ru/forum/160683/page109
1082条信息
我只是不知道这个资源,但通常版主会看到任何用户的所有帖子,包括编辑。
如何做这样的帖子链接,我不知道。
https://www.mql5.com/ru/forum/160683/page109
1082条信息
我只是不知道这个资源,但通常版主会看到任何用户的所有帖子,包括编辑。
如何做这样的帖子链接,我不知道。
https://www.mql5.com/ru/forum/160683/page109
1082条信息
使用SRC按钮,将其作为代码附在这里。然后你可以安全地查看代码,而不必下载并将其放在正确的终端文件夹 中--为什么要让那些可以帮助你的人的生活变得困难呢?
不,你不想下载。
使用 SRC 按钮在此处附加为代码。然后您可以安全地查看代码,而无需下载并将其放在终端的正确文件夹中- 为什么要让那些可以帮助您的人生活困难?
拜托,只有我不明白如何在不将其下载到我的终端的情况下进行检查。还请解释在这里抛出阻塞页面的代码有什么好处。
//| Close_MA.mq4 |
//| Copyright 2016, MetaQuotes Software Corp. |
//| https://www.mql5.com |
//+------------------------------------------------------------------+
#property copyright "Copyright 2016, MetaQuotes Software Corp."
#property link "https://www.mql5.com"
#property version "1.00"
#property strict
extern bool Uslovie1= false ; //Uslovie 4 6+50 MA
extern bool OpenOrders= false ; //+---Открыть ордер
extern double Lots= 0.01 ; //Oбьем открываемого ордера
extern const string Настройки_работы_советника= "" ;
extern int Period1= 6 ; //Период 1МА
extern ENUM_APPLIED_PRICE PRICE1= PRICE_MEDIAN ; // 1МА По цене
extern int Period2= 50 ; //Период 2МА
extern ENUM_APPLIED_PRICE PRICE2= PRICE_MEDIAN ; // 2МА По цене
extern int Period3= 1000 ; //Период 3МА
extern ENUM_APPLIED_PRICE PRICE3= PRICE_MEDIAN ; // 3МА По цене
extern uint X= 1 ; // отклонение от ма, пунктов
extern bool PlaySound = false ;
extern int M= 1000 ; // миллисекунды в Sleep
extern int R; // раз повторения музыки
extern int count= 0 ;
extern int Step= 500 ; // счетчик тиков 500макс.
int i; // исходный счетчик ордеров
int p= 0 ; // внутренняя для playSound
bool y = false ; // для удобства сравнений условий 1,2,3,4,5,6
bool dummy; // для выхода функций в переменную
int ticket = 0 ; // тикет открываемого ордера
int Magic = 222 ;
//+------------------------------------------------------------------+
//| Expert initialization function |
//+------------------------------------------------------------------+
int OnInit ()
{
return ( INIT_SUCCEEDED );
}
//+------------------------------------------------------------------+
//| Expert deinitialization function |
//+------------------------------------------------------------------+
void OnDeinit ( const int reason)
{
}
//+------------------------------------------------------------------+
//| Expert tick function |
//+------------------------------------------------------------------+
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
void OnTick ()
{
{
if ( Bars < 801 || ( IsTradeAllowed ()== false )) //--- Проверим достаточна ли в истории баров для анализа и разрешение торговли
return ;
}
//+----------------------------------------------------------------
double ma1= NormalizeDouble ( iMA ( NULL , 0 ,Period1, 0 , MODE_SMA ,PRICE1, 0 ), 5 );
double ma2= NormalizeDouble ( iMA ( NULL , 0 ,Period2, 0 , MODE_SMA ,PRICE1, 0 ), 5 ); //три заданных параметра ма
double ma3= NormalizeDouble ( iMA ( NULL , 0 ,Period3, 0 , MODE_SMA ,PRICE1, 0 ), 5 );
//+----------------------------------------------------------------- Открытие ордеров
//+----Купить
{
if ( MathAbs ( Bid -ma3)< 1000 * Point () && (myOrdersTotal()== false ))
{
ticket= OrderSend ( Symbol (), OP_BUY ,Lots, Ask , 50 , 0 , 0 , "" ,Magic, 0 , clrLightGray ); //+------отправка 1 ордера
HLineCreate();
}
else if (( Ask >=(FindLastOrderOpenPrice()+(Step* _Point )))&& myOrdersTotal()) //+------------если ордер в плюс
{
ticket= OrderSend ( Symbol (), OP_BUY ,Lots, Ask , 50 , 0 , 0 , "" ,Magic, 0 , clrLightGray );
HLineMove();
}
else if (( Ask <=(FindLastOrderOpenPrice()-(Step* _Point )))&& myOrdersTotal()) //+------------если ордер вплюс
{
ticket= OrderSend ( Symbol (), OP_BUY ,Lots, Ask , 50 , 0 , 0 , "" ,Magic, 0 , clrLightGray );
HLineMove();
}
else if (ticket== 0 )
{
return ;
}
/*
//+----Продать
if(MathAbs(Bid-ma3)>1000*Point() && (myOrdersTotal()==false))
{
ticket=OrderSend(Symbol(),OP_SELL,Lots,Bid,50,0,0,"",Magic,0,clrLightGray);//+------отправка 1 ордера
HLineCreate1();
}
else if ((Ask>=(FindLastOrderOpenPrice()+(Step*_Point)))&& myOrdersTotal())//+------------если ордер в минус
{
ticket=OrderSend(Symbol(),OP_SELL,Lots,Bid,50,0,0,"",Magic,0,clrLightGray);
HLineMove1();
}
else if ((Ask<=(FindLastOrderOpenPrice()-(Step*_Point)))&& myOrdersTotal())//+------------если ордер вплюс
{
ticket=OrderSend(Symbol(),OP_SELL,Lots,Bid,50,0,0,"",Magic,0,clrLightGray);
HLineMove1();
}
else if(ticket==0)
{
return;
} */
}
//+------------------------------------------------------------------Условия
if (Uslovie1== true ) //Bid+ma800
{
if (( Bid >=ma3-X* Point && Bid <ma3) || ( Bid <=ma3+X* Point && Bid >ma3))
{
{y= true ;}
}
}
//+------------------------------------------------------------------закрыть покупки или продажи
if ((y== true ) && (myOrdersTotal()== true )) //продажа
{
dummy=( OrderClose ( OrderTicket (), OrderLots (), Ask , 0 ,White));
}
if ((y== true ) && (myOrdersTotal()== false ))
{
dummy= false ;
HLineDelete();
HLineDelete1();
// ExpertRemove();
}
}
//+------------------------------------------------------------------+
bool myOrdersTotal() //если ордера есть
{
for (i= OrdersTotal ()- 1 ; i>= 0 ; i--) // цикл будет работать пока не останется ордеров
{
if ((( OrderSelect (i, SELECT_BY_POS , MODE_TRADES ))== true ) && OrderSymbol ()== Symbol () && ( OrderType ()< 2 ))
{
return true ;
}
}
return false ;
}
//-------------------------------------------------------------------
double FindLastOrderOpenPrice()
{
double oldorderopenprice= 0 ;
int oldticket= 0 ;
ticket= 0 ;
for (i= OrdersTotal ()- 1 ; i>= 0 ; i--) // цикл будет работать пока не останется ордеров
{
if (( OrderSelect (i, SELECT_BY_POS , MODE_TRADES )) && OrderSymbol ()== Symbol () && ( OrderMagicNumber ()==Magic)
&& ( OrderType ()== OP_BUY || OrderType ()== OP_SELL ))
{
oldticket= OrderTicket ();
if (oldticket>=ticket)
{
ticket=oldticket;
oldorderopenprice= OrderOpenPrice ();
}
}
}
return (oldorderopenprice);
}
//-------------------------------------------------------------------
//+------------------------------------------------------ часть Buy bool HLineCreate();
bool HLineCreate( const long chart_ID= 0 , // ID графика
const string name= "Buy" , // имя линии
const int sub_window= 0 , // номер подокна
double price1= 0 , // цена линии
const color clr= clrAzure , // цвет линии
const ENUM_LINE_STYLE style= STYLE_DASHDOT , // стиль линии
const int width= 3 , // толщина линии
const bool back= false , // на заднем плане
const bool selection= true , // выделить для перемещений
const bool hidden= false , // скрыт в списке объектов
const long z_order= 0 ) // приоритет на нажатие мышью
{
if (!price1)
price1=FindLastOrderOpenPrice();
ResetLastError ();
if (! ObjectCreate (chart_ID,name, OBJ_HLINE ,sub_window, 0 ,price1))
{
Print ( __FUNCTION__ ,
": не удалось создать горизонтальную линию! Код ошибки = " , GetLastError ());
return ( false );
//--- установим цвет линии
ObjectSetInteger (chart_ID,name, OBJPROP_COLOR ,clr);
//--- установим стиль отображения линии
ObjectSetInteger (chart_ID,name, OBJPROP_STYLE ,style);
//--- установим толщину линии
ObjectSetInteger (chart_ID,name, OBJPROP_WIDTH ,width);
//--- отобразим на переднем (false) или заднем (true) плане
ObjectSetInteger (chart_ID,name, OBJPROP_BACK ,back);
ObjectSetInteger (chart_ID,name, OBJPROP_SELECTABLE ,selection);
ObjectSetInteger (chart_ID,name, OBJPROP_SELECTED ,selection);
//--- скроем (true) или отобразим (false) имя графического объекта в списке объектов
ObjectSetInteger (chart_ID,name, OBJPROP_HIDDEN ,hidden);
//--- установим приоритет на получение события нажатия мыши на графике
ObjectSetInteger (chart_ID,name, OBJPROP_ZORDER ,z_order);
ChartRedraw ();
}
return ( true );
}
//+------------------------------------------------------------------+ HLineMove();
bool HLineMove( const long chart_ID= 0 , // ID графика
const string name= "Buy" , // имя линии
double price1= 0 ) // цена линии
{
if (!price1)
price1=FindLastOrderOpenPrice();
ResetLastError ();
if (! ObjectMove (chart_ID,name, 0 , 0 ,price1))
{
Print ( __FUNCTION__ ,
": не удалось переместить горизонтальную линию! Код ошибки = " , GetLastError ());
return ( false );
}
return ( true );
}
//+------------------------------------------------------------------+ bool HLineDelete();
bool HLineDelete( const long chart_ID= 0 , // ID графика
const string name= "Buy" ) // имя линии
{
ResetLastError ();
if (! ObjectDelete (chart_ID,name))
{
Print ( __FUNCTION__ ,
": не удалось удалить горизонтальную линию! Код ошибки = " , GetLastError ());
return ( false );
}
return ( true );
}
//+-----------------------------------------------------------------+
//+-----------часть SELL bool HLineCreate1
//+------------------------------------------------------
//+------------------------------------------------------ bool HLineCreate1();
bool HLineCreate1( const long chart_ID= 0 , // ID графика
const string name= "Sell" , // имя линии
const int sub_window= 0 , // номер подокна
double price2= 0 , // цена линии
const color clr= clrRed , // цвет линии
const ENUM_LINE_STYLE style= STYLE_DASHDOT , // стиль линии
const int width= 2 , // толщина линии
const bool back= false , // на заднем плане
const bool selection= true , // выделить для перемещений
const bool hidden= false , // скрыт в списке объектов
const long z_order= 0 ) // приоритет на нажатие мышью
{
if (!price2)
price2=FindLastOrderOpenPrice();
ResetLastError ();
if (! ObjectCreate (chart_ID,name, OBJ_HLINE ,sub_window, 0 ,price2))
{
Print ( __FUNCTION__ ,
": не удалось создать горизонтальную линию! Код ошибки = " , GetLastError ());
return ( false );
//--- установим цвет линии
ObjectSetInteger (chart_ID,name, OBJPROP_COLOR ,clr);
//--- установим стиль отображения линии
ObjectSetInteger (chart_ID,name, OBJPROP_STYLE ,style);
//--- установим толщину линии
ObjectSetInteger (chart_ID,name, OBJPROP_WIDTH ,width);
//--- отобразим на переднем (false) или заднем (true) плане
ObjectSetInteger (chart_ID,name, OBJPROP_BACK ,back);
ObjectSetInteger (chart_ID,name, OBJPROP_SELECTABLE ,selection);
ObjectSetInteger (chart_ID,name, OBJPROP_SELECTED ,selection);
//--- скроем (true) или отобразим (false) имя графического объекта в списке объектов
ObjectSetInteger (chart_ID,name, OBJPROP_HIDDEN ,hidden);
//--- установим приоритет на получение события нажатия мыши на графике
ObjectSetInteger (chart_ID,name, OBJPROP_ZORDER ,z_order);
ChartRedraw ();
}
return ( true );
}
//+------------------------------------------------------------------+ HLineMove1();
bool HLineMove1( const long chart_ID= 0 , // ID графика
const string name= "Sell" , // имя линии
double price2= 0 ) // цена линии
{
if (!price2)
price2=FindLastOrderOpenPrice();
ResetLastError ();
if (! ObjectMove (chart_ID,name, 0 , 0 ,price2))
{
Print ( __FUNCTION__ ,
": не удалось переместить горизонтальную линию! Код ошибки = " , GetLastError ());
return ( false );
}
return ( true );
}
//+------------------------------------------------------------------+ bool HLineDelete1();
bool HLineDelete1( const long chart_ID= 0 , // ID графика
const string name= "Sell" ) // имя линии
{
ResetLastError ();
if (! ObjectDelete (chart_ID,name))
{
Print ( __FUNCTION__ ,
": не удалось удалить горизонтальную линию! Код ошибки = " , GetLastError ());
return ( false );
}
return ( true );
}
把它放在这里。
Artyom,这是为特别有天赋的视频吗?
拜托,只是我不明白如何在不上传到我的终端的情况下检查它。另外,请解释一下,在这里抛出代码碎片 堵塞页面的好处是什么。
交易员781,你对代码的问题是什么?
大块代码的好处是,例如,我有一个测试文件,我只需从论坛上复制一段代码并将其粘贴到文件中。否则,你必须下载带有代码的文件,然后在文件夹中打开一个文件夹,粘贴你的文件,之后你必须删除它。你觉得有什么不同吗?
拜托,只是我不明白如何在不上传到我的终端的情况下检查它。也请解释一下,在这里抛出一些代码碎片,堵塞了页面,有什么好处?
实际上,人们通常会用最小的代码来重现你所说的错误。
但从代码来看,你根本没有真正理解它的作用。
你在你的函数里有参数,可以传给它们。特别是线条的颜色。但你把它们都做成了默认值,而且不问 "我的函数里面有什么,它得到什么参数?"但你开始说终端失败了。这很好...
从创建行的函数中删除所有默认参数--编译器会让你在调用函数 时考虑设置这些参数--这对于你自己的教育是必要的。并删除重复的函数--那些你在名字后面加了1的函数--使用一个有不同参数的函数。
trader781,关于代码的问题到底是什么?
代码片的好处是,例如,我有一个测试文件,我只需要从论坛上复制一段代码并粘贴到文件中。否则,你必须下载带有代码的文件,然后在文件夹中打开一个文件夹,粘贴你的文件,之后你必须删除它。感觉到差异了吗?
好的,我明白了
该死的部门......。
我明白目前这一切都远不能接受,但你能告诉我为什么在购买的情况下,我不能得到指定颜色的给定虚线,虽然白色或只是绿色,但它会悄悄地给出来。
和
双重OP=5.00000
TP=(OP/100)。
Print("TP=",TP)。
2017.02.09 21:36:03.650 2015.01.05 04:00:00 martin H1-1 USDJPY,H1: TP= 0.5
不明白你什么时候开始用5除以100就是0.5 了?