红烧牛蹄筋的做法:会变色的均线

来源:百度文库 编辑:偶看新闻 时间:2024/04/29 23:06:18

会变色的均线

标签:

股票

分类: 均线系统

下面这个是示意图:


均线会变色,看起来很神秘,但原理其实很简单:


这里实际上有两条均线,一条红线,一条绿线:
当价格在均线上方时,红线显示,绿线隐藏;
当价格在均线下方时,红线隐藏,绿线显示,
所以看起来就只是一条会变色的均线。

要隐藏一条指标线中的其中一段,也很简单,只要把这一段指标线的值赋为空值(EMPTY_VALUE)就行了。

说说容易,但实际操作的时候,我们又遇到了一个小问题,那就是红绿转换点的“断点”问题,红线和绿线不连续了。图:


这个问题着实困扰了我好一阵,后来终于想通了。
原来,画线的条件是:前后两个时点上都必须有值,才能画出线来。而上图中2和3之间应该画上红线,但在3点位上,红线的值为空,所以,红线画不出来。

要让红线、绿线连续,必须使3点位上,既有绿线值又有红线值,这样2和3之间才能出现红线,红线绿才会连续。

为了做到这一点,我们在给指标线循环赋值的时候:

1、在 i 时点上,除了给 i 时点赋值,同时还要给 i+1时点赋同色值(以上图为例:我们在给3时点赋绿线值时,同时给4时点赋绿线值;在给2时点赋红线值时,同时再给3点赋红线值;这样3时点上就既有红线值,又有绿线值);

2、赋值的顺序为从左向右,即递减循环,以避免前一操作所赋的值被清空。

这样我们的目的就达到了。

下面这是经过测试的源代码

---------------------------------------------------------------------------------------------------

#property indicator_chart_window
#property indicator_buffers 2
#property indicator_color1 Red
#property indicator_color2 Green
extern int  变色均线=18;
double duo[];
double kong[];
int init()
  {SetIndexBuffer(0,duo);
   SetIndexBuffer(1,kong);
   SetIndexStyle(0,DRAW_LINE);
   SetIndexStyle(1,DRAW_LINE);
   SetIndexDrawBegin(0,变色均线);
   SetIndexDrawBegin(1,变色均线);
   IndicatorDigits(Digits);
   return(0);}
int start()
  {double temp0,temp1;
   int limit;
   int counted_bars=IndicatorCounted();
   if(counted_bars<0) return(-1);
   if(counted_bars>0) counted_bars--;
   limit=Bars-counted_bars;
   for(int i=limit; i>=0; i--)
    {duo[i]=EMPTY_VALUE;
      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);
      if(iClose(NULL,0,i)>=iMA(NULL,0,变色均线,0,MODE_SMA,PRICE_CLOSE,i)) 
            {duo[i]=temp0; duo[i+1]=temp1;}
      else  {kong[i]=temp0; kong[i+1]=temp1;}
     return(0);}
-----------------------------------------------------------------------------------------------------------

当然,上面这个是以价格在均线上下方为条件的,我们也可以以MACD、KDJ、RSI等指标作为均线变色的条件。我们还可以更进一步,把双色线改为三色线等等

 

 

 

===================================================
语句简要解释如下:
===================================================
#property indicator_chart_window
指标放在主图

#property indicator_buffers 2
设置指标线数组为2个

#property indicator_color1 Red
#property indicator_color2 Green
设置第一条指标线颜色值为Red,第二条颜色值为Green

extern int  变色均线=18;
设立一个自定义变量,允许外部值修改,整数形,变量名为"变色均线",默认值18

double duo[];
设立一个自定义数组,双精度型,名称为duo
该数组在后面用于存储红线数据

double kong[];
设立一个自定义数组,双精度型,名称为kong
该数组在后面用于存储绿线数据

int init()
设立初始化函数init。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()
设立触发函数start。start为系统规定函数名,函数内容自定义。当数据变动时,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[i]=EMPTY_VALUE;
      kong[i]=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[i]=temp0; duo[i+1]=temp1;}
            判断执行语句:给数组元素duo[i]、duo[i+1]分别赋值
      else  {kong[i]=temp0; kong[i+1]=temp1;}
      如果判断条件不成立,即价格低于均线:则给数组元素kong[i]、kong[i+1]分别赋值}     
   return(0);start函数结束,返回零值}

30日均线向上时显示红色,否则为绿色
MA30:MA(C,30),COLORFFFF00;
IF(MA30>=REF(MA30,1),MA30,DRAWNULL),COLORRED;
IF(MA30<=REF(MA30,1),MA30,DRAWNULL),COLORGREEN;

输出MA30:收盘价的30日简单移动平均,COLORFFFF00
如果MA30>=昨日MA30,返回MA30,否则返回无效数,画红色
如果MA30<=昨日MA30,返回MA30,否则返回无效数,画绿色