SHI_SilverTrendSig

Indikátor bez bližší specifikace funkčnosti a použití. Znázorňuje vstupní signály.

 

 

//+——————————————————————+
//|                                           SHI_SilverTrendSig.mq4 |
//|          Copyright © 2003, VIAC.RU, OlegVS, GOODMAN, 2005 Shurka |
//|                                                 shforex@narod.ru |
//|                                                                  |
//|                                                                  |
//| Ďčřó ďđîăđŕěěű íŕ çŕęŕç                                          |
//+——————————————————————+
#property copyright „Copyright © 2005, Shurka“
#property link      „http://shforex.narod.ru“

#property indicator_chart_window
#property indicator_buffers 2
#property indicator_color1 Red
#property indicator_color2 Blue
#define  SH_BUY   1
#define  SH_SELL  -1

//—- Âőîäíűĺ ďŕđŕěĺňđű
extern int     AllBars=0;//How many bars should be counted. 0 – all the bars.
extern int     Otstup=30;//Step back.
extern double  Per=9;//Period.
int            SH,NB,i,UD;
double         R,SHMax,SHMin;
double         BufD[];
double         BufU[];
//+——————————————————————+
//| Ôóíęöč˙ číčöčŕëčçŕöčč                                            |
//+——————————————————————+
int init()
{
//We will write the number of the bars for which we are counting to the NB
if (Bars<allbars+per else=““ nb=“Bars-Per;“ allbars=“=0)“>    IndicatorBuffers(2);
IndicatorShortName(„SHI_SilverTrendSig“);
SetIndexStyle(0,DRAW_ARROW,0,1);
SetIndexStyle(1,DRAW_ARROW,0,1);
SetIndexArrow(0,159);
SetIndexArrow(1,159);
SetIndexBuffer(0,BufU);
SetIndexBuffer(1,BufD);
SetIndexDrawBegin(0,Bars-NB);//This indicator will be shown for NB bar only
SetIndexDrawBegin(1,Bars-NB);
ArrayInitialize(BufD,0.0);//Give a lot of „zero“ to the buffe. Otherwise it will be garbage during the changing of time frame.
ArrayInitialize(BufU,0.0);
return(0);
}
//+——————————————————————+
//| Ôóíęöč˙ äĺčíčöčŕëčçŕöčč                                          |
//+——————————————————————+
int deinit()
{
return(0);
}
//+——————————————————————+
//| Ńîáńíŕ číäčęŕňîđ                                                 |
//+——————————————————————+
int start()
{
int CB=IndicatorCounted();
/* It is the optimization option. We have the function here which restore/return the number of counted bars in very special way.
During the first indicator’s call we have 0: it is normal because it was not counted anything,
and then we receive the number of bars minus 1. For example, if the number of bars equal 100,
we will have 99. I did it especially, you may see that NB is the number of bars whioch should be counted.
You know we may throw out this parameter. But for the people who understand we may keep it. So, during the first call
of indicator this NB is the same one but during the 2dn etc calls – reducing the value up to the last bar,
That is 1 or 2 for example*/
if(CB<0) return(-1); else if(NB>Bars-CB) NB=Bars-CB;
for (SH=1;SH<nb;sh++) br=““ to=““ the=““ out=““ from=““ comb=““ chart=““ 1=““>    {
for (R=0,i=SH;i<sh+10;i++) r=““>

SHMax = High[Highest(NULL,0,MODE_HIGH,Per,SH)];
SHMin = Low[Lowest(NULL,0,MODE_LOW,Per,SH)];
if (Close[SH]<shmin+(shmax-shmin)*otstup br=““ ud=“SH_SELL;“ 100=““>       if (Close[SH]>SHMax-(SHMax-SHMin)*Otstup/100 && UD!=SH_BUY) { BufD[SH]=High[SH]+R*0.5; UD=SH_BUY; }
}
return(0);
}

Napsat komentář

Vaše emailová adresa nebude zveřejněna. Vyžadované informace jsou označeny *