Не знаю что имелось ввиду..?
i-dist/2
Получается отрицателное значение.
Это никак нельзя исправить? Бо я в программировании не бум-бум. ..
Можно - i+dist/2
Покрутил я этот индикатор и так и эдак.. сразу не понял: то ли
я совсем уже умом поехал, а создателю надо Нобелевскую, то ли
здесь что-то не так.
Оказолось всё просто, как мыло. Нас просто обдурили!:))
Что это значит?
Оказолось всё просто, как мыло. Нас просто обдурили!:))
Что это значит?
i-dist/2
Это значит, что на нулевом баре (т.е. на текущем) запрашиваются
и обрабатываются максимальное и минимальное значения курсов
на барах с отрицательным индексом.
Бар с отрицательным индексом - это тот, который справа от текущего
(нулевого).
Автор этого шедевра просто напросто подглядывал в будущее!:)
Легко проверить, что индикатор показывает совсем другую картину
в режиме реального времени.
Не наколитесь, Cvinto!
Integer, если такое сделать - индикатор просто пропадет с экрана
монитора )
Вы упускаете торговые возможности:
- Бесплатные приложения для трейдинга
- 8 000+ сигналов для копирования
- Экономические новости для анализа финансовых рынков
Регистрация
Вход
Вы принимаете политику сайта и условия использования
Если у вас нет учетной записи, зарегистрируйтесь
//+------------------------------------------------------------------+
//| sss. mq4 |
//| Copyright © 2006, Nick Bilak, beluck[AT]gmail. com |
//+------------------------------------------------------------------+
#property copyright "Copyright © 2006, Nick Bilak"
#property link "https://www.metaquotes.net/ru/"
#property indicator_chart_window
#property indicator_buffers 2
#property indicator_color1 Red
#property indicator_color2 Aqua
extern int SignalGap = 0;
int dist=24;
double b1[];
double b2[];
int init() {
SetIndexStyle(0,DRAW_ARROW,STYLE_SOLID,1);
SetIndexStyle(1,DRAW_ARROW,STYLE_SOLID,1);
SetIndexArrow(1,233);
SetIndexArrow(0,234);
SetIndexBuffer(0,b1);
SetIndexBuffer(1,b2);
return(0);
}
int start() {
int counted_bars=IndicatorCounted();
int k,i,j,limit,hhb,llb;
if (counted_bars<0) return(-1);
if (counted_bars>0) counted_bars--;
limit=Bars-1;
if(counted_bars>=1) limit=Bars-counted_bars-1;
if (limit<0) limit=0;
for (i=limit;i>=0;i--) {
hhb = Highest(NULL,0,MODE_CLOSE,dist,i-dist/2);
llb = Lowest(NULL,0,MODE_CLOSE,dist,i-dist/2);
if (i==hhb)
b1[i]=Close[hhb]+SignalGap*Point;
if (i==llb)
b2[i]=Close[llb]-SignalGap*Point;
}
return(0);
}