Domande dai principianti MQL5 MT5 MetaTrader 5 - pagina 470

 
Artyom Trishkin:

Perché i tuoi capelli sono crespi? Forse è lo shampoo sbagliato? ;)

Cosa c'è che non va? Tre buffer, ognuno responsabile di un diverso periodo di calcolo.

Cosa c'è che non va?

https://www.mql5.com/ru/forum/1111/page1442#comment_2012053 - descritto in dettaglio lì. :)
Riguardo ai capelli - sono quasi spariti. :)))
 
Mike:
https://www.mql5.com/ru/forum/1111/page1442#comment_2012053 - ha descritto tutto in dettaglio. :)
Riguardo ai capelli - sono quasi spariti. :)))

Primo: tutti i parametri degli IMA separati in una finestra coincidono con i parametri degli IMA creati da un indicatore con tre buffer?

Secondo: quando hai sovrapposto le AMI in una finestra l'una sull'altra, nel parametro "Apply to" (o qualcosa del genere - non ricordo esattamente) cosa hai selezionato?

Il gatto dice che può condividere il suo pelo - non gli dispiace ;)

 

La documentazione della Guida di riferimento MQL5Fondamenti del linguaggioVariabiliVariabili di ingresso

è dato come esempio:


#property script_show_inputs 

//--- input parameters
input dayOfWeek swapday=W;

//--- day of week
enum dayOfWeek 
  {
   S=0,     // Sunday
   M=1,     // Monday
   T=2,     // Tuesday
   W=3,     // Wednesday
   Th=4,    // Thursday
   Fr=5,    // Friday,
   St=6,    // Saturday
  };

//Вставляю в советник, только без #property script_show_inputs
//Компилятор ругается:
//'dayOfWeek' - declaration without type   54   7

//Испавляю на:
input int dayOfWeek swapday=W;
//Компилятор пишет шибку:
//'swapday' - semicolon expected                   54   21

Potete dirmi per favore qual è il problema?


 
Leo59:

La documentazione della Guida di riferimento MQL5Fondamenti del linguaggioVariabiliVariabili di ingresso

è dato come esempio:

Potete dirmi per favore qual è il problema?

enum dayOfWeek dovrebbe essere sopra l'input dayOfWeek. La seconda ortografia non è affatto corretta. Inoltre un consiglio: non scrivete tale enumerazione, il modificatore W sarà estremamente difficile da trovare in seguito.
 
Vasiliy Sokolov:
enum dayOfWeek dovrebbe essere superiore all'input dayOfWeek. La seconda variante di scrittura non è affatto corretta. Inoltre un consiglio - non scrivere tale enumerazione, il modificatore W sarà estremamente difficile da trovare in seguito.
GRAZIE TANTE!!!!
E io ....., per la mia semplicità, ho sollevato questa linea qui sopra.
Grazie!
 

Compagni, aiutate l'allarme per favore.

Volevo fare in modo che se la barra precedente è più di 250 pip, allora appare una notifica e un segnale acustico, il problema è che suona ogni 2-3 secondi... Come possiamo fare in modo che l'indicatore aspetti 10 minuti, o un avviso fino al prossimo segnale

input int Bar     = 1;
input int pips    = 250;
input bool alert  = true;
input bool sound  = true;
//+------------------------------------------------------------------+
//| expert initialization function                                   |
//+------------------------------------------------------------------+

//+------------------------------------------------------------------+
//| expert start function                                            |
//+------------------------------------------------------------------+


int start()
  {
  //alert criteria
int buy_o, sell_o, buy_go=0, sell_go=0;

int dig;
if (Digits==3)(dig=100);
if (Digits==5)(dig=10000);

double buy_bar=(High[Bar]-Low[Bar]);if(buy_bar>0 && Open[Bar]>Close[Bar]){buy_o=buy_bar*dig;}
if(buy_o>pips){buy_go=1;}

double sell_bar=(High[Bar]-Low[Bar]);if(sell_bar>0 && Open[Bar]<Close[Bar]){sell_o=sell_bar*dig;}
if(sell_o>pips){sell_go=1;}
Comment (buy_o,"_",sell_o);   
 if (buy_go==1) //Signal Buy
 {

if(alert==TRUE){Alert("Покупка: ",Symbol(),", Пунктов:" ,buy_o);}
if(sound==TRUE){PlaySound("alert.wav");} Comment("buy");
 }
 if (sell_go==1) //Signal Sell
 {
if(alert==TRUE){Alert("Продажа: ",Symbol(),", Пунктов:" ,sell_o);}
if(sound==TRUE){PlaySound("alert.wav");} Comment ("sell");
 }




//----------
return(0);
  }
 

Potete dirmi come passare correttamente gli array per riferimento in una funzione?

#define   SIZE     50 
double   MACD[SIZE];         // Статический массив

int start()
   {
    Fun(     );
   }

int Fun(const double &MACD[    ])
   {
    for(int i=1; i<SIZE; i++)
        {
         if(MACD[i]>MACD[i-1] && MACD[i]>MACD[i+1])
              return(1);
        }
   }
 
Leo59:

Potete dirmi come passare correttamente gli array per riferimento in una funzione?

#define   SIZE     50 
double   MACD[SIZE];         // Статический массив

int start()
   {
    // Необходимо перед вызовом функции заполнить массив данными
    Fun(MACD);
   }

int Fun(const double & _array[])
   {
    for(int i=1; i<ArraySize(_array)-1; i++)
        {
         if(_array[i]>_array[i-1] && _array[i]>_array[i+1])
              return(1);
        }
   return(0);
   }
Si può fare così
 
Victor Nikolaev:
Si può fare così.
Grazie!!!!
 
Artyom Trishkin:

Primo: tutti i parametri degli IMA separati in una finestra coincidono con i parametri degli IMA creati da un indicatore con tre buffer?

Secondo: quando hai sovrapposto i MAH in una finestra, cosa hai scelto nel parametro "Apply to" (o qualcosa di simile - non ricordo esattamente)?

Il gatto dice che può condividere il suo pelo - non gli dispiace ;)

1. Tutta la partita.
2. Non esiste un tale parametro.
Mi è stato detto in un altro thread che questo problema è irrisolvibile in MT4. :(