Olá, Sr. Nicholas,
Acrescentei "timeframes relativos".
//+------------------------------------------------------------------+ //|Fib_SR_6.mq5 //|Direitos autorais © 2006, Eli hayun | //| http://www.elihayun.com | //+------------------------------------------------------------------+ //---- indicator authorship #property copyright "Copyright © 2006, Eli hayun." //---- link para o site do autor #property link "http://www.elihayun.com" //---- número da versão do indicador #property version "1.00" //---- desenhar indicador na janela principal #property indicator_chart_window //---- nenhum buffer é usado para cálculo e desenho do indicador #property indicator_buffers 0 //---- zero construções gráficas usadas #property indicator_plots 0 //+----------------------------------------------+ //| declarando constantes | //+----------------------------------------------+ #define RESET 0 // Constante para retornar ao terminal o comando para recalcular o indicador #define FIB_RES3 "FIB_RES_3" #define FIB_RES2 "FIB_RES_2" #define FIB_RES1 "FIB_RES_1" #define FIB_SUP1 "FIB_SUP_1" #define FIB_SUP2 "FIB_SUP_2" #define FIB_SUP3 "FIB_SUP_3" //--- // enum enTimeFrames { tf_cu = PERIOD_CURRENT, // Período de tempo atual tf_m1 = PERIOD_M1, // 1 minuto tf_m2 = PERIOD_M2, // 2 minutos tf_m3 = PERIOD_M3, // 3 minutos tf_m4 = PERIOD_M4, // 4 minutos tf_m5 = PERIOD_M5, // 5 minutos tf_m6 = PERIOD_M6, // 6 minutos tf_m10 = PERIOD_M10, // 10 minutos tf_m12 = PERIOD_M12, // 12 minutos tf_m15 = PERIOD_M15, // 15 minutos tf_m20 = PERIOD_M20, // 20 minutos tf_m30 = PERIOD_M30, // 30 minutos tf_h1 = PERIOD_H1, // 1 hora tf_h2 = PERIOD_H2, // 2 horas tf_h3 = PERIOD_H3, // 3 horas tf_h4 = PERIOD_H4, // 4 horas tf_h6 = PERIOD_H6, // 6 horas tf_h8 = PERIOD_H8, // 8 horas tf_h12 = PERIOD_H12, // 12 horas tf_d1 = PERIOD_D1, // diariamente tf_w1 = PERIOD_W1, // semanalmente tf_mn = PERIOD_MN1, // mensal tf_cp1 = -1, // Próximo período de tempo superior tf_cp2 = -2, // Segundo período de tempo superior tf_cp3 = -3, // Terceiro período de tempo superior tf_cp4 = -4, // Quarto período de tempo superior tf_cp5 = -5, // Quinto período de tempo superior tf_cp6 = -6 // Sexto período de tempo superior }; ENUM_TIMEFRAMES _tfsPer[]={PERIOD_M1,PERIOD_M2,PERIOD_M3,PERIOD_M4,PERIOD_M5,PERIOD_M6,PERIOD_M10,PERIOD_M12,PERIOD_M15,PERIOD_M20,PERIOD_M30,PERIOD_H1,PERIOD_H2,PERIOD_H3,PERIOD_H4,PERIOD_H6,PERIOD_H8,PERIOD_H12,PERIOD_D1,PERIOD_W1,PERIOD_MN1}; // //--- // //+----------------------------------------------+ //|| Parâmetros de entrada do indicador //+----------------------------------------------+ input enTimeFrames InpTimeframe = tf_cp1; // Indicador Próximo período de tempo para calcular o indicador input uint NumberofBar = 1; // Número da barra para calcular o indicador input double Ratio1 = 0.618; // primeira proporção input double Ratio2 = 1.382; // segunda proporção input double Ratio3 = 2.764; // segunda proporção input double Step = 0.50; // etapa de extensão input color Color_Res3 = clrAqua; // cor da terceira zona de resistência input color Color_Res2 = clrLime; // cor da segunda zona de resistência input color Color_Res1 = clrGreen; // cor da primeira zona de resistência input color Color_Sup1 = clrRed; // cor da primeira zona de suporte input color Color_Sup2 = clrMagenta; // cor da segunda zona de suporte input color Color_Sup3 = clrYellow; // cor da terceira zona de suporte input uint RightTail = 60; // protrusão de retângulos além da barra zero à direita em minutos input uint LeftTail = 60; // protrusão de retângulos atrás da barra inicial à esquerda em minutos //+----------------------------------------------+ uint SecondRightTail,SecondLeftTail; //--- variáveis globais ENUM_TIMEFRAMES Timeframe; //+------------------------------------------------------------------+ //| Criando um objeto retangular| //+------------------------------------------------------------------+ void CreateRectangle ( long chart_id, // identificador de gráfico string name, // nome do objeto int nwin, // índice da janela datetime time1, // tempo 1 double price1, // preço 1 datetime time2, // tempo 2 double price2, // preço 2 color Color, // cor da linha bool background, // exibição em segundo plano da linha string text // texto ) //---- { //---- ObjectCreate(chart_id,name,OBJ_RECTANGLE,nwin,time1,price1,time2,price2); ObjectSetInteger(chart_id,name,OBJPROP_COLOR,Color); ObjectSetInteger(chart_id,name,OBJPROP_FILL,true); ObjectSetString(chart_id,name,OBJPROP_TEXT,text); ObjectSetInteger(chart_id,name,OBJPROP_BACK,background); ObjectSetString(chart_id,name,OBJPROP_TOOLTIP,"\n"); //proibir dica de ferramenta ObjectSetInteger(chart_id,name,OBJPROP_BACK,true); //objeto em segundo plano //---- } //+------------------------------------------------------------------+ //|| Redefinição de um objeto retangular //+------------------------------------------------------------------+ void SetRectangle ( long chart_id, // identificador de gráfico string name, // nome do objeto int nwin, // índice da janela datetime time1, // tempo 1 double price1, // preço 1 datetime time2, // tempo 2 double price2, // preço 2 color Color, // cor da linha bool background, // exibição em segundo plano da linha string text // texto ) //---- { //---- if(ObjectFind(chart_id,name)==-1) CreateRectangle(chart_id,name,nwin,time1,price1,time2,price2,Color,background,text); else { ObjectSetString(chart_id,name,OBJPROP_TEXT,text); ObjectMove(chart_id,name,0,time1,price1); ObjectMove(chart_id,name,1,time2,price2); } //---- } //+------------------------------------------------------------------+ //| Função de inicialização do indicador personalizado //+------------------------------------------------------------------+ int OnInit() { //---Calcular o período de tempo do indicador Timeframe = MathMax(timeFrameGet((int)InpTimeframe),_Period); //---- SecondRightTail=RightTail*60; SecondLeftTail=LeftTail*60; //---- determinação da precisão da exibição dos valores do indicador IndicatorSetInteger(INDICATOR_DIGITS,_Digits); //---- criar rótulos para exibição na DataWindow e nome para exibição em uma subjanela separada e dica de ferramenta IndicatorSetString(INDICATOR_SHORTNAME,"Fib_SR"); //---- inicialização concluída return(INIT_SUCCEEDED); } //+------------------------------------------------------------------+ //| Função de desinicialização do indicador personalizado //+------------------------------------------------------------------+ void OnDeinit(const int reason) { //---- ObjectDelete(0,FIB_SUP3); ObjectDelete(0,FIB_SUP2); ObjectDelete(0,FIB_SUP1); ObjectDelete(0,FIB_RES1); ObjectDelete(0,FIB_RES2); ObjectDelete(0,FIB_RES3); //---- ChartRedraw(0); } //+------------------------------------------------------------------+ //| Função de iteração de indicador personalizado //+------------------------------------------------------------------+ int OnCalculate( const int rates_total, // quantidade de histórico em barras no tique atual const int prev_calculated,// quantidade de histórico em barras no tique anterior const datetime &time[], const double &open[], const double& high[], // array de preços máximos para o cálculo do indicador const double& low[], // matriz de preços mínimos para o cálculo do indicador const double &close[], const long &tick_volume[], const long &volume[], const int &spread[] ) { //---- if(prev_calculated==rates_total && NumberofBar) return(rates_total); //---- double nClose[1],nHigh[1],nLow[1]; datetime nTime[1]; int to_copy; //---- indexação de elementos em matrizes como em séries temporais ArraySetAsSeries(time,true); //---- to_copy=1; //---- if(CopyTime(NULL,Timeframe,0,to_copy,nTime)<to_copy)return(RESET); if(CopyClose(NULL,Timeframe,NumberofBar,to_copy,nClose)<to_copy)return(RESET); if(CopyHigh(NULL,Timeframe,NumberofBar,to_copy,nHigh)<to_copy)return(RESET); if(CopyLow(NULL,Timeframe,NumberofBar,to_copy,nLow)<to_copy)return(RESET); //---- double C=nClose[0]; double H=nHigh[0]; double L=nLow[0]; double R=(H-L); //---- C=(H+L+C)/3; double D=C+R*Step; double B=C-R*Step; double E=C+R*2*Step; double A=C-R*2*Step; //---- double R2=R*Ratio2; double R1=R*Ratio1; double B1=C-R1; double A1=C-R2; //---- double D1=C+R1; double E1=C+R2; //---- double R3=R*Ratio3; double F=C+R*4*Step; double G=C-R*4*Step; double F1=C+R3; double G1=C-R3; //---- SetRectangle(0,FIB_RES3,0,nTime[0]-SecondLeftTail,F,time[0]+SecondRightTail,F1,Color_Res3,true,FIB_RES3); SetRectangle(0,FIB_RES2,0,nTime[0]-SecondLeftTail,E,time[0]+SecondRightTail,E1,Color_Res2,true,FIB_RES2); SetRectangle(0,FIB_RES1,0,nTime[0]-SecondLeftTail,D,time[0]+SecondRightTail,D1,Color_Res1,true,FIB_RES1); SetRectangle(0,FIB_SUP1,0,nTime[0]-SecondLeftTail,B,time[0]+SecondRightTail,B1,Color_Sup1,true,FIB_SUP1); SetRectangle(0,FIB_SUP2,0,nTime[0]-SecondLeftTail,A,time[0]+SecondRightTail,A1,Color_Sup2,true,FIB_SUP2); SetRectangle(0,FIB_SUP3,0,nTime[0]-SecondLeftTail,G,time[0]+SecondRightTail,G1,Color_Sup3,true,FIB_SUP3); //---- ChartRedraw(0); return(rates_total); } //+------------------------------------------------------------------+ // ENUM_TIMEFRAMES timeFrameGet(int period) { int _shift=(period<0?MathAbs(period):0); if(_shift>0 || period==tf_cu) period=_Period; int i; for(i=0;i<ArraySize(_tfsPer);i++) if(period==_tfsPer[i]) break; return(_tfsPer[(int)MathMin(i+_shift,ArraySize(_tfsPer)-1)]); } // //---
Você está perdendo oportunidades de negociação:
- Aplicativos de negociação gratuitos
- 8 000+ sinais para cópia
- Notícias econômicas para análise dos mercados financeiros
Registro
Login
Você concorda com a política do site e com os termos de uso
Se você não tem uma conta, por favor registre-se
Fib_SR_6:
O indicador Fib_SR com duas zonas adicionais de suporte e resistência.
Autor: Nikolay Kositsin