GLUCK?! Manipulação de eventos com o clique do rato!!! - página 13

 
sergeev:


despachem-se! Só agora!!! descarregue este produto único!

E obtém uma versão com um bug especialmente concebido - pequenos blips de linha!


:))


tem uma solução para este problema? Já procurei em tudo - ainda não consigo pensar em mais nada, e não é um insecto, mudar as linhas é deliberado, mas é uma coisa que pisca - já escrevi o problema antes.

Eu nem diria que é um blip, é um deslocamento em linhas ao longo do eixo x.

 

Caros colegas comerciantes!

Acabei de copiar um exemplo do manual .chm na descrição da função OrderSendAsync, com um simples botão respondendo a um clique, no meu caso é assim que se parece:

void OnChartEvent(const int id,
                  const long &lparam,
                  const double &dparam,
                  const string &sparam)
{
//--- обработка события CHARTEVENT_CLICK ("Нажатие кнопки мышки на графике")
   if( id == CHARTEVENT_OBJECT_CLICK )
   {
      Print( "=> ", __FUNCTION__, ": sparam = ", sparam );
      if( sparam=="Finalize" )
      {
         PrintFormat( "Closing position %s",_Symbol );
         while( !ClosePosition() );

         //--- отожмем нажатую кнопку обратно
         ObjectSetInteger( 0, "Finalize", OBJPROP_STATE, false );
      }
      ChartRedraw();
   }      
}

void CreateFinalizeButton()
{
//--- проверим наличие объекта с именем "Finalize"
   if(ObjectFind(0,"Finalize")>=0)
   {
      //--- если найденный объект не является кнопкой, удалим его
      if(ObjectGetInteger(0,"Finalize",OBJPROP_TYPE)!=OBJ_BUTTON)
         ObjectDelete(0,"Finalize");
   }
   else
      ObjectCreate(0,"Finalize",OBJ_BUTTON,0,0,0); // создадим кнопку "Finalize"
//--- настроим кнопку "Finalize"
   ObjectSetInteger( 0, "Finalize", OBJPROP_CORNER, CORNER_LEFT_LOWER );
   ObjectSetInteger( 0, "Finalize", OBJPROP_XDISTANCE, 100 );
   ObjectSetInteger( 0, "Finalize", OBJPROP_YDISTANCE, 50 );
   ObjectSetInteger( 0, "Finalize", OBJPROP_XSIZE, 150 );
   ObjectSetInteger( 0, "Finalize", OBJPROP_YSIZE, 30 );
   ObjectSetString( 0, "Finalize", OBJPROP_TEXT, "Finalize" );
   ObjectSetInteger( 0, "Finalize", OBJPROP_COLOR, clrBlue );
//--- принудительно обновим график, чтобы кнопки отрисовались немедленно
   ChartRedraw();
}

Ao que parece, desencadeia-se quando o prazo muda. Pode por favor dizer-me como é que este problema pode ser resolvido?

 
surava:

Caros colegas comerciantes!

Acabei de copiar um exemplo do manual .chm na descrição da função OrderSendAsync, com um simples botão respondendo a um clique, no meu caso parece que é assim:

Ao que parece, desencadeia-se quando o prazo muda. Pode por favor dizer-me como é que este problema pode ser resolvido?

O exemplo padrão para OrderSendAsync não reage à mudança do período do gráfico. Isto significa que fez asneira em alguma coisa. Precisa de mais informações: tipo de terminal, construção do terminal e todo o seu código.
 
Karputov Vladimir:
O exemplo padrão para OrderSendAsync não reage à mudança do período do gráfico. Isto significa que fez asneira em alguma coisa. Precisa de mais informações: tipo de terminal, construção de terminal e todo o seu código.

Vladimir, obrigado pela sua resposta rápida!

Aqui está a informação sobre o terminal:


Aqui está o código (apenas agora começou a aprender como funcionam as funções comerciais):

#property copyright "surava"
#property link      "https://www.mql5.com"
#property version   "1.00"

ulong MagicNumber = 1649353089;

int OnInit()
{
   CreateFinalizeButton();

   return(INIT_SUCCEEDED);
}
//+------------------------------------------------------------------+
//| Expert deinitialization function                                 |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
{
   while( !ClosePosition() );
   
   if( ObjectFind( 0, "Finalize" ) >= 0 )
      ObjectDelete(0,"Finalize");
}
//+------------------------------------------------------------------+
//| Expert tick function                                             |
//+------------------------------------------------------------------+
void OnTick()
  {
//---
   
  }
//+------------------------------------------------------------------+
//| Trade function                                                   |
//+------------------------------------------------------------------+
void OnTrade()
{
 
}
//+------------------------------------------------------------------+
//| TradeTransaction function                                        |
//+------------------------------------------------------------------+
void OnTradeTransaction(const MqlTradeTransaction& trans,
                        const MqlTradeRequest& request,
                        const MqlTradeResult& result)
{
   if( trans.type != TRADE_TRANSACTION_REQUEST )
      return;
   
   Print( "============= New transaction =============" );
   Print( __FUNCTION__, " Trans action: ", EnumToString( trans.type ) ); 
   Print( __FUNCTION__, " Trans order state: ", EnumToString( trans.order_state ) );    
   Print( __FUNCTION__, " Result order type: ", EnumToString( request.action ) );
   Print( __FUNCTION__, " Request action: ", EnumToString( request.type ) );
   Print( __FUNCTION__, " Deal price: ", result.price );   
   Print( __FUNCTION__, " Result comment: ", result.comment ); 
}

