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

Рейтинг 2081



РЕКОМЕНДУЮ



Здравствуйте. Если возможно, установите алерт с визуальным оповещением при смене цвета индикатора.

Здравствуйте. Индикатор отображается несколькими линиями. Некоторые из них я отключаю(скрин прилагаю). Возможно ли сделать, когда при смене цвета, как на скрине, появляется окошко с наименованием валюты и звучит алерт? Спасибо. Corridor RSX.mq4 (7 Kb)
  • +1
  • Просмотров: 5704
  • 5 мая 2015, 12:08
  • tat
Понравилcя материал? Не забудьте поставить плюс и поделиться в социальной сети!

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

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

+
0
не прикрепился индикатор
avatar

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

  • 5 мая 2015, 13:10
+
0
У меня такое часто случалось — здесь cut ставится посередине названия индикатора.
В этих случаях я просила Bishop-а или в чате или в личке поправить cut и все вставало на свои места.
avatar

  27  Oxy Сообщений: 3418 - ..ιllιlι.lι.ιllι.ιlι..

  • 5 мая 2015, 13:18
+
0
Сейчас попрошу. Благодарю.
avatar

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

  • 5 мая 2015, 13:22
+
0
Поправил
avatar

  45  Bishop Сообщений: 5719 - АЛЬФАХАМЕЦ-Машковод

  • 5 мая 2015, 14:43
+
0
благодарю
avatar

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

  • 5 мая 2015, 14:46
+
0
пытаюсь, но почему-то не прикрепляется
avatar

  2  tat Автор Сообщений: 31

  • 5 мая 2015, 13:13
+
0
могу сам скачать по ссылке
avatar

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

  • 5 мая 2015, 13:16
+
0
Спасибо. Сейчас ссылку поищу.
Редактирован: 5 мая 2015, 13:32
avatar

  2  tat Автор Сообщений: 31

  • 5 мая 2015, 13:31
+
0
Пришлось создать новый запрос, только так удалось загрузить индикатор. Извините.
avatar

  2  tat Автор Сообщений: 31

  • 5 мая 2015, 13:56
+
0
В этом индикаторе 12 ошибок выдает при компиляции.
avatar

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

  • 5 мая 2015, 14:00
+
0
Нужен индикатор который компилируется без ошибок.
avatar

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

  • 5 мая 2015, 14:06
+
0
Я тут немного исправил критические ошибки индикатора, если это Вам поможет:
//------------------------------------------------------------------
#property copyright "mladen"
#property link      "mladenfx@gmail.com"
#property strict
//------------------------------------------------------------------
#property indicator_separate_window
#property indicator_buffers    5
#property indicator_color1     Green
#property indicator_color2     DarkOrange
#property indicator_color3     LimeGreen
#property indicator_color4     Orange
#property indicator_color5     Orange
#property indicator_width1     2
#property indicator_width2     2
#property indicator_width3     2
#property indicator_width4     2
#property indicator_width5     2

//
//
//
//
//

extern string TimeFrame   = "Current time frame";
extern int    Length      = 32;
extern int    Price       = PRICE_TYPICAL;
extern double HighLowStep = 0.5;

//
//
//
//
//

double rsx[];
double rsxDa[];
double rsxDb[];
double slope[];
double max[];
double min[];

//
//
//
//
//

string indicatorFileName;
int    timeFrame;
bool   returnBars;
bool   calculateValue;

//-------------------------------------------------------------------
//
//-------------------------------------------------------------------
//
//
//
//
//

int init()
{
   IndicatorBuffers(6);
      SetIndexBuffer(0,max); SetIndexEmptyValue(0,0);
      SetIndexBuffer(1,min);
      SetIndexBuffer(2,rsx);
      SetIndexBuffer(3,rsxDa);
      SetIndexBuffer(4,rsxDb);
      SetIndexBuffer(5,slope);
      
       //
       //
       //
       //
       //
     
        indicatorFileName = WindowExpertName();
        calculateValue    = (TimeFrame=="calculateValue"); if (calculateValue) return(0);
        returnBars        = (TimeFrame=="returnBars");     if (returnBars)     return(0);
        timeFrame         = stringToTimeFrame(TimeFrame); 
        
      //
      //
      //
      //
      // 
     
   IndicatorShortName(timeFrameToString(timeFrame)+"  Rsx ("+IntegerToString(Length)+")");
return(0);
}

