MT4编程实例:会变色的均线

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

要隐藏一条指标线中的其中一段,也很简单,只要把这一段指标线的值赋为空值(EMPTY_VALUE)就行了。要让红线、绿线连续,必须使3点位上,既有绿线值又有红线值,这样2和3之间才能出现红线,红线绿才会连续。
3.jpg (10.63 KB)

2008-10-16 09:29
为了做到这一点,我们在给指标线循环赋值的时候:

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=EMPTY_VALUE;
kong=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=temp0; duo[i+1]=temp1;}
else {kong=temp0; kong[i+1]=temp1;}
}




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

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

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

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

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=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函数结束,返回零值
  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下是一个简单的均线交易系统的代码: ``` extern int MA_Period = 20; // 均线周期 extern double Stop_Loss = 50; // 止损,以点为单位 extern double Take_Profit = 100; // 止盈,以点为单位 int start() { // 计算均线 double ma = iMA(NULL, 0, MA_Period, 0, MODE_SMA, PRICE_CLOSE, 0); // 获取当前持仓情况 int positions = PositionsTotal(); for (int i = 0; i < positions; i++) { // 获取持仓信息 ulong ticket = PositionGetTicket(i); double lots = PositionGetDouble(POSITION_VOLUME); double open_price = PositionGetDouble(POSITION_PRICE_OPEN); // 判断是否达到止损或止盈 if (PositionGetDouble(POSITION_PROFIT) <= -Stop_Loss * Point) { // 达到止损,平仓 OrderClose(ticket, lots, Bid, 3, Red); } else if (PositionGetDouble(POSITION_PROFIT) >= Take_Profit * Point) { // 达到止盈,平仓 OrderClose(ticket, lots, Bid, 3, Green); } } // 判断是否需要开仓 if (Close[0] > ma) { // 当前价格在均线上方,开多仓 double lots = NormalizeDouble(AccountFreeMargin() * 0.1 / Stop_Loss, 2); if (lots > 0) { OrderSend(NULL, OP_BUY, lots, Ask, 3, Ask - Stop_Loss * Point, Ask + Take_Profit * Point, "MA Trading", 0, 0, Green); } } else if (Close[0] < ma) { // 当前价格在均线下方,开空仓 double lots = NormalizeDouble(AccountFreeMargin() * 0.1 / Stop_Loss, 2); if (lots > 0) { OrderSend(NULL, OP_SELL, lots, Bid, 3, Bid + Stop_Loss * Point, Bid - Take_Profit * Point, "MA Trading", 0, 0, Red); } } return 0; } ``` 以上代码在每个tick时刻检查均线的位置,如果价格在均线上方,就开多仓;如果价格在均线下方,就开空仓。同时,它每个tick时刻检查已经开仓的持仓情况,如果达到止损或止盈,就平仓。其中,止损和止盈的点数可以通过外部输入参数进行设置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值