本组函数用于设计和编写自定义指标。
这些函数不能用在智能交易和脚本中。
- IndicatorBuffers() – 指标数据缓冲区
- IndicatorCounted() – 指标计数
- IndicatorDigits() – 设置指标精度
- IndicatorShortName() – 设置指标简称
- SetIndexArrow() – 设置指标箭头符号
- SetIndexBuffer() – 设置指标缓冲区位置
- SetIndexDrawBegin() – 设置指标线起始位置
- SetIndexEmptyValue() – 设置图表画线空值
- SetIndexLabel() – 设置指标线标签
- SetIndexShift() – 设置指标线偏移值
- SetIndexStyle() – 设置指标线样式
- SetLevelStyle() – 设置水平线样式
- SetLevelValue() – 设置水平线值
SetIndexDrawBegin() – 设置指标线起始位置
void SetIndexDrawBegin(int index, int begin)
设置开始绘制指标线的柱体(指标线从什么位置开始绘制)。指标线从左边绘制到右边,已给出的柱子左边的数组值不会显示在图表或数据窗口中。设置0作为默认值,所有数据将被绘出。
参数:
index - 指标线。必须在0至7之间。 begin - 开始绘制指标线的柱体编号。
示例:
int init()
{
//----使用2个额外的缓冲区用于计算。
IndicatorBuffers(3);
//----画线设置
SetIndexStyle(0,DRAW_HISTOGRAM,STYLE_SOLID,3);
SetIndexDrawBegin(0,SignalSMA);
IndicatorDigits(MarketInfo(Symbol(),MODE_DIGITS)+2);
//---- 设置 3 个指标缓冲区位置
SetIndexBuffer(0,ind_buffer1);
SetIndexBuffer(1,ind_buffer2);
SetIndexBuffer(2,ind_buffer3);
//---- DataWindow 和自定义子窗口标签名称
IndicatorShortName("OsMA("+FastEMA+","+SlowEMA+","+SignalSMA+")");
//---- 初始化完成
return(0);
}
SetIndexEmptyValue() – 设置图表画线空值
void SetIndexEmptyValue(int index, double value)
设置图表画线空值。设置的值不绘出或不显示在数据窗口。默认值为 EMPTY VALUE。
参数:
index - 指标线。必须在0至7之间。 value - 设置的"空值"。
示例:
int init()
{
//----设置 2 个指标缓冲区位置
SetIndexBuffer(0,ExtUppperBuffer);
SetIndexBuffer(1,ExtLowerBuffer);
//---- 画出参数设置
SetIndexStyle(0,DRAW_ARROW);
SetIndexArrow(0,217);
SetIndexStyle(1,DRAW_ARROW);
SetIndexArrow(1,218);
//---- 值为 0 不显示
SetIndexEmptyValue(0,0.0);
SetIndexEmptyValue(1,0.0);
//----
SetIndexLabel(0,"Fractal Up");
SetIndexLabel(1,"Fractal Down");
//---- 初始化完成
return(0);
}
SetIndexLabel() – 设置指标线标签
void SetIndexLabel(int index, string text)
设置在数据窗口和快速提示中显示的指标线说明。
参数:
index - 指标线。必须在0至7之间。 text - 标签文本。NULL表示指标值在数据窗口中不显示。
示例:
//+------------------------------------------------------------------+
//| Ichimoku Kinko Hyo initialization function |
//+------------------------------------------------------------------+
int init()
{
//----
SetIndexStyle(0,DRAW_LINE);
SetIndexBuffer(0,Tenkan_Buffer);
SetIndexDrawBegin(0,Tenkan-1);
SetIndexLabel(0,"Tenkan Sen");
//----
SetIndexStyle(1,DRAW_LINE);
SetIndexBuffer(1,Kijun_Buffer);
SetIndexDrawBegin(1,Kijun-1);
SetIndexLabel(1,"Kijun Sen");
//----
a_begin=Kijun; if(a_begin<Tenkan) a_begin=Tenkan;
SetIndexStyle(2,DRAW_HISTOGRAM,STYLE_DOT);
SetIndexBuffer(2,SpanA_Buffer);
SetIndexDrawBegin(2,Kijun+a_begin-1);
SetIndexShift(2,Kijun);
//---- 在DataWindow窗口 Up Kumo 线不显示
SetIndexLabel(2,NULL);
SetIndexStyle(5,DRAW_LINE,STYLE_DOT);
SetIndexBuffer(5,SpanA2_Buffer);
SetIndexDrawBegin(5,Kijun+a_begin-1);
SetIndexShift(5,Kijun);
SetIndexLabel(5,"Senkou Span A");
//----
SetIndexStyle(3,DRAW_HISTOGRAM,STYLE_DOT);
SetIndexBuffer(3,SpanB_Buffer);
SetIndexDrawBegin(3,Kijun+Senkou-1);
SetIndexShift(3,Kijun);
//---- 在DataWindow窗口上 Down Kumo 线不显示
SetIndexLabel(3,NULL);
//----
SetIndexStyle(6,DRAW_LINE,STYLE_DOT);
SetIndexBuffer(6,SpanB2_Buffer);
SetIndexDrawBegin(6,Kijun+Senkou-1);
SetIndexShift(6,Kijun);
SetIndexLabel(6,"Senkou Span B");
//----
SetIndexStyle(4,DRAW_LINE);
SetIndexBuffer(4,Chinkou_Buffer);
SetIndexShift(4,-Kijun);
SetIndexLabel(4,"Chinkou Span");
//----
return(0);
}
SetIndexShift() – 设置指标线偏移值
void SetIndexShift(int index, int shift)
设置在数据窗口和快速提示中显示的指标线说明。
参数:
index - 指标线。必须在0至7之间。 shift - 柱体(K线)偏移值。
示例:
//+------------------------------------------------------------------+
//| Alligator initialization function |
//+------------------------------------------------------------------+
int init()
{
//----当画线时指标线的偏移
SetIndexShift(0,JawsShift);
SetIndexShift(1,TeethShift);
SetIndexShift(2,LipsShift);
//---- 当画线时指标线跳过的位置
SetIndexDrawBegin(0,JawsShift+JawsPeriod);
SetIndexDrawBegin(1,TeethShift+TeethPeriod);
SetIndexDrawBegin(2,LipsShift+LipsPeriod);
//---- 设置 3 个指标缓冲区位置
SetIndexBuffer(0,ExtBlueBuffer);
SetIndexBuffer(1,ExtRedBuffer);
SetIndexBuffer(2,ExtLimeBuffer);
//---- 画出设置
SetIndexStyle(0,DRAW_LINE);
SetIndexStyle(1,DRAW_LINE);
SetIndexStyle(2,DRAW_LINE);
//---- 指标线标签文本
SetIndexLabel(0,"Gator Jaws");
SetIndexLabel(1,"Gator Teeth");
SetIndexLabel(2,"Gator Lips");
//---- 初始化完成
return(0);
}
SetIndexStyle() – 设置指标线样式
void SetIndexStyle(int index, int type, void style, void width, void clr)
为指定的指标线设置新类型、样式、宽度和颜色。
参数:
index - 指标线。必须在0至7之间。 type - 形状样式,可以是 划线形状样式列表 中任意一个。 style - 线型。可以应用一个像素的粗线,可以是 划线形状样式列表 其中一个。EMPTY值表示线型不变。 width - 线宽。有效值是1,2,3,4,5。EMPTY值表示线宽不变。 clr - 线的颜色。省略本参数表示颜色将保持不变
示例:
SetIndexStyle(3, DRAW_LINE, EMPTY, 2, Red);
SetLevelStyle() – 设置水平线样式
void SetLevelStyle(int draw_style, int line_width, void clr)
本函数设置输出到独立窗口的指标水平线的样式、宽度和颜色。
参数:
draw_style - 形状样式,可以是 划线形状样式列表 中任意一个。 line_width - 线宽。有效值是1,2,3,4,5。EMPTY值表示线宽不变。 clr - 线的颜色。空值CLR_NONE表示颜色不变。
示例:
//---- 红色单线显示水平 SetLevelStyle(STYLE_SOLID,2,Red)
SetLevelValue() – 设置水平线值
void SetLevelValue(int level, double value)
本函数设置在独立窗口输出的水平指标线的值。
参数:
level - 水平线编号,0到31。 value - 给出的水平线值。 clr - 线的颜色。空值CLR_NONE表示颜色不变。
示例:
SetLevelValue(1,3.14);
MyFxtop迈投-靠谱的外汇跟单社区,免费跟随高手做交易!
免责声明:本文系转载自网络,如有侵犯,请联系我们立即删除,另:本文仅代表作者个人观点,与迈投财经无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
著作权归作者所有。
商业转载请联系作者获得授权,非商业转载请注明出处。

MyFxTops邁投財經