MT4会变色的均线下面这个是示意图:均线会变色,看起来很神秘,但原理其实很简单:这里实际上有两条均线,一条红线,一条绿线:当价格在均线上方时,红线显示,绿线隐藏;当价格在均线下方时,红线隐藏,绿线显示 ...
MT4会变色的均线下面这个是示意图: 均线会变色,看起来很神秘,但原理其实很简单:这里实际上有两条均线,一条红线,一条绿线:当价格在均线上方时,红线显示,绿线隐藏;当价格在均线下方时,红线隐藏,绿线显示,所以看起来就只是一条会变色的均线。要隐藏一条指标线中的其中一段,也很简单,只要把这一段指标线的值赋为空值(EMPTY_VALUE)就行了。说说容易,但实际操作的时候,我们又遇到了一个小问题,那就是红绿转换点的“断点”问题,红线和绿线不连续了。图: 这个问题着实困扰了我好一阵,后来终于想通了。原来,画线的条件是:前后两个时点上都必须有值,才能画出线来。而上图中2和3之间应该画上红线,但在3点位上,红线的值为空,所以,红线画不出来。要让红线、绿线连续,必须使3点位上,既有绿线值又有红线值,这样2和3之间才能出现红线,红线绿才会连续。 为了做到这一点,我们在给指标线循环赋值的时候:1、在 i 时点上,除了给 i 时点赋值,同时还要给 i 1时点赋同色值(以上图为例:我们在给3时点赋绿线值时,同时给4时点赋绿线值;在给2时点赋红线值时,同时再给3点赋红线值;这样3时点上就既有红线值,又有绿线值);2、赋值的顺序为从左向右,即递减循环,以避免前一操作所赋的值被清空。这样我们的目的就达到了。下面这是经过测试的源代码: 1. 2. --------------------------------------------------------------------------------------------------- 3. #property indicator_chart_window 4. #property indicator_buffers 2 5. #property indicator_color1 Red 6. #property indicator_color2 Green 7. extern int 变色均线=18; 8. double duo[]; 9. double kong[]; 10. int init() 11. { 12. SetIndexBuffer(0,duo); 13. SetIndexBuffer(1,kong); 14. SetIndexStyle(0,DRAW_LINE); 15. SetIndexStyle(1,DRAW_LINE); 16. SetIndexDrawBegin(0,变色均线); 17. SetIndexDrawBegin(1,变色均线); 18. IndicatorDigits(Digits); 19. return(0); 20. } 21. int start() 22. { 23. double temp0,temp1; 24. int limit; 25. int counted_bars=IndicatorCounted(); 26. if(counted_bars<0) return(-1); 27. if(counted_bars>0) counted_bars--; 28. limit=Bars-counted_bars; 29. for(int i=limit; i>=0; i--) 30. { 31. duo[i]=EMPTY_VALUE; 32. kong[i]=EMPTY_VALUE; 33. temp0=iMA(NULL,0,变色均线,0,MODE_SMA,PRICE_CLOSE,i); 34. temp1=iMA(NULL,0,变色均线,0,MODE_SMA,PRICE_CLOSE,i 1); 35. if(iClose(NULL,0,i)>=iMA(NULL,0,变色均线,0,MODE_SMA,PRICE_CLOSE,i)) 36. {duo[i]=temp0; duo[i 1]=temp1;} 37. else {kong[i]=temp0; kong[i 1]=temp1;} 38. } 39. return(0); 40. } 41. ----------------------------------------------------------------------------------------------------------- 复制代码 当然,上面这个是以价格在均线上下方为条件的,我们也可以以MACD、KDJ、RSI等指标作为均线变色的条件。我们还可以更进一步,把双色线改为三色线等等 语句简要解释如下:===================================================================#property indicator_chart_window指标放在主图 #property indicator_buffers 2设置指标线数组为2个 #property indicator_color1 Red #property indicator_color2 Green设置第一条指标线颜色值为Red,第二条颜色值为Greenextern int 变色均线=18;设立一个自定义变量,允许外部值修改,整数形,变量名为"变色均线",默认值18double duo[];设立一个自定义数组,双精度型,名称为duo该数组在后面用于存储红线数据double kong[];设立一个自定义数组,双精度型,名称为kong该数组在后面用于存储绿线数据 int init() SetIndexBuffer(0,duo); SetIndexBuffer(1,kong); 设置第一、二条指标线的数组为duo和kong SetIndexStyle(0,DRAW_LINE); SetIndexStyle(1,DRAW_LINE); 设置第一、二条指标线的样式,线型为连续曲线 SetIndexDrawBegin(0,变色均线); SetIndexDrawBegin(1,变色均线); 设置第一、二条指标线的最左边的起始划线位置 IndicatorDigits(Digits); 设置指标精确到的小数位数 Digits是当前汇率小数位,日系Digits=2,其他币对Digits=4 return(0); init函数结束; int start() { double temp0,temp1; 设立双精度型自定义变量temp0、temp1; int limit; 设立自定义变量limit,整数型; int counted_bars=IndicatorCounted(); 设立整数型自定义变量counted_bars,并将IndicatorCounted()的值赋给counted_bars IndicatorCounted()为缓存数,即已经计算过值的烛柱数 if(counted_bars<0) return(-1); 如果counted_bars值小于零,start函数结束 if(counted_bars>0) counted_bars--; 如果counted_bars值大于零,则counted_bars值减掉1。 这是为了配合下一句,以避免limit相差1而出错 limit=Bars-counted_bars; 给limit赋值 Bars为图表中的烛柱数 counted_bars为缓存数,即已经运算过的烛柱数 这样limit的值就是未经运算的烛柱数 这样做的目的是避免重复运算,优化程序 for(int i=limit; i>=0; i--) 循环语句,括号中有三个语句: 第一句int i=limit; 表示循环从i=limit开始 第二句i>=0; 这是循环的条件,如果条件满足则执行大括号中的循环体,如果条件不满足,则中止循环,跳到大括号下面的语句执行 第三句i--,这是循环步调控制语句,每循环一次后执行一次此语句。 i--相当于i=i-1,即i值在原有数值上减少1 { duo=EMPTY_VALUE; kong=EMPTY_VALUE; 给数组duo和kong在i位置上赋空值 EMPTY_VALUE:空值 temp0=iMA(NULL,0,变色均线,0,MODE_SMA,PRICE_CLOSE,i); temp1=iMA(NULL,0,变色均线,0,MODE_SMA,PRICE_CLOSE,i 1); 把均线在i和i 1位置上均线值,分别赋给temp0和temp1 这是为了使后面的语句看起来简洁 判断条件语句如果价格高于均线 if(iClose(NULL,0,i)>=iMA(NULL,0,变色均线,0,MODE_SMA,PRICE_CLOSE,i)) {duo=temp0; duo[i 1]=temp1;} 判断执行语句:给数组元素duo、duo[i 1]分别赋值 else {kong=temp0; kong[i 1]=temp1;} 如果判断条件不成立,即价格低于均线:则给数组元素kong、kong[i 1]分别赋值 } return(0); start函数结束,返回零值 } 本文来自网络,如若转载引用本网站内容须注明原网址,并标明本网站网址(www.anwei66.com)。 对于不当转载或引用本网站内容而引起的民事纷争、行政处理或其他损失,本网站不承担责任。 |
0