From 6cdfe1d568d06bc63bb513ce0ef1df6aac3c7c3d Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Sat, 20 Feb 2021 15:32:12 +0800 Subject: [PATCH] fix --- src/main/java/com/xcong/excoin/utils/CalculateUtil.java | 21 ++++++++------------- 1 files changed, 8 insertions(+), 13 deletions(-) diff --git a/src/main/java/com/xcong/excoin/utils/CalculateUtil.java b/src/main/java/com/xcong/excoin/utils/CalculateUtil.java index bf4d078..0ef6ae6 100644 --- a/src/main/java/com/xcong/excoin/utils/CalculateUtil.java +++ b/src/main/java/com/xcong/excoin/utils/CalculateUtil.java @@ -1,7 +1,9 @@ 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; @@ -16,7 +18,7 @@ /** * 计算预估强平价 * - * @param bondAmount 保证金 + * @param bondAmount 保证金 * @param openPrice 开仓价 * @param symbolSkuNumber 张数 * @param lotNumber 规格 @@ -25,25 +27,18 @@ */ public static BigDecimal getForceSetPrice(BigDecimal bondAmount, BigDecimal openPrice, int symbolSkuNumber, BigDecimal lotNumber, int type, MemberEntity member) { - CacheSettingUtils cacheSettingUtils = SpringContextHolder.getBean(CacheSettingUtils.class); - PlatformTradeSettingEntity tradeSetting = cacheSettingUtils.getTradeSetting(); + 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) { - log.info("---->{}", money); - log.info("------>{}", openPrice); forcePrice = money.add(openPrice); - if (member.getIsProfit() == 1) { - //预估强平价 = 预估强平价-预估强平价*系数 - forcePrice = forcePrice.subtract(forcePrice.multiply(tradeSetting.getForceParam())); - } } else {//开多 forcePrice = openPrice.subtract(money); - if (member.getIsProfit() == 1) { - //预估强平价 = 预估强平价-预估强平价*系数 - forcePrice = forcePrice.add(forcePrice.multiply(tradeSetting.getForceParam())); - } } if (forcePrice.compareTo(BigDecimal.ZERO) < 0) { forcePrice = BigDecimal.ZERO; -- Gitblit v1.9.1