//
//
//
//
//

int deinit() { return(0); }

//-------------------------------------------------------------------
//
//-------------------------------------------------------------------
//
//
//
//
//

double wrkBuffer[][13];

int start()
{
   int i,r,counted_bars=IndicatorCounted();
      if(counted_bars<0) return(-1);
      if(counted_bars>0) counted_bars--;
         int limit = MathMin(Bars-counted_bars,Bars-1);
         if (returnBars) { rsx[0] = limit+1; return(0); }
         
   //
   //
   //
   //
   //
   
   if (calculateValue || timeFrame==Period())
   {
     double Kg = (3.0)/(2.0+Length); 
     double Hg = 1.0-Kg;
     if (slope[limit]==-1) CleanPoint(limit,rsxDa,rsxDb);
     if (ArrayRange(wrkBuffer,0) != Bars) ArrayResize(wrkBuffer,Bars);
     for(i=limit, r=Bars-i-1; i>=0; i--, r++)
     {
        wrkBuffer[r][12] = iMA(NULL,0,1,0,MODE_SMA,Price,i);
        if (i==(Bars-1)) { for (int c=0; c<12; c++) wrkBuffer[r][c] = 0; continue; }  

        //
        //
        //
        //
        //
      
        double mom = wrkBuffer[r][12]-wrkBuffer[r-1][12];
        double moa = MathAbs(mom);
        for (int k=0; k<3; k++)
        {
           int kk = k*2;
              wrkBuffer[r][kk+0] = Kg*mom                + Hg*wrkBuffer[r-1][kk+0];
              wrkBuffer[r][kk+1] = Kg*wrkBuffer[r][kk+0] + Hg*wrkBuffer[r-1][kk+1]; mom = 1.5*wrkBuffer[r][kk+0] - 0.5 * wrkBuffer[r][kk+1];
              wrkBuffer[r][kk+6] = Kg*moa                + Hg*wrkBuffer[r-1][kk+6];
              wrkBuffer[r][kk+7] = Kg*wrkBuffer[r][kk+6] + Hg*wrkBuffer[r-1][kk+7]; moa = 1.5*wrkBuffer[r][kk+6] - 0.5 * wrkBuffer[r][kk+7];
        }
        if (moa != 0)
             rsx[i] = MathMax(MathMin((mom/moa+1.0)*50.0,100.00),0.00); 
        else rsx[i] = 50;
        max[i] = MathMax(rsx[i],max[i+1]-HighLowStep);
        min[i] = MathMin(rsx[i],min[i+1]+HighLowStep);
      
        //
        //
        //
        //
        //
      
        rsxDa[i] = EMPTY_VALUE;
        rsxDb[i] = EMPTY_VALUE;
        slope[i] = slope[i+1];
            if (rsx[i]>rsx[i+1])  slope[i] = 1;
            if (rsx[i]<rsx[i+1])  slope[i] =-1;
            if (slope[i]==-1) PlotPoint(i,rsxDa,rsxDb,rsx); 
     }      
     return(0);
     }
     
     //
     //
     //
     //
     //
   
     limit =(int) MathMax(limit,MathMin(Bars-1,iCustom(NULL,timeFrame,indicatorFileName,"returnBars",0,0)*timeFrame/Period()));
     if (slope[limit]==-1) CleanPoint(limit,rsxDa,rsxDb);
     for (i=limit;i>=0; i--)
     {
        int y = iBarShift(NULL,timeFrame,Time[i]);
           min[i]   = iCustom(NULL,timeFrame,indicatorFileName,"calculateValue",Length,Price,HighLowStep,0,y);
           max[i]   = iCustom(NULL,timeFrame,indicatorFileName,"calculateValue",Length,Price,HighLowStep,1,y);
           rsx[i]   = iCustom(NULL,timeFrame,indicatorFileName,"calculateValue",Length,Price,HighLowStep,2,y);
           slope[i] = iCustom(NULL,timeFrame,indicatorFileName,"calculateValue",Length,Price,HighLowStep,5,y);
           rsxDa[i] = EMPTY_VALUE;
           rsxDb[i] = EMPTY_VALUE;
           if (slope[i]==-1) PlotPoint(i,rsxDa,rsxDb,rsx);
     }
return(0);
}

//-------------------------------------------------------------------
//
//-------------------------------------------------------------------
//
//
//
//
//

