Indicators Used
0
Views
0
Downloads
0
Favorites
ZigZagOnParabolic_v1
//+------------------------------------------------------------------+
//| ZigZagOnParabolic.mq5 |
//| Copyright © 2009, EarnForex |
//| http://www.earnforex.com/ |
//+------------------------------------------------------------------+
//---- àâòîðñòâî èíäèêàòîðà
#property copyright "Copyright © 2009, EarnForex"
//---- ññûëêà íà ñàéò àâòîðà
#property link "http://www.earnforex.com"
//---- íîìåð âåðñèè èíäèêàòîðà
#property version "1.01"
#property description "ZigZag on Parabolic"
//+----------------------------------------------+
//| Ïàðàìåòðû îòðèñîâêè èíäèêàòîðà |
//+----------------------------------------------+
//---- îòðèñîâêà èíäèêàòîðà â ãëàâíîì îêíå
#property indicator_chart_window
//---- äëÿ ðàñ÷¸òà è îòðèñîâêè èíäèêàòîðà èñïîëüçîâàíî 3 áóôåðà
#property indicator_buffers 3
//---- èñïîëüçîâàíî âñåãî 1 ãðàôè÷åñêîå ïîñòðîåíèå
#property indicator_plots 1
//---- â êà÷åñòâå èíäèêàòîðà èñïîëüçîâàí ZIGZAG
#property indicator_type1 DRAW_COLOR_ZIGZAG
//---- îòîáðàæåíèå ìåòêè èíäèêàòîðà
#property indicator_label1 "ZigZag"
//---- â êà÷åñòâå öâåòîâ ëèíèè èíäèêàòîðà èñïîëüçîâàíû
#property indicator_color1 clrDarkSalmon,clrDodgerBlue
//---- ëèíèÿ èíäèêàòîðà - äëèííûé ïóíêòèð
#property indicator_style1 STYLE_DASH
//---- òîëùèíà ëèíèè èíäèêàòîðà ðàâíà 1
#property indicator_width1 1
//+----------------------------------------------+
//| Âõîäíûå ïàðàìåòðû èíäèêàòîðà |
//+----------------------------------------------+
input double Step=0.02; //SAR øàã
input double Maximum=0.2; //SAR ìàêñèìóì
input bool ExtremumsShift=true; //ôëàã ñäâèãà âåðøèíû
//+----------------------------------------------+
//---- îáúÿâëåíèå äèíàìè÷åñêèõ ìàññèâîâ, êîòîðûå áóäóò â
// äàëüíåéøåì èñïîëüçîâàíû â êà÷åñòâå èíäèêàòîðíûõ áóôåðîâ
double LowestBuffer[];
double HighestBuffer[];
double ColorBuffer[];
//---- Îáúÿâëåíèå öåëûõ ïåðåìåííûõ
int EShift;
//---- Îáúÿâëåíèå öåëûõ ïåðåìåííûõ íà÷àëà îòñ÷¸òà äàííûõ
int min_rates_total;
//---- Îáúÿâëåíèå öåëûõ ïåðåìåííûõ äëÿ õåíäëîâ èíäèêàòîðîâ
int SAR_Handle;
//+------------------------------------------------------------------+
//| Custom indicator initialization function |
//+------------------------------------------------------------------+
void OnInit()
{
//---- Èíèöèàëèçàöèÿ ïåðåìåííûõ íà÷àëà îòñ÷¸òà äàííûõ
min_rates_total=1;
//---- Èíèöèàëèçàöèÿ êîíñòàíò
if(ExtremumsShift) EShift=1;
else EShift=0;
//---- ïîëó÷åíèå õåíäëà èíäèêàòîðà SAR
SAR_Handle=iSAR(NULL,0,Step,Maximum);
if(SAR_Handle==INVALID_HANDLE)Print(" Íå óäàëîñü ïîëó÷èòü õåíäë èíäèêàòîðà SAR");
//---- ïðåâðàùåíèå äèíàìè÷åñêèõ ìàññèâîâ â èíäèêàòîðíûå áóôåðû
SetIndexBuffer(0,LowestBuffer,INDICATOR_DATA);
SetIndexBuffer(1,HighestBuffer,INDICATOR_DATA);
SetIndexBuffer(2,ColorBuffer,INDICATOR_COLOR_INDEX);
//---- çàïðåò íà îòðèñîâêó èíäèêàòîðîì ïóñòûõ çíà÷åíèé
PlotIndexSetDouble(0,PLOT_EMPTY_VALUE,0.0);
PlotIndexSetDouble(1,PLOT_EMPTY_VALUE,0.0);
//---- ñîçäàíèå ìåòîê äëÿ îòîáðàæåíèÿ â Îêíå äàííûõ
PlotIndexSetString(0,PLOT_LABEL,"ZigZag Lowest");
PlotIndexSetString(1,PLOT_LABEL,"ZigZag Highest");
//---- èíäåêñàöèÿ ýëåìåíòîâ â áóôåðàõ êàê â òàéìñåðèÿõ
ArraySetAsSeries(LowestBuffer,true);
ArraySetAsSeries(HighestBuffer,true);
ArraySetAsSeries(ColorBuffer,true);
//---- óñòàíîâêà ïîçèöèè, ñ êîòîðîé íà÷èíàåòñÿ îòðèñîâêà óðîâíåé Áîëëèíäæåðà
PlotIndexSetInteger(0,PLOT_DRAW_BEGIN,min_rates_total);
PlotIndexSetInteger(1,PLOT_DRAW_BEGIN,min_rates_total);
//---- Óñòàíîâêà ôîðìàòà òî÷íîñòè îòîáðàæåíèÿ èíäèêàòîðà
IndicatorSetInteger(INDICATOR_DIGITS,_Digits);
//---- èìÿ äëÿ îêîí äàííûõ è ëýéáà äëÿ ñóáúîêîí
string shortname;
StringConcatenate(shortname,"ZigZag on Parabolic(",
double(Step), ", ", double(Maximum), ", ", bool(ExtremumsShift), ")");
IndicatorSetString(INDICATOR_SHORTNAME,shortname);
//----
}
//+------------------------------------------------------------------+
//| Custom indicator iteration function |
//+------------------------------------------------------------------+
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[])
{
//---- ïðîâåðêà êîëè÷åñòâà áàðîâ íà äîñòàòî÷íîñòü äëÿ ðàñ÷¸òà
if(BarsCalculated(SAR_Handle)<rates_total || rates_total<min_rates_total)return(0);
//---- îáúÿâëåíèÿ ëîêàëüíûõ ïåðåìåííûõ
static int j_,lastcolor_;
static bool dir_;
static double h_,l_;
int j,limit,climit,to_copy,bar,shift,NewBar,lastcolor;
double h,l,mid0,mid1,SAR[];
bool dir;
//---- ðàñ÷¸ò ñòàðòîâîãî íîìåðà limit äëÿ öèêëà ïåðåñ÷¸òà áàðîâ è ñòàðòîâàÿ èíèöèàëèçàöèÿ ïåðåìåííûõ
if(prev_calculated>rates_total || prev_calculated<=0)// ïðîâåðêà íà ïåðâûé ñòàðò ðàñ÷¸òà èíäèêàòîðà
{
limit=rates_total-1-min_rates_total; // ñòàðòîâûé íîìåð äëÿ ðàñ÷¸òà âñåõ áàðîâ
h_=0.0;
l_=999999999;
dir_=false;
j_=0;
lastcolor_=0;
}
else
{
limit=rates_total-prev_calculated; // ñòàðòîâûé íîìåð äëÿ ðàñ÷¸òà íîâûõ áàðîâ
}
climit=limit; // ñòàðòîâûé íîìåð äëÿ ðàñêðàñêè èíäèêàòîðà
to_copy=limit+2;
if(limit==0) NewBar=1;
else NewBar=0;
//---- èíäåêñàöèÿ ýëåìåíòîâ â ìàññèâàõ êàê â òàéìñåðèÿõ
ArraySetAsSeries(SAR,true);
ArraySetAsSeries(high,true);
ArraySetAsSeries(low,true);
//---- êîïèðóåì âíîâü ïîÿâèâøèåñÿ äàííûå â ìàññèâ
if(CopyBuffer(SAR_Handle,0,0,to_copy,SAR)<=0) return(0);
//---- âîññòàíàâëèâàåì çíà÷åíèÿ ïåðåìåííûõ
j=j_;
dir=dir_;
h=h_;
l=l_;
lastcolor=lastcolor_;
//---- Ïåðâûé áîëüøîé öèêë ðàñ÷¸òà èíäèêàòîðà
for(bar=limit; bar>=0 && !IsStopped(); bar--)
{
//---- çàïîìèíàåì çíà÷åíèÿ ïåðåìåííûõ ïåðåä ïðîãîíàìè íà òåêóùåì áàðå
if(rates_total!=prev_calculated && bar==0)
{
j_=j;
dir_=dir;
h_=h;
l_=l;
}
mid0=(high[bar]+low[bar])/2;
mid1=(high[bar+1]+low[bar+1])/2;
HighestBuffer[bar]=0.0;
LowestBuffer[bar]=0.0;
if(bar>0) j++;
if(dir)
{
if(h<high[bar])
{
h=high[bar];
j=NewBar;
}
if(SAR[bar+1]<=mid1 && SAR[bar]>mid0)
{
shift=bar+EShift *(j+NewBar);
if(shift>rates_total-1) shift=rates_total-1;
HighestBuffer[shift]=h;
dir=false;
l=low[bar];
j=0;
if(shift>climit) climit=shift;
}
}
else
{
if(l>low[bar])
{
l=low[bar];
j=NewBar;
}
if(SAR[bar+1]>=mid1 && SAR[bar]<mid0)
{
shift=bar+EShift *(j+NewBar);
if(shift>rates_total-1) shift=rates_total-1;
LowestBuffer[shift]=l;
dir=true;
h=high[bar];
j=0;
if(shift>climit) climit=shift;
}
}
}
//---- Òðåòèé áîëüøîé öèêë ðàñêðàñêè èíäèêàòîðà
for(bar=climit; bar>=0 && !IsStopped(); bar--)
{
if(rates_total!=prev_calculated && !bar) lastcolor_=lastcolor;
if(!HighestBuffer[bar] || !LowestBuffer[bar]) ColorBuffer[bar]=lastcolor;
if(HighestBuffer[bar] || LowestBuffer[bar])
{
if(lastcolor==0)
{
ColorBuffer[bar]=1;
lastcolor=1;
}
else
{
ColorBuffer[bar]=0;
lastcolor=0;
}
}
if(!HighestBuffer[bar] || !LowestBuffer[bar])
{
ColorBuffer[bar]=1;
lastcolor=1;
}
if(HighestBuffer[bar] || LowestBuffer[bar])
{
ColorBuffer[bar]=0;
lastcolor=0;
}
}
//----
return(rates_total);
}
//+------------------------------------------------------------------+
Comments
Markdown Formatting Guide
# H1
## H2
### H3
**bold text**
*italicized text*
[title](https://www.example.com)

`code`
```
code block
```
> blockquote
- Item 1
- Item 2
1. First item
2. Second item
---