Se você ainda não conheceu o Indicador de Nível, está perdendo uma ferramenta poderosa para suas operações no MetaTrader 4. Quando o nível de ativação (trigLv) que você definiu nas configurações é cruzado dentro de um determinado intervalo (deviation), o indicador enviará uma notificação para o seu dispositivo móvel, desde que a opção de notificação esteja ativada. Além disso, ele emite um alerta sonoro se a opção de alerta estiver habilitada. Os níveis de ativação e os limites de desvio são destacados com linhas horizontais, que você pode personalizar em termos de estilo, cor e espessura. Isso permite que você adicione várias cópias do indicador no gráfico e receba sinais com base em suas interseções.
Vale lembrar que o nível trigLv é acionado apenas uma vez por barra. Para que o acionamento ocorra novamente, é necessário que a próxima barra abra. Essa mecânica ajuda a evitar gatilhos excessivos a cada tick.

//+------------------------------------------------------------------+ //| LevelIndicator.mq4 | //| Copyright 2022, © Cyberdev | //| https://www.mql5.com/en/users/cyberdev/seller | //+------------------------------------------------------------------+ #property copyright "Copyright 2022, © Cyberdev" #property link "https://www.mql5.com/en/users/cyberdev/seller" #property version "1.00" #property strict #property indicator_chart_window #property indicator_plots 0 #include <ChartObjects\ChartObjectsLines.mqh> input bool alert = true; // usar alerta input bool notification = true; // usar notificações push input double trigLv = 0.0; // nível de ativação input int deviation = 30; // desvio em pontos a partir de trigLv input int lineWidth = 1; // espessura da linha input ENUM_LINE_STYLE lineStyle = STYLE_SOLID; // estilo da linha input color lineColor = clrMediumSpringGreen; // cor da linha input color inactivityColor = clrLightGray; // cor de inatividade CChartObjectHLine lv, dvH, dvL; bool equal(double _v1, double _v2, double _epsilon) { return fabs(_v1 - _v2) <= fabs(_epsilon); } //+------------------------------------------------------------------+ //| Função de inicialização do indicador personalizado | //+------------------------------------------------------------------+ int OnInit() { string name; double dv; color color_; name = "alert.lv-"; dv = deviation * SymbolInfoDouble(NULL, SYMBOL_POINT); color_ = (alert || notification) ? lineColor : inactivityColor; for (int n = 0; n <= INT_MAX && !IsStopped(); n++) { if (ObjectFind(0, name + (string)n) != 0) { if (!lv.Create(0, name + (string)n, 0, trigLv)) return INIT_FAILED; lv.Width(lineWidth); lv.Style(lineStyle); lv.Color(color_); dvH.Create(0, "alert.dvH-" + (string)n, 0, trigLv + dv); dvH.Width(1); dvH.Style(STYLE_DOT); dvH.Color(color_); dvL.Create(0, "alert.dvL-" + (string)n, 0, trigLv - dv); dvL.Width(1); dvL.Style(STYLE_DOT); dvL.Color(color_); break; } } if (!alert && !notification) Print("Indicador de Nível. Nível ", lv.Price(0), " está inativo!"); if (trigLv == 0.0) Alert("Indicador de Nível. Defina o parâmetro \"trigLv\" para o valor desejado!"); return(INIT_SUCCEEDED); } void OnDeinit(const int reason) { //lv.Delete(); //dvH.Delete(); //dvL.Delete(); } //+------------------------------------------------------------------+ //| Função de iteração do indicador personalizado | //+------------------------------------------------------------------+ int OnCalculate(const int rates_total, const int prev_calculated, const datetime &time[], const double &open[], const double &high[], const double &low[], const double &close[], const long &tick_volume[], const long &volume[], const int &spread[] ) { static bool triggered = false; static datetime time_ = 0; if (!alert && !notification) return rates_total; if (equal(lv.Price(0), close[0], deviation * SymbolInfoDouble(NULL, SYMBOL_POINT))) { if (time_ != time[0]) time_ = time[0]; else return rates_total; if (!triggered) { if (alert) Alert("Indicador de Nível. Nível ", NormalizeDouble(lv.Price(0), (int)SymbolInfoInteger(NULL, SYMBOL_DIGITS)), " acionado!"); if (notification) SendNotification("Indicador de Nível. Nível " + (string)NormalizeDouble(lv.Price(0), (int)SymbolInfoInteger(NULL, SYMBOL_DIGITS)) + " acionado!"); } triggered = true; } else triggered = false; return(rates_total); } //+------------------------------------------------------------------+
Publicações relacionadas
- Calendário Econômico: Monitoramento e Cache para Testes de Estratégia no MetaTrader 5
- Buffers Horários para Coleta de Dados no MetaTrader 5
- Níveis Históricos: O Indicador Essencial para MetaTrader 5
- EquiPeak Drawdown Tracker: Controle Eficiente para Seus EAs no MetaTrader 5
- Painel Gráfico: Mostre a Tendência Atual em Todos os Tempos no MetaTrader 4