void CleanPoint(int i,double& first[],double& second[])
{
   if ((second[i]  != EMPTY_VALUE) && (second[i+1] != EMPTY_VALUE))
        second[i+1] = EMPTY_VALUE;
   else
      if ((first[i] != EMPTY_VALUE) && (first[i+1] != EMPTY_VALUE) && (first[i+2] == EMPTY_VALUE))
          first[i+1] = EMPTY_VALUE;
}

//
//
//
//
//

void PlotPoint(int i,double& first[],double& second[],double& from[])
{
   if (first[i+1] == EMPTY_VALUE)
      {
         if (first[i+1] == EMPTY_VALUE) {
                first[i]   = from[i];
                first[i+1] = from[i+1];
                second[i]  = EMPTY_VALUE;
            }
         else {
                second[i]   =  from[i];
                second[i+1] =  from[i+1];
                first[i]    = EMPTY_VALUE;
            }
      }
   else
      {
         first[i]  = from[i];
         second[i] = EMPTY_VALUE;
      }
}

//-------------------------------------------------------------------
//
//-------------------------------------------------------------------
//
//
//
//
//

string sTfTable[] = {"M1","M5","M15","M30","H1","H4","D1","W1","MN"};
int    iTfTable[] = {1,5,15,30,60,240,1440,10080,43200};

//
//
//
//
//

int stringToTimeFrame(string tfs)
{
   tfs = stringUpperCase(tfs);
   for (int i=ArraySize(iTfTable)-1; i>=0; i--)
         if (tfs==sTfTable[i] || tfs==""+IntegerToString(iTfTable[i])) return(MathMax(iTfTable[i],Period()));
                                                      return(Period());
}
string timeFrameToString(int tf)
{
   for (int i=ArraySize(iTfTable)-1; i>=0; i--) 
         if (tf==iTfTable[i]) return(sTfTable[i]);
                              return("");
}

//
//
//
//
//

string stringUpperCase(string str)
{
   string   s = str;

   for (int length=StringLen(str)-1; length>=0; length--)
   {
      int char1 = StringGetChar(s, length);
         if((char1 > 96 && char1 < 123) || (char1 > 223 && char1 < 256))
                     s = StringSetChar(s, length, char1 - 32);
         else if(char1 > -33 && char1 < 0)
                     s = StringSetChar(s, length, char1 + 224);
   }
   return(s);
}
avatar

  18  Andrju81 Сообщений: 245 - Андрей

  • 5 мая 2015, 15:23
+
0
Благодарю, но я тоже поправил, но внешний вид индикатора изменился :) 
avatar

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

  • 5 мая 2015, 15:27
+
0
Просто надо отключит отображения нулевого и первого буфера(линии) как на скрине выше, оставить бесцветными, тогда получается как надо!?...*good* 
avatar

  18  Andrju81 Сообщений: 245 - Андрей

  • 5 мая 2015, 15:33
+
+1
У меня поправлен код без ошибок и предупреждений:
Сейчас уберу линни и можно делать. *yes* 


//+------------------------------------------------------------------+
//|                                                 Corridor_RSX.mq4 |
//+------------------------------------------------------------------+
//------------------------------------------------------------------
#property copyright "mladen"
#property link      "mladenfx@gmail.com"
//------------------------------------------------------------------
#property indicator_separate_window
#property indicator_buffers    5
#property indicator_color1     Green
#property indicator_color2     DarkOrange
#property indicator_color3     LimeGreen
#property indicator_color4     Orange
#property indicator_color5     Orange
#property indicator_width1     2
#property indicator_width2     2
#property indicator_width3     2
#property indicator_width4     2
#property indicator_width5     2

//
//
//
//
//

extern string TimeFrame   = "Current time frame";
extern int    Length      = 32;
extern int    Price       = PRICE_TYPICAL;
extern double HighLowStep = 0.5;

//
//
//
//
//

double rsx[];
double rsxDa[];
double rsxDb[];
double slope[];
double max[];
double min[];

//
//
//
//
//

string indicatorFileName;
int    timeFrame;
bool   returnBars;
bool   calculateValue;
//-------------------------------------------------------------------
//
//-------------------------------------------------------------------
//
//
//
//
//

