//--- описание #property description "Скрипт строит графический объект \"Дуги Фибоначчи\"." #property description "Координаты точек привязки задаются в процентах от" #property description "размеров окна графика." //--- покажем окно входных параметров при запуске скрипта #property script_show_inputs //--- входные параметры скрипта input string InpName="FiboArc"; // Имя объекта input int InpDate1=25; // Дата 1-ой точки в % input int InpPrice1=25; // Цена 1-ой точки в % input int InpDate2=35; // Дата 2-ой точки в % input int InpPrice2=55; // Цена 2-ой точки в % input double InpScale=3.0; // Масштаб input bool InpFullEllipse=true; // Форма дуг input color InpColor=clrRed; // Цвет линии input ENUM_LINE_STYLE InpStyle=STYLE_DASHDOTDOT; // Стиль линии input int InpWidth=2; // Толщина линии input bool InpBack=false; // Объект на заднем плане input bool InpSelection=true; // Выделить для перемещений input bool InpHidden=true; // Скрыт в списке объектов input long InpZOrder=0; // Приоритет на нажатие мышью //+------------------------------------------------------------------+ //| Cоздает "Дуги Фибоначчи" по заданным координатам | //+------------------------------------------------------------------+ bool FiboArcCreate(const long chart_ID=0, // ID графика const string name="FiboArc", // имя объекта const int sub_window=0, // номер подокна datetime time1=0, // время первой точки double price1=0, // цена первой точки datetime time2=0, // время второй точки double price2=0, // цена второй точки const double scale=1.0, // масштаб const bool full_ellipse=false, // форма дуг const color clr=clrRed, // цвет линии const ENUM_LINE_STYLE style=STYLE_SOLID, // стиль линии const int width=1, // толщина линии const bool back=false, // на заднем плане const bool selection=true, // выделить для перемещений const bool hidden=true, // скрыт в списке объектов const long z_order=0) // приоритет на нажатие мышью { //--- установим координаты точек привязки, если они не заданы ChangeFiboArcEmptyPoints(time1,price1,time2,price2); //--- сбросим значение ошибки ResetLastError(); //--- создадим "Дуги Фибоначчи" по заданным координатам if(!ObjectCreate(chart_ID,name,OBJ_FIBOARC,sub_window,time1,price1,time2,price2)) { Print(__FUNCTION__, ": не удалось создать \"Дуги Фибоначчи\"! Код ошибки = ",GetLastError()); return(false); } //--- установим масштаб ObjectSetDouble(chart_ID,name,OBJPROP_SCALE,scale); //--- установим отображение дуг в виде полного эллипса (true) или половины (false) ObjectSetInteger(chart_ID,name,OBJPROP_ELLIPSE,full_ellipse); //--- установим цвет ObjectSetInteger(chart_ID,name,OBJPROP_COLOR,clr); //--- установим стиль линии ObjectSetInteger(chart_ID,name,OBJPROP_STYLE,style); //--- установим толщину линии ObjectSetInteger(chart_ID,name,OBJPROP_WIDTH,width); //--- отобразим на переднем (false) или заднем (true) плане ObjectSetInteger(chart_ID,name,OBJPROP_BACK,back); //--- включим (true) или отключим (false) режим выделения дуг для перемещений //--- при создании графического объекта функцией ObjectCreate, по умолчанию объект //--- нельзя выделить и перемещать. Внутри же этого метода параметр selection //--- по умолчанию равен true, что позволяет выделять и перемещать этот объект ObjectSetInteger(chart_ID,name,OBJPROP_SELECTABLE,selection); ObjectSetInteger(chart_ID,name,OBJPROP_SELECTED,selection); //--- скроем (true) или отобразим (false) имя графического объекта в списке объектов ObjectSetInteger(chart_ID,name,OBJPROP_HIDDEN,hidden); //--- установим приоритет на получение события нажатия мыши на графике ObjectSetInteger(chart_ID,name,OBJPROP_ZORDER,z_order); //--- успешное выполнение return(true); } //+------------------------------------------------------------------+ //| Задает количество уровней и их параметры | //+------------------------------------------------------------------+ bool FiboArcLevelsSet(int levels, // количество линий уровня double &values[], // значения линий уровня color &colors[], // цвет линий уровня ENUM_LINE_STYLE &styles[], // стиль линий уровня int &widths[], // толщина линий уровня const long chart_ID=0, // ID графика const string name="FiboArc") // имя объекта { //--- проверим размеры массивов if(levels!=ArraySize(colors) || levels!=ArraySize(styles) || levels!=ArraySize(widths) || levels!=ArraySize(widths)) { Print(__FUNCTION__,": длина массива не соответствует количеству уровней, ошибка!"); return(false); } //--- установим количество уровней ObjectSetInteger(chart_ID,name,OBJPROP_LEVELS,levels); //--- установим свойства уровней в цикле for(int i=0;i<levels;i++) { //--- значение уровня ObjectSetDouble(chart_ID,name,OBJPROP_LEVELVALUE,i,values[i]); //--- цвет уровня ObjectSetInteger(chart_ID,name,OBJPROP_LEVELCOLOR,i,colors[i]); //--- стиль уровня ObjectSetInteger(chart_ID,name,OBJPROP_LEVELSTYLE,i,styles[i]); //--- толщина уровня ObjectSetInteger(chart_ID,name,OBJPROP_LEVELWIDTH,i,widths[i]); //--- описание уровня ObjectSetString(chart_ID,name,OBJPROP_LEVELTEXT,i,DoubleToString(100*values[i],1)); } //--- успешное выполнение return(true); } //+------------------------------------------------------------------+ //| Перемещает точку привязки "Дуг Фибоначчи" | //+------------------------------------------------------------------+ bool FiboArcPointChange(const long chart_ID=0, // ID графика const string name="FiboArc", // имя объекта const int point_index=0, // номер точки привязки datetime time=0, // координата времени точки привязки double price=0) // координата цены точки привязки { //--- если координаты точки не заданы, то перемещаем ее на текущий бар с ценой Bid if(!time) time=TimeCurrent(); if(!price) price=SymbolInfoDouble(Symbol(),SYMBOL_BID); //--- сбросим значение ошибки ResetLastError(); //--- переместим точку привязки if(!ObjectMove(chart_ID,name,point_index,time,price)) { Print(__FUNCTION__, ": не удалось переместить точку привязки! Код ошибки = ",GetLastError()); return(false); } //--- успешное выполнение return(true); } //+------------------------------------------------------------------+ //| Удаляет "Дуги Фибоначчи" | //+------------------------------------------------------------------+ bool FiboArcDelete(const long chart_ID=0, // ID графика const string name="FiboArc") // имя объекта { //--- сбросим значение ошибки ResetLastError(); //--- удалим объект if(!ObjectDelete(chart_ID,name)) { Print(__FUNCTION__, ": не удалось удалить \"Дуги Фибоначчи\"! Код ошибки = ",GetLastError()); return(false); } //--- успешное выполнение return(true); } //+------------------------------------------------------------------+ //| Проверяет значения точек привязки "Дуг Фибоначчи" и для пустых | //| значений устанавливает значения по умолчанию | //+------------------------------------------------------------------+ void ChangeFiboArcEmptyPoints(datetime &time1,double &price1, datetime &time2,double &price2) { //--- если время второй точки не задано, то она будет на текущем баре if(!time2) time2=TimeCurrent(); //--- если цена второй точки не задана, то она будет иметь значение Bid if(!price2) price2=SymbolInfoDouble(Symbol(),SYMBOL_BID); //--- если время первой точки не задано, то она лежит на 9 баров левее второй if(!time1) { //--- массив для приема времени открытия 10 последних баров datetime temp[10]; CopyTime(Symbol(),Period(),time2,10,temp); //--- установим первую точку на 9 баров левее второй time1=temp[0]; } //--- если цена первой точки не задана, то сдвинем ее на 300 пунктов ниже второй if(!price1) price1=price2-300*SymbolInfoDouble(Symbol(),SYMBOL_POINT); } //+------------------------------------------------------------------+ //| Script program start function | //+------------------------------------------------------------------+ void OnStart() { //--- проверим входные параметры на корректность if(InpDate1<0 || InpDate1>100 || InpPrice1<0 || InpPrice1>100 || InpDate2<0 || InpDate2>100 || InpPrice2<0 || InpPrice2>100) { Print("Ошибка! Некорректные значения входных параметров!"); return; } //--- количество видимых баров в окне графика int bars=(int)ChartGetInteger(0,CHART_VISIBLE_BARS); //--- размер массива price int accuracy=1000; //--- массивы для хранения значений дат и цен, которые будут использованы //--- для установки и изменения координат точек привязки "Дуг Фибоначчи" datetime date[]; double price[]; //--- выделение памяти ArrayResize(date,bars); ArrayResize(price,accuracy); //--- заполним массив дат ResetLastError(); if(CopyTime(Symbol(),Period(),0,bars,date)==-1) { Print("Не удалось скопировать значения времени! Код ошибки = ",GetLastError()); return; } //--- заполним массив цен //--- найдем максимальное и минимальное значение графика double max_price=ChartGetDouble(0,CHART_PRICE_MAX); double min_price=ChartGetDouble(0,CHART_PRICE_MIN); //--- определим шаг изменения цены и заполним массив double step=(max_price-min_price)/accuracy; for(int i=0;i<accuracy;i++) price[i]=min_price+i*step; //--- определим точки для рисования "Дуг Фибоначчи" int d1=InpDate1*(bars-1)/100; int d2=InpDate2*(bars-1)/100; int p1=InpPrice1*(accuracy-1)/100; int p2=InpPrice2*(accuracy-1)/100; //--- создадим объект if(!FiboArcCreate(0,InpName,0,date[d1],price[p1],date[d2],price[p2],InpScale, InpFullEllipse,InpColor,InpStyle,InpWidth,InpBack,InpSelection,InpHidden,InpZOrder)) { return; } //--- перерисуем график и подождем 1 секунду ChartRedraw(); Sleep(1000); //--- теперь будем перемещать точки привязки //--- счетчик цикла int v_steps=accuracy/5; //--- перемещаем первую точку привязки for(int i=0;i<v_steps;i++) { //--- возьмем следующее значение if(p1<accuracy-1) p1+=1; //--- сдвигаем точку if(!FiboArcPointChange(0,InpName,0,date[d1],price[p1])) return; //--- проверим факт принудительного завершения скрипта if(IsStopped()) return; //--- перерисуем график ChartRedraw(); } //--- задержка в 1 секунду Sleep(1000); //--- счетчик цикла int h_steps=bars/5; //--- перемещаем вторую точку привязки for(int i=0;i<h_steps;i++) { //--- возьмем следующее значение if(d2<bars-1) d2+=1; //--- сдвигаем точку if(!FiboArcPointChange(0,InpName,1,date[d2],price[p2])) return; //--- проверим факт принудительного завершения скрипта if(IsStopped()) return; //--- перерисуем график ChartRedraw(); // задержка в 0.05 секунды Sleep(50); } //--- задержка в 1 секунду Sleep(1000); //--- удалим объект с графика FiboArcDelete(0,InpName); ChartRedraw(); //--- задержка в 1 секунду Sleep(1000); //--- } |