UltraWPR_HTF Indicator For MT5
UltraWPR_HTF Indicator For MT5 słynie przede wszystkim z różnych opcji wyboru ram czasowych. Narzędzie wyższych ram czasowych Ultra WPR może pokazać dokładne miejsce, w którym kupujący lub sprzedający zaczynają tracić swoją siłę. Poziom krytyczny dla kupujących jest oznaczony cyfrą 8, ponieważ zaczynają tracić prędkość.
Dla sprzedawców poziom podstawowy jest oznaczony liczbą 2. Po odczytaniu wskaźnika uderzył w liczbę 2, kupujący powoli przejmują kontrolę nad trendem. Chmura koloru oliwkowego powstaje po tym, jak kupujący przejmują kontrolę, a chmura koloru lawendy pokazuje kontrolę sprzedawców. Ale zabarwienie to nie jedyny sposób, w jaki możesz umieścić swój handel. Powinieneś mieć zdolność analityczną do znalezienia krytycznego wsparcia i oporu w 4-godzinnym przedziale czasowym i powyżej.
Po znalezieniu strefy SR poszukaj sygnałów. Po potwierdzeniu konfiguracji handlu użyj wskaźnika do odfiltrowania fałszywych sygnałów. Ale unikaj czytania tego wskaźnika w krytycznych wiadomościach politycznych, ponieważ może to spowodować ogromne wahania cen.
Instalowanie UltraWPR_HTF Indicator For MT5
Po pobraniu wskaźnika za pomocą powyższego formularza musisz rozpakować plik zip. Następnie musisz skopiować plik ultrawpr_htf.mq5 do folderu MQL5Indicators instalacji MT5 . Następnie uruchom ponownie MT5, a wtedy będziesz mógł zobaczyć wskaźnik na liście wskaźników.
Parametry UltraWPR_HTF Indicator For MT5
UltraWPR_HTF Indicator For MT5 17 UltraWPR_HTF Indicator For MT5 ma parametry 17 do skonfigurowania.
input ENUM_TIMEFRAMES TimeFrame=PERIOD_H4; // Indicator chart period
input int WPR_Period=13; // WPR indicator period
input Smooth_Method W_Method=MODE_JJMA; // Method of averaging
input int StartLength=3; // Initial averaging period
input int WPhase=100; // Averaging parameter
input uint Step=5; // Period change step
input uint StepsTotal=10; // Number of period changes
input Smooth_Method SmoothMethod=MODE_JJMA; // Smoothing method
input int SmoothLength=3; // Smoothing depth
input int SmoothPhase=100; // Smoothing parameter (-100..+100)
input uint UpLevel=80; // Overbought level (%)
input uint DnLevel=20; // Oversold level (%)
input color UpLevelsColor=Blue; // Overbought level color
input color DnLevelsColor=Blue; // Oversold level color
input STYLE Levelstyle=DASH_; // Style of the levels
input WIDTH LevelsWidth=Width_1; // Depth of the levels
input int Shift=0; // Horizontal shift of the indicator in bars
Bufory słowa UltraWPR_HTF Indicator For MT5
UltraWPR_HTF Indicator For MT5 zapewnia bufory 1 .
SetIndexBuffer(Number,Buffer,INDICATOR_DATA);
Główne części Kodeksu
int OnCalculate(const int rates_total, // number of bars in history at the current tick
const int prev_calculated,// amount of history in bars at the previous tick
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[])
{
//--- checking if the number of bars is enough for the calculation
if(rates_total lt min_rates_total) return(RESET);
if(BarsCalculated(Ind_Handle) lt Bars(Symbol(),TimeFrame)) return(prev_calculated);
//--- indexing elements in arrays as in timeseries
ArraySetAsSeries(time,true);
//---
if(!CountIndicator(0,Symbol(),TimeFrame,Ind_Handle,0,Ind1Buffer,1,Ind2Buffer,
time,rates_total,prev_calculated,min_rates_total)) return(RESET);
//---
return(rates_total);
}
//---
//+------------------------------------------------------------------+
//| Indicator buffer initialization |
//+------------------------------------------------------------------+
void IndInit(int Number,double &Buffer[])
{
//--- Set dynamic array as an indicator buffer
SetIndexBuffer(Number,Buffer,INDICATOR_DATA);
//--- Indexing elements in the buffer as in timeseries
ArraySetAsSeries(Buffer,true);
//---
}
//+------------------------------------------------------------------+
//| CountLine |
//+------------------------------------------------------------------+
bool CountIndicator(uint Numb, // The number of the CountLine function in the list in the indicator code (starting number - 0)
string Symb, // Chart symbol
ENUM_TIMEFRAMES TFrame, // Chart period
int IndHandle, // The handle of the processed indicator
uint UpBuffNumb, // The number of the buffer of the processed indicator for an uptrend
double& UpIndBuf[], // Receiving buffer of the indicator for an uptrend
uint DnBuffNumb, // The number of the buffer of the processed indicator for a downtrend
double& DnIndBuf[], // Receiving buffer of the indicator for a downtrend
const datetime& iTime[], // Timeseries of time
const int Rates_Total, // Amount of history in bars on the current tick
const int Prev_Calculated,// amount of history in bars at the previous tick
const int Min_Rates_Total)// minimum amount of history in bars for calculation
{
//---
static int LastCountBar[SIZE];
datetime IndTime[1];
int limit;
//--- calculations of the necessary amount of data to be copied
//--- and the limit starting index for the bars recalculation loop
if(Prev_Calculated gt Rates_Total || Prev_Calculated lt =0)// Checking for the first start of the indicator calculation
{
limit=Rates_Total-Min_Rates_Total-1; // Starting index for calculation of all bars
LastCountBar[Numb]=limit;
}
else limit=LastCountBar[Numb]+Rates_Total-Prev_Calculated; // Starting index for calculation of new bars
//--- main indicator calculation loop
for(int bar=limit; bar gt =0 && !IsStopped(); bar--)
{
//---- reset the contents of the indicator buffers for calculation
UpIndBuf[bar]=EMPTYVALUE;
DnIndBuf[bar]=EMPTYVALUE;
//---- Copy new data to the IndTime array
if(CopyTime(Symbol(),TFrame,iTime[bar],1,IndTime) lt =0) return(RESET);
if(iTime[bar] gt =IndTime[0] && iTime[bar+1] lt IndTime[0])
{
LastCountBar[Numb]=bar;
double Arr[1];
//--- Copy new data to the Arr array
if(CopyBuffer(IndHandle,UpBuffNumb,iTime[bar],1,Arr) lt =0) return(RESET); UpIndBuf[bar]=Arr[0];
if(CopyBuffer(IndHandle,DnBuffNumb,iTime[bar],1,Arr) lt =0) return(RESET); DnIndBuf[bar]=Arr[0];
}
else
{
UpIndBuf[bar]=UpIndBuf[bar+1];
DnIndBuf[bar]=DnIndBuf[bar+1];
}
}
//---
return(true);
}
//+------------------------------------------------------------------+
//| TimeFramesCheck() |
//+------------------------------------------------------------------+
bool TimeFramesCheck(string IndName,
ENUM_TIMEFRAMES TFrame) //Indicator 1 chart period (smallest timeframe)
{
//--- Checking correctness of the chart periods
if(TFrame lt Period() && TFrame!=PERIOD_CURRENT)
{
Print("Chart period for the "+IndName+" indicator cannot be less than the period of the current chart!");
Print ("You must change the indicator input parameters!");
return(RESET);
}
//---
return(true);
}
//+------------------------------------------------------------------+