From de704d4f87680600aa03782bcd905487e3e81e5f Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Tue, 06 Jan 2026 14:20:50 +0800
Subject: [PATCH] refactor(okxNewPrice): 优化MACD策略日志输出和交易逻辑

---
 src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/OrderInfoWs.java |   24 ++++++++++++++++++++----
 1 files changed, 20 insertions(+), 4 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/OrderInfoWs.java b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/OrderInfoWs.java
index 8f37385..ec8478f 100644
--- a/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/OrderInfoWs.java
+++ b/src/main/java/com/xcong/excoin/modules/okxNewPrice/okxWs/OrderInfoWs.java
@@ -107,7 +107,7 @@
                 String stateStr = TradeOrderWs.getAccountMap(accountName).get("state");
                 if (StrUtil.isNotBlank(stateStr) && state.equals(stateStr)){
                     // 使用账号特定的Map
-                    String positionAccountName = PositionsWs.initAccountName(accountName, side);
+                    String positionAccountName = PositionsWs.initAccountName(accountName, posSide);
                     Map<String, BigDecimal> positionsMap = PositionsWs.getAccountMap(positionAccountName);
                     WsMapBuild.saveBigDecimalToMap(positionsMap, CoinEnums.READY_STATE.name(), WsMapBuild.parseBigDecimalSafe(CoinEnums.READY_STATE_NO.getCode()));
 
@@ -118,9 +118,25 @@
 
                     TradeRequestParam tradeRequestParam = new TradeRequestParam();
                     tradeRequestParam.setAccountName(accountName);
-                    tradeRequestParam.setMarkPx(String.valueOf(avgPx));
-                    String fanfangxiangPosside = CoinEnums.POSSIDE_LONG.getCode().equals(posSide) ? CoinEnums.POSSIDE_SHORT.getCode() : CoinEnums.POSSIDE_LONG.getCode();
-                    tradeRequestParam.setPosSide(fanfangxiangPosside);
+                    BigDecimal zhiYingPx = getZhiYingPx(
+                            accountName,
+                            posSide,
+                            fillFee,
+                            WsMapBuild.parseBigDecimalSafe(InstrumentsWs.getAccountMap(accountName).get(CoinEnums.CTVAL.name())),
+                            WsMapBuild.parseBigDecimalSafe(accFillSz),
+                            WsMapBuild.parseBigDecimalSafe(InstrumentsWs.getAccountMap(accountName).get(CoinEnums.CONTRACTMULTIPLIER.name())),
+                            WsMapBuild.parseBigDecimalSafe(avgPx),
+                            WsMapBuild.parseBigDecimalSafe(CoinEnums.LEVERAGE.getCode())
+                    );
+                    tradeRequestParam.setMarkPx(String.valueOf(zhiYingPx));
+                    tradeRequestParam.setInstId(CoinEnums.HE_YUE.getCode());
+                    tradeRequestParam.setTdMode(CoinEnums.CROSS.getCode());
+                    tradeRequestParam.setPosSide(posSide);
+                    tradeRequestParam.setOrdType(CoinEnums.ORDTYPE_LIMIT.getCode());
+                    tradeRequestParam.setTradeType(OrderParamEnums.TRADE_YES.getValue());
+                    tradeRequestParam.setSide(CoinEnums.POSSIDE_LONG.getCode().equals(posSide) ? CoinEnums.SIDE_SELL.getCode() : CoinEnums.SIDE_BUY.getCode());
+                    tradeRequestParam.setClOrdId(WsParamBuild.getOrderNum(tradeRequestParam.getSide()));
+                    tradeRequestParam.setSz(accFillSz);
                     return tradeRequestParam;
 
                 }

--
Gitblit v1.9.1