Группа "Стол заказов MQL"

Рейтинг 2081



РЕКОМЕНДУЮ



Индикатор Bollinger bands с оповещением одной свечи для МТ4

Здравствуйте! Возможно добавить в индикатор Bollinger bands такую «фишку», как распознавание одной одиноко стоящей свечи закрывшейся полностью за линиями Bollinger'a и не касаясь их никакими частями своего тела с последующим оповещением во время формирования этой свечи об этом в виде окошка с алертом и указанием валютной пары, а если бы ещё эта свеча и цвет меняла *relax* 
bands.mq4 (4 Kb)
1 svecha.PNG (30 Kb)
1 svecha(2).PNG (28 Kb)
1 svecha (3).PNG (26 Kb)
1 svecha (4).PNG (28 Kb)
1 svecha (5).PNG (26 Kb)
1 svecha (7).PNG (30 Kb)
1 svecha (8).PNG (28 Kb)
  • +1
  • Просмотров: 12619
  • 1 марта 2016, 00:46
  • Shiva
Понравилcя материал? Не забудьте поставить плюс и поделиться в социальной сети!

Вступите в группу "Стол заказов MQL", чтобы следить за обновлениями
ПРИСОЕДИНИТЬСЯ К ГРУППЕ
присоединиться
Следующая запись в группе  
Доработка советника
29 февраля 2016
01 марта 2016

Комментарии (8)

+
0
Добавил для наглядности :) 





avatar

  34  AM2 Сообщений: 15862 - Андрей

  • 1 марта 2016, 08:32
+
+1
Сделал:




//+------------------------------------------------------------------+
//|                                                        Bands.mq4 |
//|                   Copyright 2005-2014, MetaQuotes Software Corp. |
//|                                              http://www.mql4.com |
//+------------------------------------------------------------------+
#property copyright   "2005-2014, MetaQuotes Software Corp."
#property link        "http://www.mql4.com"
#property description "Bollinger Bands"
#property strict

#include <MovingAverages.mqh>

#property indicator_chart_window
#property indicator_buffers 3
#property indicator_color1 LightSeaGreen
#property indicator_color2 LightSeaGreen
#property indicator_color3 LightSeaGreen
//--- indicator parameters
input int    InpBandsPeriod=20;      // Bands Period
input int    InpBandsShift=0;        // Bands Shift
input double InpBandsDeviations=1.0; // Bands Deviations
//--- buffers
double ExtMovingBuffer[];
double ExtUpperBuffer[];
double ExtLowerBuffer[];
double ExtStdDevBuffer[];

int b=0,s=0;
datetime t=0;
//+------------------------------------------------------------------+
//| Custom indicator initialization function                         |
//+------------------------------------------------------------------+
int OnInit(void)
  {
//--- 1 additional buffer used for counting.
   IndicatorBuffers(4);
   IndicatorDigits(Digits);
//--- middle line
   SetIndexStyle(0,DRAW_LINE);
   SetIndexBuffer(0,ExtMovingBuffer);
   SetIndexShift(0,InpBandsShift);
   SetIndexLabel(0,"Bands SMA");
//--- upper band
   SetIndexStyle(1,DRAW_LINE);
   SetIndexBuffer(1,ExtUpperBuffer);
   SetIndexShift(1,InpBandsShift);
   SetIndexLabel(1,"Bands Upper");
//--- lower band
   SetIndexStyle(2,DRAW_LINE);
   SetIndexBuffer(2,ExtLowerBuffer);
   SetIndexShift(2,InpBandsShift);
   SetIndexLabel(2,"Bands Lower");
//--- work buffer
   SetIndexBuffer(3,ExtStdDevBuffer);
//--- check for input parameter
   if(InpBandsPeriod<=0)
     {
      Print("Wrong input parameter Bands Period=",InpBandsPeriod);
      return(INIT_FAILED);
     }
//---
   SetIndexDrawBegin(0,InpBandsPeriod+InpBandsShift);
   SetIndexDrawBegin(1,InpBandsPeriod+InpBandsShift);
   SetIndexDrawBegin(2,InpBandsPeriod+InpBandsShift);
//--- initialization done
   return(INIT_SUCCEEDED);
  }
