MT4インジケータ ADXm
下記は、ADXmのプログラムなのですが、ADXmは、基本的に右肩上がり、右肩下がりの動きをします。右肩上がり、下がりでは、ラインの色が違うのですが、この色の変化の際(上がり、下がりの変化)の際に下記の条件を行うには、どのようにプログラムを変更すればよいのでしょうか。
どなたかMT4のプログラミングに詳しい方、ご教授ください。
(1)Alertを鳴らす
(2)Soundを一度鳴らす
(3)Soundを鳴らし続ける
//-------ANG3110@latchess.com-------
//****************************************
#property indicator_separate_window
#property indicator_buffers 5
#property indicator_color1 White
#property indicator_color2 DeepPink
#property indicator_color3 DeepSkyBlue
#property indicator_color4 Goldenrod
#property indicator_color5 Goldenrod
#property indicator_width2 2
#property indicator_width3 2
#property indicator_style4 0
#property indicator_style5 0
#property indicator_level1 0
//=====================================
extern int p=14;
extern int Level=25;
//=====================================
double ADX[],ADXL[],DI[],levh[],levl[];
double dh,dl,tr,H,L,num1,num2,num3,dhk,dlk,div;
double zdh,zdhp,zdl,zdlp,zdx,zdxp,zdhl,si;
double temp,ki;
int fs,fss,ti;
//*********************************************************
int init()
{
IndicatorShortName("ADXm "+"("+p+")");
//--------------------
SetIndexBuffer(0,DI);
SetIndexBuffer(1,ADX);
SetIndexBuffer(2,ADXL); SetIndexEmptyValue(2,0.0);
SetIndexBuffer(3,levh);
SetIndexBuffer(4,levl);
//--------------------
return(0);
}
//*********************************************************
int start()
{
int cbi,IC=Bars-IndicatorCounted()-1;
if (IC<10) cbi=IC; else
{
cbi=Bars-2;
ki=2.0/(p+1);
ADX[cbi+1]=0.0; ADXL[cbi+1]=0.0;
zdhp=0.0; zdh=0.0; zdlp=0.0; zdl=0.0; zdxp=0.0; zdx=0.0;
ti=Time[cbi]; fs=0; fss=0;
}
//-------------------------------------------------
for (int i=cbi; i>=0; i--)
{
if (ti!=Time[i]) {zdhp=zdh; zdlp=zdl; zdxp=zdx; ti=Time[i];}
H=High[i]; L=Low[i];
dh=H-High[i+1];
dl=Low[i+1]-L;
if(dh<0) dh=0;
if(dl<0) dl=0;
if(dh==dl) {dh=0; dl=0;} else if(dh<dl) dh=0; else if(dl<dh) dl=0;
num1=MathAbs(H-L);
num2=MathAbs(H-Close[i+1]);
num3=MathAbs(L-Close[i+1]);
tr=MathMax(MathMax(num1,num2),num3);
if(tr==0) {dhk=0; dlk=0;} else {dhk=100.0*dh/tr; dlk=100.0*dl/tr;}
zdh=zdhp+(dhk-zdhp)*ki;
zdl=zdlp+(dlk-zdlp)*ki;
zdhl=zdh-zdl; DI[i]=zdhl;
div=MathAbs(zdh+zdl);
if(div==0.00) temp=0; else temp=100*(MathAbs(zdhl)/div);
if (zdh>zdl) fs=1;
if (zdh<zdl) fs=2;
if (fs==2) temp=-temp;
zdx=zdxp+(temp-zdxp)*ki;
ADX[i]=zdx;
if (ADX[i]>ADX[i+1]) fss=1;
if (ADX[i]<ADX[i+1]) {if (fss==1) ADXL[i+1]=ADX[i+1]; fss=2;}
if (fss==2) ADXL[i]=ADX[i]; else ADXL[i]=0.0;
levh[i]=Level;
levl[i]=-Level;
}
return(0);
}
//******************************************************************