int init()
  {
   IndicatorBuffers(6);
   SetIndexBuffer(0,max); SetIndexEmptyValue(0,0);
   SetIndexBuffer(1,min);
   SetIndexBuffer(2,rsx);
   SetIndexBuffer(3,rsxDa);
   SetIndexBuffer(4,rsxDb);
   SetIndexBuffer(5,slope);

//
//
//
//
//

   indicatorFileName = WindowExpertName();
   calculateValue    = (TimeFrame=="calculateValue"); if(calculateValue) return(0);
   returnBars        = (TimeFrame=="returnBars");     if(returnBars)     return(0);
   timeFrame         = stringToTimeFrame(TimeFrame);

//
//
//
//
// 

   IndicatorShortName(timeFrameToString(timeFrame)+"  Rsx ("+Length+")");
   return(0);
  }

//
//
//
//
//

int deinit() { return(0); }

//-------------------------------------------------------------------
//
//-------------------------------------------------------------------
//
//
//
//
//

double wrkBuffer[][13];
//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
int start()
  {
   int i,r,counted_bars=IndicatorCounted();
   if(counted_bars<0) return(-1);
   if(counted_bars>0) counted_bars--;
   int limit=MathMin(Bars-counted_bars,Bars-1);
   if(returnBars) { rsx[0]=limit+1; return(0); }

//
//
//
//
//

   if(calculateValue || timeFrame==Period())
     {
      double Kg = (3.0)/(2.0+Length);
      double Hg = 1.0-Kg;
      if(slope[limit]==-1) CleanPoint(limit,rsxDa,rsxDb);
      if(ArrayRange(wrkBuffer,0)!=Bars) ArrayResize(wrkBuffer,Bars);
      for(i=limit,r=Bars-i-1; i>=0; i--,r++)
        {
         wrkBuffer[r][12]=iMA(NULL,0,1,0,MODE_SMA,Price,i);
         if(i==(Bars-1)) { for(int c=0; c<12; c++) wrkBuffer[r][c]=0; continue; }

         //
         //
         //
         //
         //

         double mom = wrkBuffer[r][12]-wrkBuffer[r-1][12];
         double moa = MathAbs(mom);
         for(int k=0; k<3; k++)
           {
            int kk=k*2;
            wrkBuffer[r][kk+0] = Kg*mom                + Hg*wrkBuffer[r-1][kk+0];
            wrkBuffer[r][kk+1] = Kg*wrkBuffer[r][kk+0] + Hg*wrkBuffer[r-1][kk+1]; mom = 1.5*wrkBuffer[r][kk+0] - 0.5 * wrkBuffer[r][kk+1];
            wrkBuffer[r][kk+6] = Kg*moa                + Hg*wrkBuffer[r-1][kk+6];
            wrkBuffer[r][kk+7] = Kg*wrkBuffer[r][kk+6] + Hg*wrkBuffer[r-1][kk+7]; moa = 1.5*wrkBuffer[r][kk+6] - 0.5 * wrkBuffer[r][kk+7];
           }
         if(moa!=0)
            rsx[i] = MathMax(MathMin((mom/moa+1.0)*50.0,100.00),0.00);
         else rsx[i] = 50;
         max[i] = MathMax(rsx[i],max[i+1]-HighLowStep);
         min[i] = MathMin(rsx[i],min[i+1]+HighLowStep);

         //
         //
         //
         //
         //

         rsxDa[i] = EMPTY_VALUE;
         rsxDb[i] = EMPTY_VALUE;
         slope[i] = slope[i+1];
         if(rsx[i]>rsx[i+1])  slope[i] = 1;
         if(rsx[i]<rsx[i+1])  slope[i] =-1;
         if(slope[i]==-1) PlotPoint(i,rsxDa,rsxDb,rsx);
        }
      return(0);
     }

//
//
//
//
//

   limit=MathMax(limit,MathMin(Bars-1,iCustom(NULL,timeFrame,indicatorFileName,"returnBars",0,0)*timeFrame/Period()));
   if(slope[limit]==-1) CleanPoint(limit,rsxDa,rsxDb);
   for(i=limit;i>=0; i--)
     {
      int y=iBarShift(NULL,timeFrame,Time[i]);
      min[i]   = iCustom(NULL,timeFrame,indicatorFileName,"calculateValue",Length,Price,HighLowStep,0,y);
      max[i]   = iCustom(NULL,timeFrame,indicatorFileName,"calculateValue",Length,Price,HighLowStep,1,y);
      rsx[i]   = iCustom(NULL,timeFrame,indicatorFileName,"calculateValue",Length,Price,HighLowStep,2,y);
      slope[i] = iCustom(NULL,timeFrame,indicatorFileName,"calculateValue",Length,Price,HighLowStep,5,y);
      rsxDa[i] = EMPTY_VALUE;
      rsxDb[i] = EMPTY_VALUE;
      if(slope[i]==-1) PlotPoint(i,rsxDa,rsxDb,rsx);
     }
   return(0);
  }