//+------------------------------------------------------------------+
//| Bollinger Bands                                                  |
//+------------------------------------------------------------------+
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[])
  {
   int i,pos;
//---
   if(rates_total<=InpBandsPeriod || InpBandsPeriod<=0)
      return(0);
//--- counting from 0 to rates_total
   ArraySetAsSeries(ExtMovingBuffer,false);
   ArraySetAsSeries(ExtUpperBuffer,false);
   ArraySetAsSeries(ExtLowerBuffer,false);
   ArraySetAsSeries(ExtStdDevBuffer,false);
   ArraySetAsSeries(close,false);

//--- initial zero
   if(prev_calculated<1)
     {
      for(i=0; i<InpBandsPeriod; i++)
        {
         ExtMovingBuffer[i]=EMPTY_VALUE;
         ExtUpperBuffer[i]=EMPTY_VALUE;
         ExtLowerBuffer[i]=EMPTY_VALUE;
        }
     }
//--- starting calculation
   if(prev_calculated>1)
      pos=prev_calculated-1;
   else
      pos=0;
//--- main cycle
   for(i=pos; i<rates_total && !IsStopped(); i++)
     {
      //--- middle line
      ExtMovingBuffer[i]=SimpleMA(i,InpBandsPeriod,close);
      //--- calculate and write down StdDev
      ExtStdDevBuffer[i]=StdDev_Func(i,close,ExtMovingBuffer,InpBandsPeriod);
      //--- upper line
      ExtUpperBuffer[i]=ExtMovingBuffer[i]+InpBandsDeviations*ExtStdDevBuffer[i];
      //--- lower line
      ExtLowerBuffer[i]=ExtMovingBuffer[i]-InpBandsDeviations*ExtStdDevBuffer[i];
      //---
     }
/*
   Comment("\n UP1: ",ExtUpperBuffer[rates_total-1],
           "\n DN1: ",ExtLowerBuffer[rates_total-1],
           "\n CL1: ",close[rates_total-1],
           "\n LOW1: ",low[1]);
*/
   double up=ExtUpperBuffer[rates_total-2];
   double dn=ExtLowerBuffer[rates_total-2];
   double cl=close[rates_total-2];
   
   if(t!=time[0])
     {
      if(cl>up && low[1]>up && s==0)  {Alert(Symbol()+" Одинокая свеча выше границы!!!");s++;b=0;}
      if(cl<dn && high[1]<dn && b==0) {Alert(Symbol()+" Одинокая свеча ниже границы!!!");b++;s=0;}
      t=time[0];
     }
//---- OnCalculate done. Return new prev_calculated.
   return(rates_total);
  }
//+------------------------------------------------------------------+
//| Calculate Standard Deviation                                     |
//+------------------------------------------------------------------+
double StdDev_Func(int position,const double &price[],const double &MAprice[],int period)
  {
//--- variables
   double StdDev_dTmp=0.0;
//--- check for position
   if(position>=period)
     {
      //--- calcualte StdDev
      for(int i=0; i<period; i++)
         StdDev_dTmp+=MathPow(price[position-i]-MAprice[position],2);
      StdDev_dTmp=MathSqrt(StdDev_dTmp/period);
     }
//--- return calculated value
   return(StdDev_dTmp);
  }
//+------------------------------------------------------------------+

avatar

  34  AM2 Сообщений: 15862 - Андрей

  • 1 марта 2016, 09:38
+
0
Спасибо. Протестирую.
avatar

  10  Shiva Автор Сообщений: 148

  • 19 марта 2016, 02:08
+
0
Спасибо.Всё отлично работает, а можно ещё пару дополнений внести?*victory* 
avatar

  10  Shiva Автор Сообщений: 148

  • 3 апреля 2016, 19:32
+
0
Уважаемые коллеги, а где скачать данный индикатор доработанный?
avatar

  6  Roman34 Сообщений: 25 - Blesk34

  • 1 августа 2019, 06:27
+
0
код индикатора выложен выше *razdacha* 
avatar

  22  igrun Сообщений: 1569 - igrun

  • 1 августа 2019, 19:45
+
0
Уважаемый разработчик, могу ли связаться с вами, напишите пожалуйста на почту, хочу обсудить с вами один индикатор и внесения в него одного изменения, в долгу не останусь.Почта risk555@mail.ru
avatar

  6  Roman34 Сообщений: 25 - Blesk34

  • 1 августа 2019, 20:22
+
0
платно не делаю. по остальным вопросам пишите в стол заказов
avatar

  34  AM2 Сообщений: 15862 - Андрей

  • 1 августа 2019, 21:31

Зарегистрируйтесь или авторизуйтесь, чтобы оставить комментарий
Начать торговлю с Альпари