По беглому просмотру исходника, приходит в голову просто добавить два буфера, один для mml[0], другой для dmml. И восстанавливать все уровни уже в эксперте. Такой вот вариант.
Или же попытаться этот алгоритм переоформить как функцию.
Или же попытаться этот алгоритм переоформить как функцию.
По моему, самое лучшее, встрой индикатор прямо в советник, благо код позволяет, но без прорисовки, и бери нужные тебе параметры вживую.
Ну, переоформить как функцию(набор функций) по сути и означает встроить в эксперта :)
Вот код, выкладывался в "Индикатор поддержки/сопротивления" Владиславом.
Никак не могу расчитать его значения из эксперта через
Никак не могу расчитать его значения из эксперта через
Конечно не против - меняйте код как Вам будет удобно - единственное условие - он должен оставаться работоспособным :).
В индикаторе вместо start(){......}
пишете название функции, например, MM_Levels(){} и полностью переносите код в советника - там будут глобальные переменные так , что просмотрите внимательно. В принципе можно массивы передать по ссылкам.
В советнике в функции stаrt(){} - ставите вызов:
stаrt(){
.......................
MM_Levels();
...................
}
Не забудьте операторы из функции инит индикатора перенести в функцию инит эксперта.
По iCustom() можно получить только значения массивов связанных с буферами индикатора функцией SetIndexBuffer(N,....);, где N не больше 8 (их все равно на все уровни не хватает).
Удачи и попутных трендов.
Всем спасибо, буду пробовать.
Чтобы не захламлять график линиями (с позволения автора), заменил соответствующие стороки в ините на:
ln_txt[0] = "[-2/8] Сильное отклонение SUP"; ln_txt[1] = "[-1/8] Отклонение SUP"; ln_txt[2] = "[0/8] Сильная SUP"; ln_txt[3] = "[1/8] Слабая SUP"; ln_txt[4] = "[2/8] Слабее Главной SUP"; ln_txt[5] = "[3/8] SUP диапазона++"; ln_txt[6] = "[4/8] Главная SUP/RES"; ln_txt[7] = "[5/8] RES диапазона++"; ln_txt[8] = "[6/8] Слабее Главного RES"; ln_txt[9] = "[7/8] Слабое RES"; ln_txt[10] = "[8/8] Сильное RES"; ln_txt[11] = "[+1/8] Отклонение RES"; ln_txt[12] = "[+2/8] Сильное отклонение RES";
и в start() тело последнего цикла на:
for(i=0; i<OctLinesCnt; i++) { buff_str = "mml"+i; if(ObjectFind(buff_str) == -1) { ObjectCreate(buff_str, OBJ_ARROW, 0, Time[20], mml[i]); ObjectSet(buff_str, OBJPROP_ARROWCODE, 5); ObjectSet(buff_str, OBJPROP_COLOR, mml_clr[i]); ObjectMove(buff_str, 0, Time[20], mml[i]);} else {ObjectMove(buff_str, 0, Time[20], mml[i]);} buff_str = "mml_txt"+i; if(ObjectFind(buff_str) == -1) { ObjectCreate(buff_str, OBJ_TEXT, 0, Time[mml_shft], mml[i] + 5*Point); ObjectSetText(buff_str, ln_txt[i], 8, "Arial", mml_clr[i]); ObjectMove(buff_str, 0, Time[mml_shft], mml[i] + 5*Point);} else {ObjectMove(buff_str, 0, Time[mml_shft], mml[i] + 5*Point);} }
вместо линий получаем ценовые метки уровней. При масштабе №3 (+++) от самого мелкого, достаточно удобно.
В индикаторе вместо start(){......}
пишете название функции, например, MM_Levels(){} и полностью переносите код в советника - там будут глобальные переменные так , что просмотрите внимательно. В принципе можно массивы передать по ссылкам.
В советнике в функции stаrt(){} - ставите вызов:
stаrt(){
.......................
MM_Levels();
...................
}
Не забудьте операторы из функции инит индикатора перенести в функцию инит эксперта.
пишете название функции, например, MM_Levels(){} и полностью переносите код в советника - там будут глобальные переменные так , что просмотрите внимательно. В принципе можно массивы передать по ссылкам.
В советнике в функции stаrt(){} - ставите вызов:
stаrt(){
.......................
MM_Levels();
...................
}
Не забудьте операторы из функции инит индикатора перенести в функцию инит эксперта.
Эту методику по написанию ф-ций я еще не освоил, уж что имею.
Ув. Владислав, предлагаю Вам внести в ваш индикатор данную примочку или выложить понятную инструкцию, чтобы индик был полезен и в использовании его в экспертах.
Выложи код, что получился, да и картинку не помешает. Картинки народ лучше привлекают :)
Код пожалуйста, а вот картинку сложнее :)
//+------------------------------------------------------------------+ //| Murrey_Math_MT_VG.mq4 | //| Copyright © 2005, Vladislav Goshkov (VG). | //| 4vg@mail.ru | //+------------------------------------------------------------------+ #property copyright "Vladislav Goshkov (VG)." #property link "4vg@mail.ru" //#property indicator_buffers 8 #property indicator_chart_window extern int StepBack = 1; extern int P = 100; //64 color MarkColor = MidnightBlue; int MarkNumber = 217; double dmml = 0, dvtl = 0, sum = 0, v1 = 0, v2 = 0, mn = 0, mx = 0, x1 = 0, x2 = 0, x3 = 0, x4 = 0, x5 = 0, x6 = 0, y1 = 0, y2 = 0, y3 = 0, y4 = 0, y5 = 0, y6 = 0, octave = 0, fractal = 0, range = 0, finalH = 0, finalL = 0, mml[13]; string ln_txt[13], buff_str = ""; int bn_v1 = 0, bn_v2 = 0, OctLinesCnt = 13, //mml_thk = 8, mml_clr[13], mml_shft = 50, nTime = 0, CurPeriod = 0, nDigits = 0, i = 0; //+------------------------------------------------------------------+ //| Custom indicator initialization function | //+------------------------------------------------------------------+ int init() { //---- indicators ln_txt[0] = "[-2/8] Сильное отклонение SUP"; ln_txt[1] = "[-1/8] Отклонение SUP"; ln_txt[2] = "[0/8] Сильная SUP"; ln_txt[3] = "[1/8] Слабая SUP"; ln_txt[4] = "[2/8] Слабее Главной SUP"; ln_txt[5] = "[3/8] SUP диапазона++"; ln_txt[6] = "[4/8] Главная SUP/RES"; ln_txt[7] = "[5/8] RES диапазона++"; ln_txt[8] = "[6/8] Слабее Главного RES"; ln_txt[9] = "[7/8] Слабое RES"; ln_txt[10] = "[8/8] Сильное RES"; ln_txt[11] = "[+1/8] Отклонение RES"; ln_txt[12] = "[+2/8] Сильное отклонение RES"; //mml_shft = 3; //mml_thk = 3; // Начальная установка цветов уровней октав mml_clr[0] = MidnightBlue; // [-2]/8 mml_clr[1] = DarkBlue; // [-1]/8 mml_clr[2] = DarkSlateBlue; // [0]/8 mml_clr[3] = MediumSlateBlue; // [1]/8 mml_clr[4] = Indigo; // [2]/8 mml_clr[5] = Blue; // [3]/8 mml_clr[6] = Black; // [4]/8 mml_clr[7] = Red; // [5]/8 mml_clr[8] = Maroon; // [6]/8 mml_clr[9] = SandyBrown; // [7]/8 mml_clr[10] = FireBrick; // [8]/8 mml_clr[11] = Crimson; // [+1]/8 mml_clr[12] = MediumVioletRed; // [+2]/8 //---- //SetIndexBuffer(0,mml); return(0); } //+------------------------------------------------------------------+ //| Custor indicator deinitialization function | //+------------------------------------------------------------------+ int deinit() { //---- TODO: add your code here Comment(" "); for(i=0;i<OctLinesCnt;i++) { buff_str = "mml"+i; ObjectDelete(buff_str); buff_str = "mml_txt"+i; ObjectDelete(buff_str); } ObjectDelete("LR_LatestCulcBar"); //---- return(0); } //+------------------------------------------------------------------+ //| Custom indicator iteration function | //+------------------------------------------------------------------+ int start() { //---- TODO: add your code here if( (nTime != Time[0]) || (CurPeriod != Period()) ) { //price bn_v1 = Lowest(NULL,0,MODE_LOW,P+StepBack,StepBack); // P+StepBack bn_v2 = Highest(NULL,0,MODE_HIGH,P+StepBack,StepBack); // P+StepBack v1 = Low[bn_v1]; v2 = High[bn_v2]; //determine fractal..... if( v2<=250000 && v2>25000 ) fractal=100000; else if( v2<=25000 && v2>2500 ) fractal=10000; else if( v2<=2500 && v2>250 ) fractal=1000; else if( v2<=250 && v2>25 ) fractal=100; else if( v2<=25 && v2>12.5 ) fractal=12.5; else if( v2<=12.5 && v2>6.25) fractal=12.5; else if( v2<=6.25 && v2>3.125 ) fractal=6.25; else if( v2<=3.125 && v2>1.5625 ) fractal=3.125; else if( v2<=1.5625 && v2>0.390625 ) fractal=1.5625; else if( v2<=0.390625 && v2>0) fractal=0.1953125; range=(v2-v1); sum=MathFloor(MathLog(fractal/range)/MathLog(2)); octave=fractal*(MathPow(0.5,sum)); mn=MathFloor(v1/octave)*octave; if( (mn+octave)>v2 ) mx=mn+octave; else mx=mn+(2*octave); // calculating xx //x2 if( (v1>=(3*(mx-mn)/16+mn)) && (v2<=(9*(mx-mn)/16+mn)) ) x2=mn+(mx-mn)/2; else x2=0; //x1 if( (v1>=(mn-(mx-mn)/8))&& (v2<=(5*(mx-mn)/8+mn)) && (x2==0) ) x1=mn+(mx-mn)/2; else x1=0; //x4 if( (v1>=(mn+7*(mx-mn)/16))&& (v2<=(13*(mx-mn)/16+mn)) ) x4=mn+3*(mx-mn)/4; else x4=0; //x5 if( (v1>=(mn+3*(mx-mn)/8))&& (v2<=(9*(mx-mn)/8+mn))&& (x4==0) ) x5=mx; else x5=0; //x3 if( (v1>=(mn+(mx-mn)/8))&& (v2<=(7*(mx-mn)/8+mn))&& (x1==0) && (x2==0) && (x4==0) && (x5==0) ) x3=mn+3*(mx-mn)/4; else x3=0; //x6 if( (x1+x2+x3+x4+x5) ==0 ) x6=mx; else x6=0; finalH = x1+x2+x3+x4+x5+x6; // calculating yy //y1 if( x1>0 ) y1=mn; else y1=0; //y2 if( x2>0 ) y2=mn+(mx-mn)/4; else y2=0; //y3 if( x3>0 ) y3=mn+(mx-mn)/4; else y3=0; //y4 if( x4>0 ) y4=mn+(mx-mn)/2; else y4=0; //y5 if( x5>0 ) y5=mn+(mx-mn)/2; else y5=0; //y6 if( (finalH>0) && ((y1+y2+y3+y4+y5)==0) ) y6=mn; else y6=0; finalL = y1+y2+y3+y4+y5+y6; for( i=0; i<OctLinesCnt; i++) { mml[i] = 0; } dmml = (finalH-finalL)/8; mml[0] =(finalL-dmml*2); //-2/8 for( i=1; i<OctLinesCnt; i++) { mml[i] = mml[i-1] + dmml; } for( i=0; i<OctLinesCnt; i++ ){ buff_str = "mml"+i; if(ObjectFind(buff_str) == -1) { ObjectCreate(buff_str, OBJ_ARROW, 0, Time[20], mml[i]); ObjectSet(buff_str, OBJPROP_ARROWCODE, 5); ObjectSet(buff_str, OBJPROP_COLOR, mml_clr[i]); ObjectMove(buff_str, 0, Time[20], mml[i]); } else {ObjectMove(buff_str, 0, Time[20], mml[i]);} buff_str = "mml_txt"+i; if(ObjectFind(buff_str) == -1) { ObjectCreate(buff_str, OBJ_TEXT, 0, Time[mml_shft], mml[i] + 5*Point); ObjectSetText(buff_str, ln_txt[i], 8, "Arial", mml_clr[i]); ObjectMove(buff_str, 0, Time[mml_shft], mml[i] + 5*Point); } else {ObjectMove(buff_str, 0, Time[mml_shft], mml[i] + 5*Point);} } nTime = Time[0]; CurPeriod= Period(); string buff_str = "LR_LatestCulcBar"; if(ObjectFind(buff_str) == -1) { ObjectCreate(buff_str, OBJ_ARROW,0, Time[StepBack], Low[StepBack]-2*Point ); ObjectSet(buff_str, OBJPROP_ARROWCODE, MarkNumber); ObjectSet(buff_str, OBJPROP_COLOR, MarkColor); } else { ObjectMove(buff_str, 0, Time[StepBack], Low[StepBack]-2*Point ); } } //---- End Of Program return(0); } //+------------------------------------------------------------------+
Картинку выкоадываешь здесь - https://www.mql5.com/ru/forum
Потом жмыкаешь на ней мышкой - открывается новое окно с большой картинкой, копируешь ее урлу и вставляешь в пост сюда, выделяешь линк в посте и жмешь кнопку [img] - готово
ЗЫ Название картинке надо давать на латинице обязательно
Потом жмыкаешь на ней мышкой - открывается новое окно с большой картинкой, копируешь ее урлу и вставляешь в пост сюда, выделяешь линк в посте и жмешь кнопку [img] - готово
ЗЫ Название картинке надо давать на латинице обязательно
Вы упускаете торговые возможности:
- Бесплатные приложения для трейдинга
- 8 000+ сигналов для копирования
- Экономические новости для анализа финансовых рынков
Регистрация
Вход
Вы принимаете политику сайта и условия использования
Если у вас нет учетной записи, зарегистрируйтесь
Никак не могу расчитать его значения из эксперта через
double iCustom(NULL, PERIOD_H1, "Murrey_Math_MT_VG", ... , int mode, int shift), ну не хватает моих знаний, много перепробовал комбинаций, но тщетно. Уважаемые программеры, может кто подскажет, как вызвать значения mml[i], или может что что-нибудь нужно добавить в этот индик (если господин Vladislav Goshkov не против)? плз