void OnChartEvent(const int id,
                  const long &lparam,
                  const double &dparam,
                  const string &sparam)
{
//--- обработка события CHARTEVENT_CLICK ("Нажатие кнопки мышки на графике")
   if( id == CHARTEVENT_OBJECT_CLICK )
   {
      Print( "=> ", __FUNCTION__, ": sparam = ", sparam );
      if( sparam=="Finalize" )
      {
         PrintFormat( "Closing position %s",_Symbol );
         while( !ClosePosition() );

         //--- отожмем нажатую кнопку обратно
         ObjectSetInteger( 0, "Finalize", OBJPROP_STATE, false );
      }
      ChartRedraw();
   }      
}

void CreateFinalizeButton()
{
//--- проверим наличие объекта с именем "Finalize"
   if(ObjectFind(0,"Finalize")>=0)
   {
      //--- если найденный объект не является кнопкой, удалим его
      if(ObjectGetInteger(0,"Finalize",OBJPROP_TYPE)!=OBJ_BUTTON)
         ObjectDelete(0,"Finalize");
   }
   else
      ObjectCreate(0,"Finalize",OBJ_BUTTON,0,0,0); // создадим кнопку "Finalize"
//--- настроим кнопку "Finalize"
   ObjectSetInteger( 0, "Finalize", OBJPROP_CORNER, CORNER_LEFT_LOWER );
   ObjectSetInteger( 0, "Finalize", OBJPROP_XDISTANCE, 100 );
   ObjectSetInteger( 0, "Finalize", OBJPROP_YDISTANCE, 50 );
   ObjectSetInteger( 0, "Finalize", OBJPROP_XSIZE, 150 );
   ObjectSetInteger( 0, "Finalize", OBJPROP_YSIZE, 30 );
   ObjectSetString( 0, "Finalize", OBJPROP_TEXT, "Finalize" );
   ObjectSetInteger( 0, "Finalize", OBJPROP_COLOR, clrBlue );
//--- принудительно обновим график, чтобы кнопки отрисовались немедленно
   ChartRedraw();
}

bool ClosePosition( bool async = true )
{
   int numPos = PositionsTotal();
   PrintFormat( "Positions number: %d", numPos );
   
   if( PositionSelect( _Symbol ) )
      Print( "PositionSelect returned true" );
   else
      Print( "PositionSelect returned false" );
      
   if( numPos == 0 )
      return true;
       
   double volume = PositionGetDouble( POSITION_VOLUME );
   uint posType = PositionGetInteger( POSITION_TYPE );

   MqlTradeRequest req={0};
   req.action      = TRADE_ACTION_DEAL;
   req.symbol      = _Symbol;
   req.magic       = MagicNumber;
   req.volume      = volume;
   switch( posType )
   {
   case POSITION_TYPE_BUY:
      req.type = ORDER_TYPE_SELL;
      req.price = SymbolInfoDouble( req.symbol, SYMBOL_BID );
      break;
   case POSITION_TYPE_SELL:
      req.type = ORDER_TYPE_BUY;
      req.price = SymbolInfoDouble( req.symbol, SYMBOL_ASK );
      break;
   default:
      Print( "Wrong position type" );
      return true;
   }
   req.deviation   = 3;
   req.comment     = "Closing opened position";
   MqlTradeResult  res={0};
   if( !OrderSend( req, res ) )
   {
      Print(__FUNCTION__,": ошибка ",GetLastError(),", retcode = ",res.retcode);
      return false;
   }
   return true;
}
 
surava:

Vladimir, obrigado pela sua resposta rápida!

Aqui está a informação sobre o terminal:


Aqui está o código (apenas agora começou a aprender como funcionam as funções de negociação):

Num relance - remover enquanto.
 
Karputov Vladimir:
À primeira vista, remover enquanto.
Não custa nada removê-lo, mas é óbvio que o problema está noutro lugar. Quanto a mim - melhor o problema com uma posição não fechada a tempo resultará num loop infinito do que numa perda, que talvez nem se consiga notar de imediato).
 

Estou a ver qual é o problema. Basta explicar esta lógica, por favor, porque é que o manipulador de botões é afectado pela presença/ausência da linha

input bool DescriptionModeFull=true;

???

 

Parece que não se trata apenas desta linha. Terei de fazer mais alguma dança para que o metatarraxador torto funcione correctamente...

Isto é, no meu exemplo funcionou bem, mas no programa real não funcionou((

 
surava:

Isto é, no meu exemplo funcionou bem, mas no programa real não funcionou((

Talvez haja uma dobra noutro lugar? Não irá muito longe com essa abordagem

 
surava:

Parece que não se trata apenas desta linha. Terei de fazer mais alguma dança para que o metatarraxador torto funcione correctamente...

Isto é, no meu exemplo funcionou bem, mas no programa real não funcionou((

Talvez o meu pandeiro não seja suficientemente grande?
Razão: