Summary: 黄金顶点追踪EA是一款专为XAUUSD设计的MQL4智能交易系统。结合多时间框架EMA趋势过滤、ADX趋势强度验证、ATR波动率保护以及受控分层加仓和整体止盈,适合H4周期稳定运行。
黄金顶点追踪EA专为黄金(XAUUSD)设计,采用纪律严明的趋势跟踪方法,配备多重验证层。与盲目累积仓位的激进网格或马丁格尔系统不同,本EA等待H1和H4时间框架的结构对齐,在入场前需要EMA确认和ADX趋势强度双重验证。趋势确认后,EA以固定初始手数入场,并在趋势继续有利时最多追加两层仓位(受控分层,无马丁格尔递进)。EA包含基于ATR的波动率过滤以规避极端市场条件,整体止盈机制在达到组合盈利目标时平仓所有头寸,以及每日净值保护和周五平仓机制。这种设计优先考虑稳定性和资金保全而非激进收益。
推荐加载周期: H4
策略核心逻辑:
1. 多时间框架对齐:H4 EMA(100)定义主趋势方向;H1 EMA(50)必须同向。
2. 趋势强度验证:ADX(14)必须超过25,确保市场处于趋势状态。
3. 入场触发:价格收盘突破近期20根K线的波段高点(做多)或波段低点(做空),伴随动量确认。
4. 受控分层加仓:最多追加2个仓位(共3单),仅在价格从前序入场价有利移动1.2倍ATR时触发。
5. 波动率保护:当前ATR(14)不得超过50周期平均ATR的1.8倍。
6. 风险管理:基于ATR的固定止损(1.5倍ATR),止盈2.5倍ATR,整体止盈150点,每日亏损上限5%。
```mql4
//+------------------------------------------------------------------+
//| GoldApexTrackerEA.mq4 |
//| |
//+------------------------------------------------------------------+
#property copyright ""
#property link ""
#property version "1.00"
#property strict
//--- 输入参数及注释
input double LotSize = 0.01; // 固定交易手数(黄金0.01手)
input int H4TrendPeriod = 100; // H4 EMA周期(主趋势方向)
input int H1TrendPeriod = 50; // H1 EMA周期(趋势对齐)
input int StructureLookback = 20; // 结构高低点回溯K线数
input int ADXPeriod = 14; // ADX周期(趋势强度)
input int ADXThreshold = 25; // 最小ADX阈值(趋势市场要求)
input int ATRPeriod = 14; // ATR波动率周期
input double ATRMaxMultiplier = 1.8; // 最大ATR倍数(波动率保护)
input double ATRStopMultiplier = 1.5; // 止损倍数(ATR倍数)
input double ATRTakeMultiplier = 2.5; // 止盈倍数(ATR倍数)
input double LayerDistanceATR = 1.2; // 分层加仓距离(ATR倍数)
input int MaxLayers = 3; // 最大分层数(含首单)
input double BasketProfitPoints = 150; // 整体止盈点数
input double TrailingStartATR = 1.0; // 追踪止损启动(盈利达到x倍ATR)
input double TrailingStepATR = 0.5; // 追踪步长(ATR倍数)
input int MagicNumber = 202422; // EA魔术号
input int MaxSpread = 35; // 最大允许点差(黄金单位:点)
input double DailyLossLimit = 5.0; // 每日亏损限额(账户余额百分比)
input bool UseFridayClose = true; // 周五21:00 GMT前平仓
//--- 全局变量
double dailyStartBalance = 0;
datetime lastBarTime = 0;
bool fridayCloseExecuted = false;
double avgATR = 0;
double structureHigh = 0;
double structureLow = 0;
int lastDirection = 0;
//+------------------------------------------------------------------+
//| EA初始化函数 |
//+------------------------------------------------------------------+
int OnInit()
{
dailyStartBalance = AccountBalance();
lastBarTime = 0;
fridayCloseExecuted = false;
avgATR = iATR(Symbol(), PERIOD_H4, ATRPeriod, 1);
if(avgATR <= 0) avgATR = 300 * Point;
lastDirection = 0;
return(INIT_SUCCEEDED);
}
//+------------------------------------------------------------------+
//| EA退出函数 |
//+------------------------------------------------------------------+
void OnDeinit(const int reason)
{
Comment("");
}
//+------------------------------------------------------------------+
//| 检测结构波段水平 |
//+------------------------------------------------------------------+
void DetectStructureLevels()
{
int highestIdx = iHighest(Symbol(), PERIOD_H4, MODE_HIGH, StructureLookback, 1);
int lowestIdx = iLowest(Symbol(), PERIOD_H4, MODE_LOW, StructureLookback, 1);
if(highestIdx > 0)
structureHigh = iHigh(Symbol(), PERIOD_H4, highestIdx);
if(lowestIdx > 0)
structureLow = iLow(Symbol(), PERIOD_H4, lowestIdx);
}
//+------------------------------------------------------------------+
//| 获取多时间框架趋势对齐 |
//+------------------------------------------------------------------+
int GetTrendAlignment()
{
double closeH4 = iClose(Symbol(), PERIOD_H4, 1);
double emaH4 = iMA(Symbol(), PERIOD_H4, H4TrendPeriod, 0, MODE_EMA, PRICE_CLOSE, 1);
double closeH1 = iClose(Symbol(), PERIOD_H1, 1);
double emaH1 = iMA(Symbol(), PERIOD_H1, H1TrendPeriod, 0, MODE_EMA, PRICE_CLOSE, 1);
bool h4Bullish = (closeH4 > emaH4);
bool h4Bearish = (closeH4 < emaH4);
bool h1Bullish = (closeH1 > emaH1);
bool h1Bearish = (closeH1 < emaH1);
if(h4Bullish && h1Bullish) return 1;
if(h4Bearish && h1Bearish) return -1;
return 0;
}
//+------------------------------------------------------------------+
//| 检查ADX趋势强度 |
//+------------------------------------------------------------------+
bool IsTrendStrong()
{
double adx = iADX(Symbol(), PERIOD_H4, ADXPeriod, PRICE_CLOSE, MODE_MAIN, 1);
return (adx >= ADXThreshold);
}
//+------------------------------------------------------------------+
//| 计算整体持仓浮动盈亏 |
//+------------------------------------------------------------------+
double CalculateBasketProfit()
{
double totalProfit = 0;
for(int i = OrdersTotal()-1; i >= 0; i--)
{
if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == MagicNumber)
{
totalProfit += OrderProfit() + OrderSwap() + OrderCommission();
}
}
}
return totalProfit;
}
//+------------------------------------------------------------------+
//| 检查整体止盈条件 |
//+------------------------------------------------------------------+
bool CheckBasketTakeProfit()
{
double basketProfit = CalculateBasketProfit();
double targetAmount = BasketProfitPoints * Point * LotSize * 100;
if(targetAmount <= 0) targetAmount = 15.0;
if(basketProfit >= targetAmount)
{
CloseAllOrders();
Print("整体止盈触发,盈利:", basketProfit);
return true;
}
return false;
}
//+------------------------------------------------------------------+
//| 管理受控分层加仓 |
//+------------------------------------------------------------------+
void ManagePositionLayering(double atr)
{
int posCount = CountPositions();
if(posCount >= MaxLayers || posCount == 0) return;
// 获取首单方向和价格
int firstDirection = 0;
double firstOpenPrice = 0;
for(int i = OrdersTotal()-1; i >= 0; i--)
{
if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == MagicNumber)
{
firstDirection = (OrderType() == OP_BUY) ? 1 : -1;
firstOpenPrice = OrderOpenPrice();
break;
}
}
}
if(firstDirection == 0) return;
double addDistance = atr * LayerDistanceATR;
double currentPrice = (firstDirection == 1) ? Bid : Ask;
double priceDiff = MathAbs(currentPrice - firstOpenPrice);
// 价格有利移动足够距离且未超最大层数时加仓
if(priceDiff >= addDistance && posCount < MaxLayers)
{
double sl = 0, tp = 0;
int cmd = firstDirection;
if(cmd == OP_BUY)
{
sl = currentPrice - (atr * ATRStopMultiplier);
tp = currentPrice + (atr * ATRTakeMultiplier);
}
else
{
sl = currentPrice + (atr * ATRStopMultiplier);
tp = currentPrice - (atr * ATRTakeMultiplier);
}
int ticket = OrderSend(Symbol(), cmd, LotSize, currentPrice, 5, sl, tp, "Apex Layer", MagicNumber, 0, clrNONE);
if(ticket > 0)
Print("第 ", posCount+1, " 层加仓成功,方向:", cmd==OP_BUY?"买入":"卖出");
}
}
//+------------------------------------------------------------------+
//| 管理持仓的追踪止损 |
//+------------------------------------------------------------------+
void ManageTrailingStop(double atr)
{
for(int i = OrdersTotal()-1; i >= 0; i--)
{
if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == MagicNumber)
{
double activate = atr * TrailingStartATR;
double step = atr * TrailingStepATR;
double newSL = 0;
if(OrderType() == OP_BUY)
{
double profit = Bid - OrderOpenPrice();
if(profit >= activate)
{
newSL = Bid - step;
if(newSL > OrderStopLoss())
OrderModify(OrderTicket(), OrderOpenPrice(), newSL, OrderTakeProfit(), 0, clrNONE);
}
}
else if(OrderType() == OP_SELL)
{
double profit = OrderOpenPrice() - Ask;
if(profit >= activate)
{
newSL = Ask + step;
if(newSL < OrderStopLoss() || OrderStopLoss() == 0)
OrderModify(OrderTicket(), OrderOpenPrice(), newSL, OrderTakeProfit(), 0, clrNONE);
}
}
break;
}
}
}
}
//+------------------------------------------------------------------+
//| 检查结构突破入场条件 |
//+------------------------------------------------------------------+
bool CheckStructuralBreakout(int direction, double &entryPrice, double &sl, double &tp, double atr)
{
if(direction == 0) return false;
double close1 = iClose(Symbol(), PERIOD_H4, 1);
if(direction == 1 && structureHigh > 0)
{
if(close1 > structureHigh)
{
entryPrice = Ask;
sl = entryPrice - (atr * ATRStopMultiplier);
tp = entryPrice + (atr * ATRTakeMultiplier);
return true;
}
}
else if(direction == -1 && structureLow > 0)
{
if(close1 < structureLow)
{
entryPrice = Bid;
sl = entryPrice + (atr * ATRStopMultiplier);
tp = entryPrice - (atr * ATRTakeMultiplier);
return true;
}
}
return false;
}
//+------------------------------------------------------------------+
//| EA主循环函数(每Tick执行) |
//+------------------------------------------------------------------+
void OnTick()
{
// 每日净值保护
double currentEquity = AccountEquity();
double lossPercent = (dailyStartBalance - currentEquity) / dailyStartBalance * 100;
if(lossPercent >= DailyLossLimit)
{
Comment("已达每日亏损上限,停止开新仓");
return;
}
// 周五收盘前平仓(规避周末跳空)
if(UseFridayClose && !fridayCloseExecuted)
{
datetime currentTime = TimeCurrent();
if(TimeDayOfWeek(currentTime) == 5 && TimeHour(currentTime) >= 21)
{
CloseAllOrders();
fridayCloseExecuted = true;
return;
}
if(TimeDayOfWeek(currentTime) != 5)
fridayCloseExecuted = false;
}
// 点差过滤
if(MarketInfo(Symbol(), MODE_SPREAD) > MaxSpread)
{
Comment("当前点差过大:", MarketInfo(Symbol(), MODE_SPREAD));
return;
}
// 仅在新K线开始时检测入场(H4)
if(Time[0] == lastBarTime)
return;
lastBarTime = Time[0];
// 更新结构水平
DetectStructureLevels();
// 获取ATR用于波动率过滤
double atr = iATR(Symbol(), PERIOD_H4, ATRPeriod, 1);
if(atr > 0) avgATR = (avgATR * 0.95) + (atr * 0.05);
// 波动率保护
if(atr > avgATR * ATRMaxMultiplier && avgATR > 0)
{
Comment("当前波动率过高,ATR: ", atr);
return;
}
// 管理现有持仓
int posCount = CountPositions();
if(posCount > 0)
{
CheckBasketTakeProfit();
ManagePositionLayering(atr);
ManageTrailingStop(atr);
return;
}
// 检查趋势对齐
int trendDirection = GetTrendAlignment();
if(trendDirection == 0)
{
Comment("H4与H1趋势方向不一致");
return;
}
// 检查ADX趋势强度
if(!IsTrendStrong())
{
Comment("ADX低于阈值,无明确趋势");
return;
}
// 检查结构突破入场
double entryPrice = 0, sl = 0, tp = 0;
if(CheckStructuralBreakout(trendDirection, entryPrice, sl, tp, atr))
{
int cmd = (trendDirection == 1) ? OP_BUY : OP_SELL;
int ticket = OrderSend(Symbol(), cmd, LotSize, entryPrice, 5, sl, tp, "Apex Entry", MagicNumber, 0, clrNONE);
if(ticket < 0)
Print("开仓失败,错误码:", GetLastError());
else
Print("结构突破开仓成功,方向:", cmd==OP_BUY?"买入":"卖出");
}
}
//+------------------------------------------------------------------+
//| 统计当前魔术号的持仓数量 |
//+------------------------------------------------------------------+
int CountPositions()
{
int count = 0;
for(int i = OrdersTotal()-1; i >= 0; i--)
{
if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == MagicNumber)
count++;
}
}
return count;
}
//+------------------------------------------------------------------+
//| 平仓当前品种下所有属于该EA的订单 |
//+------------------------------------------------------------------+
void CloseAllOrders()
{
for(int i = OrdersTotal()-1; i >= 0; i--)
{
if(OrderSelect(i, SELECT_BY_POS, MODE_TRADES))
{
if(OrderSymbol() == Symbol() && OrderMagicNumber() == MagicNumber)
{
if(OrderType() == OP_BUY)
OrderClose(OrderTicket(), OrderLots(), Bid, 5, clrNONE);
else if(OrderType() == OP_SELL)
OrderClose(OrderTicket(), OrderLots(), Ask, 5, clrNONE);
}
}
}
}
//+------------------------------------------------------------------+
```
参考来源: 原创MQL4代码,策略架构参考了2026年6月近期发布的商业黄金EA的多层趋势确认原理。
免责声明: 黄金交易因高波动性具有重大风险。本EA按“原样”提供,不保证盈利。实盘部署前请在模拟账户充分测试。历史表现不代表未来结果。
```