Price Data Components
Miscellaneous
0
Views
0
Downloads
0
Favorites
Multi pair EMA angle zero + mtf
//+------------------------------------------------------------------+
//| Multi pair laguerre RSI.mq4 |
//| mladen |
//+------------------------------------------------------------------+
#property copyright "mladen"
#property link "mladenfx@gmail.com"
#property indicator_separate_window
#property indicator_buffers 4
#property indicator_color1 Green
#property indicator_color2 Red
#property indicator_color3 Gold
#property indicator_color4 DeepSkyBlue
#property indicator_width1 2
#property indicator_width2 2
#property indicator_width3 2
#property indicator_width4 1
#property indicator_level1 0.3
#property indicator_level2 -0.3
#property indicator_levelcolor RoyalBlue
//
//
//
//
//
extern int MAPeriod = 34;
extern int MA_MODE = 1;//0 sma; 1 ema; 2 smma; 3 lwma
extern int MA_PRICE = 0;
extern double AngleTreshold = 0.2;
extern int StartMAShift = 6;
extern int EndMAShift = 0;
extern int SigMA_Period = 9;
extern int SigMA_mode = 1;//0 sma; 1 ema; 2 smma; 3 lwma
//
//
//
//
//
extern int barsPerPair = 70;
extern string TimeFrame = "Current time frame";
extern string pairs = "EURUSD;GBPUSD;USDCAD";
extern string text = "color";
extern color textColor = Silver;
extern color backColor = C'48,48,48';
extern int separatorWidth = 6;
//
//
//
//
//
double ind_buffer1[];
double ind_buffer2[];
double ind_buffer3[];
double ind_buffer4[];
//
//
//
//
//
string aPairs[];
string shortName;
int window;
int timeFrame;
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
//
//
//
//
//
int init()
{
SetIndexBuffer(0,ind_buffer1);
SetIndexBuffer(1,ind_buffer2);
SetIndexBuffer(2,ind_buffer3);
SetIndexBuffer(3,ind_buffer4);
SetIndexStyle(0,DRAW_HISTOGRAM);
SetIndexStyle(1,DRAW_HISTOGRAM);
SetIndexStyle(2,DRAW_HISTOGRAM);
SetIndexStyle(3,DRAW_LINE);
//
//
//
//
//
pairs = StringUpperCase(StringTrimLeft(StringTrimRight(pairs)));
if (StringSubstr(pairs,StringLen(pairs),1) != ";")
pairs = StringConcatenate(pairs,";");
//
//
//
//
//
string addition="";
if (IsMini()) addition="m";
if (IsDoubleDotted()) addition="..";
else if (IsDotted()) addition=".";
int s = 0;
int i = StringFind(pairs,";",s);
string current;
string temp;
while (i > 0)
{
current = StringSubstr(pairs,s,i-s)+addition;
if (iClose(current,0,0) > 0)
{
ArrayResize(aPairs,ArraySize(aPairs)+1);
aPairs[ArraySize(aPairs)-1] = current;
if (current == Symbol())
{
temp = aPairs[0];
aPairs[0] = current;
aPairs[ArraySize(aPairs)-1] = temp;
}
}
s = i + 1;
i = StringFind(pairs,";",s);
}
//
//
//
//
//
separatorWidth = MathMax(separatorWidth,4);
shortName = MakeUniqueName("Multi Angle EMA","");
IndicatorShortName(shortName);
timeFrame = stringToTimeFrame(TimeFrame);
//
//
//
//
//
return(0);
}
int deinit()
{
for (int i = 0; i < ArraySize(aPairs); i++) {
ObjectDelete(shortName+i);
ObjectDelete(shortName+i+i);
}
return(0);
}
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
//
//
//
//
//
int start()
{
int limit = ArraySize(aPairs);
int i,k;
//
//
//
//
//
window = WindowFind(shortName);
for(i=0,k=0; i<limit; i++) calculateEMAAngle(aPairs[i],barsPerPair,k,i);
//
//
//
//
//
for (i=0;i<indicator_buffers;i++) SetIndexDrawBegin(i,Bars-k);
return(0);
}
//+------------------------------------------------------------------+
//+ +
//+------------------------------------------------------------------+
//
//
//
//
//
int calculateEMAAngle(string symbol,int limit,int& shift,int element)
{
int i;
//
//
//
//
//
for(i=0; i<limit; i++) {
int y=iBarShift(NULL,timeFrame,Time[i]);
ind_buffer1[shift+i]=iCustom(symbol,timeFrame,"MA_AngleZeroSigMAm",MAPeriod,MA_MODE,MA_PRICE,AngleTreshold,StartMAShift,EndMAShift,SigMA_Period,SigMA_mode,0,y);
ind_buffer2[shift+i]=iCustom(symbol,timeFrame,"MA_AngleZeroSigMAm",MAPeriod,MA_MODE,MA_PRICE,AngleTreshold,StartMAShift,EndMAShift,SigMA_Period,SigMA_mode,1,y);
ind_buffer3[shift+i]=iCustom(symbol,timeFrame,"MA_AngleZeroSigMAm",MAPeriod,MA_MODE,MA_PRICE,AngleTreshold,StartMAShift,EndMAShift,SigMA_Period,SigMA_mode,2,y);
ind_buffer4[shift+i]=iCustom(symbol,timeFrame,"MA_AngleZeroSigMAm",MAPeriod,MA_MODE,MA_PRICE,AngleTreshold,StartMAShift,EndMAShift,SigMA_Period,SigMA_mode,3,y);
}
//
//
//
//
//
for (i=0;i<separatorWidth;i++) {
ind_buffer1[shift+limit+i] = EMPTY_VALUE;
ind_buffer2[shift+limit+i] = EMPTY_VALUE;
ind_buffer3[shift+limit+i] = EMPTY_VALUE;
ind_buffer4[shift+limit+i] = EMPTY_VALUE;
}
//
//
//
//
//
createLabel(symbol,element,shift+limit+separatorWidth-2,false);
shift += limit+separatorWidth-1;
}
//+------------------------------------------------------------------+
//+ +
//+------------------------------------------------------------------+
//
//
//
//
//
void createLabel(string symbol,int element, int shift, bool signalCrossing)
{
string name = shortName+element;
double price1 = 100;
double price2 = -100;
//
//
//
//
//
if (ObjectFind(name) == -1)
{
ObjectCreate(name,OBJ_TEXT,window,0,0);
ObjectSet(name,OBJPROP_ANGLE,90);
ObjectSetText(name,symbol);
}
ObjectSet(name,OBJPROP_TIME1 ,Time[shift]);
ObjectSet(name,OBJPROP_PRICE1,(price1+price2)/2);
if (signalCrossing)
ObjectSet(name,OBJPROP_COLOR,Gold);
else ObjectSet(name,OBJPROP_COLOR,textColor);
//
//
//
//
//
name = shortName+element+element;
if (ObjectFind(name) == -1)
{
ObjectCreate(name,OBJ_RECTANGLE,window,0,0,0,0);
ObjectSet(name,OBJPROP_COLOR,backColor);
}
ObjectSet(name,OBJPROP_TIME1,Time[shift]);
ObjectSet(name,OBJPROP_PRICE1,price1);
ObjectSet(name,OBJPROP_TIME2,Time[shift-(separatorWidth-2)]);
ObjectSet(name,OBJPROP_PRICE2,price2);
}
//+------------------------------------------------------------------+
//+ +
//+------------------------------------------------------------------+
//
//
//
//
//
string StringUpperCase(string str)
{
string s = str;
int lenght = StringLen(str) - 1;
int char;
while(lenght >= 0)
{
char = StringGetChar(s, lenght);
//
//
//
//
//
if((char > 96 && char < 123) || (char > 223 && char < 256))
s = StringSetChar(s, lenght, char - 32);
else
if(char > -33 && char < 0)
s = StringSetChar(s, lenght, char + 224);
lenght--;
}
//
//
//
//
//
return(s);
}
//+------------------------------------------------------------------+
//| |
//+------------------------------------------------------------------+
//
//
//
//
//
string MakeUniqueName(string first, string rest)
{
string result = first+(MathRand()%1001)+rest;
while (WindowFind(result)> 0)
result = first+(MathRand()%1001)+rest;
return(result);
}
bool IsMini() { return(StringFind(Symbol(),"m") > -1); }
bool IsDoubleDotted() { return(StringFind(Symbol(),"..") > -1); }
bool IsDotted() { return(StringFind(Symbol(),".") > -1); }
//
//
//
//
//
int stringToTimeFrame(string tfs)
{
for(int l = StringLen(tfs)-1; l >= 0; l--)
{
int char = StringGetChar(tfs,l);
if((char > 96 && char < 123) || (char > 223 && char < 256))
tfs = StringSetChar(tfs, l, char - 32);
else
if(char > -33 && char < 0)
tfs = StringSetChar(tfs, l, char + 224);
}
//
//
//
//
//
int tf=0;
if (tfs=="M1" || tfs=="1") tf=PERIOD_M1;
if (tfs=="M5" || tfs=="5") tf=PERIOD_M5;
if (tfs=="M15"|| tfs=="15") tf=PERIOD_M15;
if (tfs=="M30"|| tfs=="30") tf=PERIOD_M30;
if (tfs=="H1" || tfs=="60") tf=PERIOD_H1;
if (tfs=="H4" || tfs=="240") tf=PERIOD_H4;
if (tfs=="D1" || tfs=="1440") tf=PERIOD_D1;
if (tfs=="W1" || tfs=="10080") tf=PERIOD_W1;
if (tfs=="MN" || tfs=="43200") tf=PERIOD_MN1;
if (tf<Period() && tf!=0) tf=Period();
return(tf);
}
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
---