From 34212a418d7b6c757ec2abce18612df674e84fad Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Wed, 03 Dec 2025 17:57:06 +0800
Subject: [PATCH] chore(config): 更新测试环境配置并添加新依赖
---
src/main/java/com/xcong/excoin/utils/CalculateUtil.java | 86 +++++++++++++++++++++---------------------
1 files changed, 43 insertions(+), 43 deletions(-)
diff --git a/src/main/java/com/xcong/excoin/utils/CalculateUtil.java b/src/main/java/com/xcong/excoin/utils/CalculateUtil.java
index 0551a28..0ef6ae6 100644
--- a/src/main/java/com/xcong/excoin/utils/CalculateUtil.java
+++ b/src/main/java/com/xcong/excoin/utils/CalculateUtil.java
@@ -1,48 +1,48 @@
-package com.kebex.common;
+package com.xcong.excoin.utils;
+
+
+import com.xcong.excoin.modules.member.dao.MemberSettingDao;
+import com.xcong.excoin.modules.member.entity.MemberEntity;
+import com.xcong.excoin.modules.member.entity.MemberSettingEntity;
+import com.xcong.excoin.modules.platform.entity.PlatformTradeSettingEntity;
+import lombok.extern.slf4j.Slf4j;
import java.math.BigDecimal;
-import com.kebex.app.entity.member.Member;
-import com.kebex.app.entity.trade.TradeSetting;
-import com.kebex.common.cache.TradeSettingCache;
+/**
+ * @author helius
+ */
+@Slf4j
+public class CalculateUtil {
-public class CaculateUtil {
-
- /**
- * 计算预估强平价
- *
- * @param prePrice 保证金
- * @param openPrice 开仓价
- * @param symbolSkuNumber 张数
- * @param lotNumber 规格
- * @param type 1:买多2:卖空
- * @return
- */
- public static BigDecimal getForceSetPrice(Double prePrice, Double openPrice, Long symbolSkuNumber, BigDecimal lotNumber,
- int type,Member member) {
- TradeSettingCache tradeSettingCache = WebUtil.getApplicationContext().getBean(TradeSettingCache.class);
- BigDecimal forcePrice = BigDecimal.ZERO;
- if (type == 2) {//卖空
- forcePrice = new BigDecimal(prePrice)
- .divide(new BigDecimal(symbolSkuNumber).multiply(lotNumber),8,BigDecimal.ROUND_DOWN)
- .add(new BigDecimal(openPrice));
- if(member.getIsProfit() == 1) {
- TradeSetting tradeSetting = tradeSettingCache.getTradeSetting();
- //预估强平价 = 预估强平价-预估强平价*系数
- forcePrice = forcePrice.subtract(forcePrice.multiply(new BigDecimal(tradeSetting.getForceParam())));
- }
- } else {//开多
- forcePrice = new BigDecimal(openPrice).subtract(new BigDecimal(prePrice)
- .divide(new BigDecimal(symbolSkuNumber).multiply(lotNumber),8,BigDecimal.ROUND_DOWN));
- if(member.getIsProfit() == 1) {
- TradeSetting tradeSetting = tradeSettingCache.getTradeSetting();
- //预估强平价 = 预估强平价-预估强平价*系数
- forcePrice = forcePrice.add(forcePrice.multiply(new BigDecimal(tradeSetting.getForceParam())));
- }
- }
- if(forcePrice.compareTo(BigDecimal.ZERO)<0) {
- forcePrice = BigDecimal.ZERO;
- }
- return forcePrice;
- }
+ /**
+ * 计算预估强平价
+ *
+ * @param bondAmount 保证金
+ * @param openPrice 开仓价
+ * @param symbolSkuNumber 张数
+ * @param lotNumber 规格
+ * @param type 1:买多2:卖空
+ * @return
+ */
+ public static BigDecimal getForceSetPrice(BigDecimal bondAmount, BigDecimal openPrice, int symbolSkuNumber, BigDecimal lotNumber,
+ int type, MemberEntity member) {
+ MemberSettingDao memberSettingDao = SpringContextHolder.getBean(MemberSettingDao.class);
+ BigDecimal forcePrice = BigDecimal.ZERO;
+ BigDecimal money = bondAmount.divide(new BigDecimal(symbolSkuNumber).multiply(lotNumber), 8, BigDecimal.ROUND_DOWN);
+ if (member.getIsForce() == 1) {
+ MemberSettingEntity memberSetting = memberSettingDao.selectMemberSettingByMemberId(member.getId());
+ money = money.multiply(memberSetting.getForceParam().multiply(BigDecimal.valueOf(100)));
+ }
+ //卖空
+ if (type == 2) {
+ forcePrice = money.add(openPrice);
+ } else {//开多
+ forcePrice = openPrice.subtract(money);
+ }
+ if (forcePrice.compareTo(BigDecimal.ZERO) < 0) {
+ forcePrice = BigDecimal.ZERO;
+ }
+ return forcePrice;
+ }
}
--
Gitblit v1.9.1