//-------------------------------------------------------------------
//
//-------------------------------------------------------------------
//
//
//
//
//

void CleanPoint(int i,double &first[],double &second[])
  {
   if((second[i]  != EMPTY_VALUE) &&(second[i+1] != EMPTY_VALUE))
      second[i+1]= EMPTY_VALUE;
   else
   if((first[i] != EMPTY_VALUE) &&(first[i+1] != EMPTY_VALUE) &&(first[i+2]== EMPTY_VALUE))
                  first[i+1]= EMPTY_VALUE;
  }
//
//
//
//
//

void PlotPoint(int i,double &first[],double &second[],double &from[])
  {
   if(first[i+1]==EMPTY_VALUE)
     {
      if(first[i+2]==EMPTY_VALUE) 
        {
         first[i]   = from[i];
         first[i+1] = from[i+1];
         second[i]  = EMPTY_VALUE;
        }
      else 
        {
         second[i]   =  from[i];
         second[i+1] =  from[i+1];
         first[i]    = EMPTY_VALUE;
        }
     }
   else
     {
      first[i]  = from[i];
      second[i] = EMPTY_VALUE;
     }
  }

//-------------------------------------------------------------------
//
//-------------------------------------------------------------------
//
//
//
//
//

string sTfTable[] = {"M1","M5","M15","M30","H1","H4","D1","W1","MN"};
int    iTfTable[] = {1,5,15,30,60,240,1440,10080,43200};
//
//
//
//
//

int stringToTimeFrame(string tfs)
  {
   tfs=stringUpperCase(tfs);
   for(int i=ArraySize(iTfTable)-1; i>=0; i--)
      if(tfs==sTfTable[i] || tfs==""+iTfTable[i]) return(MathMax(iTfTable[i],Period()));
   return(Period());
  }
//+------------------------------------------------------------------+
//|                                                                  |
//+------------------------------------------------------------------+
string timeFrameToString(int tf)
  {
   for(int i=ArraySize(iTfTable)-1; i>=0; i--)
      if(tf==iTfTable[i]) return(sTfTable[i]);
   return("");
  }
//
//
//
//
//

string stringUpperCase(string str)
  {
   string   s=str;

   for(int length=StringLen(str)-1; length>=0; length--)
     {
      int Char=StringGetChar(s,length);
      if((Char>96 && Char<123) || (Char>223 && Char<256))
         s=StringSetChar(s,length,Char-32);
      else if(Char>-33 && Char<0)
         s=StringSetChar(s,length,Char+224);
     }
   return(s);
  }
//+------------------------------------------------------------------+


Редактирован: 5 мая 2015, 15:37
avatar

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

  • 5 мая 2015, 15:35
+
0
Я ведь только учусь!?...*stesnitelno* 
avatar

  18  Andrju81 Сообщений: 245 - Андрей

  • 5 мая 2015, 15:42
+
0
все равно большущее спасибо! свежий взгляд очень полезен бывает!
avatar

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

  • 5 мая 2015, 15:44
+
+1
Рад был помочь!*friends* 
avatar

  18  Andrju81 Сообщений: 245 - Андрей

  • 5 мая 2015, 15:49
+
0
Сегодня явно не мой день. Что я накуралесила, у меня было 2 индикатора, рабочий и нет, я удалила рабочий… Буду искать сейчас. Извините, что отвлекла Вас. Как найду и проверю, обращусь еще раз к вам. Прошу прощения.
avatar

  2  tat Автор Сообщений: 31

  • 5 мая 2015, 14:25
+
+1
avatar

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

  • 5 мая 2015, 17:17
+
0
*good*  потестим
avatar

  16  cerber04 Сообщений: 409

  • 5 мая 2015, 22:40
+
0
БОЛЬШОЕ спасибо!
avatar

  2  tat Автор Сообщений: 31

  • 7 мая 2015, 15:19

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