From 86c38d586645e8ed14c32e1a69faf5540a27ff61 Mon Sep 17 00:00:00 2001 From: 张天森 <1292933220@qq.com> Date: 星期六, 08 十月 2022 15:01:28 +0800 Subject: [PATCH] update --- springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/McsGameServiceImpl.java | 208 ++++++++++++++++++++++++++++++++++++---------------- 1 files changed, 144 insertions(+), 64 deletions(-) diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/McsGameServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/McsGameServiceImpl.java index 7af4dd0..67f7d1c 100644 --- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/McsGameServiceImpl.java +++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/McsGameServiceImpl.java @@ -2,28 +2,17 @@ import static java.util.Objects.isNull; import static java.util.Objects.nonNull; -import static org.apache.commons.lang3.StringUtils.isNotEmpty; +import java.util.ArrayList; import java.util.Date; import java.util.List; +import java.util.Random; import javax.annotation.Resource; -import com.alibaba.fastjson.JSONObject; -import com.panzhihua.common.model.vos.community.microCommercialStreet.McsCouponVO; -import com.panzhihua.common.model.vos.community.microCommercialStreet.McsEvaluateVO; -import com.panzhihua.common.model.vos.community.microCommercialStreet.McsMerchantVO; -import com.panzhihua.common.utlis.QRCodeUtils; -import com.panzhihua.common.utlis.Snowflake; -import com.panzhihua.service_community.dao.McsEvaluateDAO; -import com.panzhihua.service_community.entity.McsCoupon; -import com.panzhihua.service_community.entity.McsEvaluate; -import com.panzhihua.service_community.util.NearbyUtil; -import com.panzhihua.service_community.util.QRCodeUtil; -import com.spatial4j.core.shape.Rectangle; -import org.apache.commons.lang3.RandomUtils; import org.springframework.beans.BeanUtils; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; @@ -34,16 +23,20 @@ import com.panzhihua.common.model.dtos.community.microCommercialStreet.SetPopularForGameDTO; import com.panzhihua.common.model.dtos.community.microCommercialStreet.SetShelfForGameDTO; import com.panzhihua.common.model.vos.R; +import com.panzhihua.common.model.vos.community.microCommercialStreet.McsCouponVO; import com.panzhihua.common.model.vos.community.microCommercialStreet.McsGameVO; import com.panzhihua.common.model.vos.community.microCommercialStreet.TopStatisticsVO; import com.panzhihua.common.utlis.DateUtils; +import com.panzhihua.common.utlis.Snowflake; import com.panzhihua.service_community.dao.McsCouponDAO; +import com.panzhihua.service_community.dao.McsEvaluateDAO; import com.panzhihua.service_community.dao.McsGameDAO; import com.panzhihua.service_community.dao.McsMerchantDAO; +import com.panzhihua.service_community.entity.McsCoupon; import com.panzhihua.service_community.entity.McsGame; import com.panzhihua.service_community.entity.McsMerchant; import com.panzhihua.service_community.service.McsGameService; -import org.springframework.transaction.annotation.Transactional; +import com.panzhihua.service_community.util.QRCodeUtil; /** * (McsGame)表服务实现类 @@ -236,6 +229,9 @@ } Integer beforeCoins = mcsGame.getCoins(); Integer beforeSurplusCoins = mcsGame.getSurplusCoins(); + if (isNull(beforeSurplusCoins)) { + beforeSurplusCoins = beforeCoins; + } Integer beforeUsedCoins = beforeCoins - beforeSurplusCoins; Integer surplusCoins = coins - beforeUsedCoins; if (surplusCoins < 0) { @@ -320,10 +316,11 @@ /** * 戳戳游戏顶部统计数据 * @param userId + * @param type * @return */ @Override - public R getTopStatistics(Long userId) { + public R getTopStatistics(Long userId, Integer type) { McsMerchant mcsMerchant = mcsMerchantDAO.selectOne(new QueryWrapper<McsMerchant>().lambda().eq(McsMerchant::getUserId, userId)); if (isNull(mcsMerchant)) { return R.fail("未查询到商家信息"); @@ -331,12 +328,12 @@ TopStatisticsVO topStatisticsVO = new TopStatisticsVO(); topStatisticsVO.setExpireAt(mcsMerchant.getExpireAt()); if (nonNull(mcsMerchant.getExpireAt())) { - int surplusLitDays = DateUtils.differentDays(new Date(), mcsMerchant.getExpireAt()); + int surplusLitDays = DateUtils.retrieveRemainingDays(mcsMerchant.getExpireAt()); topStatisticsVO.setSurplusLitDays(surplusLitDays > 0 ? surplusLitDays : 0); } - Integer appliedCount = this.baseMapper.selectAppliedCount(mcsMerchant.getId()); + Integer appliedCount = this.baseMapper.selectAppliedCount(mcsMerchant.getId(), type); topStatisticsVO.setAppliedTotal(appliedCount); - Integer verifiedCount = this.baseMapper.selectVerifiedCount(mcsMerchant.getId()); + Integer verifiedCount = this.baseMapper.selectVerifiedCount(mcsMerchant.getId(), type); topStatisticsVO.setVerifiedTotal(verifiedCount); Integer publishLimit = mcsMerchant.getPublishLimit(); @@ -379,6 +376,11 @@ Integer allocation = mcsGame.getAllocation(); if (allocation.equals(1)) { //随机分配 + Integer surplusCoins = mcsGame.getSurplusCoins(); + Integer coin = getRandomCoins(surplusCoins, mcsGame.getSurplusCoupons()); + mcsCoupon.setCoin(coin); + mcsCoupon.setAward("戳戳币:" + coin); + mcsGame.setSurplusCoins(surplusCoins - coin); } else { //固定值 mcsCoupon.setCoin(mcsGame.getCoins()); @@ -388,9 +390,13 @@ //体验游戏 Integer awardType = mcsGame.getAwardType(); if (awardType.equals(1)) { - mcsCoupon.setAward("免费产品"); + mcsCoupon.setAward("免费领"); + } else if (awardType.equals(2)) { + mcsCoupon.setAward("产品试用"); + } else if (awardType.equals(3)) { + mcsCoupon.setAward("消费赠礼"); } else { - mcsCoupon.setAward("免费服务"); + mcsCoupon.setAward("优惠券"); } } int num = mcsCouponDAO.insert(mcsCoupon); @@ -417,19 +423,7 @@ Page page = new Page<>(); page.setSize(pageMcsGameDTO.getPageSize()); page.setCurrent(pageMcsGameDTO.getPageNum()); - String lat = pageMcsGameDTO.getLat(); - String lon = pageMcsGameDTO.getLon(); - Integer distance = pageMcsGameDTO.getDistance(); - IPage<McsGameVO> mcsGames; - if (isNotEmpty(lat) && isNotEmpty(lon) && nonNull(distance)) { - Rectangle rectangle = new NearbyUtil().getRectangle(pageMcsGameDTO.getDistance(), - Double.parseDouble(pageMcsGameDTO.getLon()), Double.parseDouble(pageMcsGameDTO.getLat())); - mcsGames = this.baseMapper.pageH5McsGame(page, rectangle.getMinX(), rectangle.getMaxX(), - rectangle.getMinY(), rectangle.getMaxY(), pageMcsGameDTO); - } else { - mcsGames = this.baseMapper.pageH5McsGame(page, null, null, null, null, pageMcsGameDTO); - } - + IPage<McsGameVO> mcsGames = this.baseMapper.pageH5McsGame(page, pageMcsGameDTO); return R.ok(mcsGames); } @@ -442,41 +436,127 @@ public R getMcsGame(Long gameId) { McsGameVO mcsGameVO = this.baseMapper.selectDetailById(gameId); Integer gameCount = this.baseMapper.selectCount(new QueryWrapper<McsGame>().lambda() - .eq(McsGame::getMerchantId, mcsGameVO.getMerchantId()).eq(McsGame::getIsDel, false)); + .eq(McsGame::getMerchantId, mcsGameVO.getMerchantId()).eq(McsGame::getStatus, McsGame.Status.jxz) + .eq(McsGame::getType, mcsGameVO.getType()).eq(McsGame::getIsDel, false)); mcsGameVO.setGameCount(gameCount); return R.ok(mcsGameVO); } - public static void main(String[] args) { - int total = 300; - int people = 10; - dispath(total, people, 30); - - } - - public static void dispath(int total, int people, int min) { - for (int i = 0; i < people - 1; i++) { - int leftPeople = people - i; - - double avg = Double.valueOf(total) / leftPeople; - - double ratio1 = RandomUtils.nextInt(0, 3); - - double ratio2 = RandomUtils.nextInt(0, 1); - - double ratio = ratio1 + ratio2; - - int cur = (int) Math.floor(ratio * avg) > min ? (int) Math.floor(ratio * avg) : min; - - // 扣减总额阅点数目 - - total = total - cur; - - System.out.format("第 %d 个红包: %d 阅点,剩下: %d 阅点\n", i + 1, cur,total); + /** + * 定时任务-每隔5分钟执行一次,将已到期的微商业街游戏结束 + * @return + */ + @Override + public R endStatusForMcsGame() { + List<McsGame> games = this.baseMapper.selectNeedDealExpire(); + if (nonNull(games) && !games.isEmpty()) { + games.forEach(e -> e.setStatus(McsGame.Status.yjs)); + this.updateBatchById(games); } - // 剩余的就是最后一个用户的阅点额度 - - System.out.format("第 %d 个红包: %d 阅点,剩下: 0 阅点\n", people, total); + return R.ok(); } + public static void main(String[] args) { + int total = 500; + int people = 10; + for (int i = 1;i <= 10; i++) { + Integer decrease = getRandomCoins(total, people); + total -= decrease; + people --; + System.out.println("第:" + i + "个人领取到:" + decrease + "戳戳币,总数还剩下:" + total); + } + } + + public static Integer getRandomCoins(int totalCoins, int peopleTotal) { + List<Integer> list = new ArrayList<>(peopleTotal); + if (peopleTotal == 1) { + return totalCoins; + } + Random random = new Random(); + // 平均分配 + int average = totalCoins / peopleTotal; + int max = (int) Math.floor(totalCoins * 0.6); + int min = (int) Math.floor(average * 0.5); + float thresh = 0.95F; + int rest = totalCoins - average * peopleTotal; + for (int i = 0; i < peopleTotal; i++) { + if (i < rest) { + list.add(average + 1); + } else { + list.add(average); + } + } + // 根据阀值进行数据随机处理 + int randOfRange = 0; + int randRom = 0; + int nextIndex = 0; + int nextValue = 0; + //多余 + int surplus = 0; + //缺少 + int lack = 0; + for (int i = 0; i < peopleTotal - 1; i++) { + nextIndex = i + 1; + int itemThis = list.get(i); + int itemNext = list.get(nextIndex); + boolean isLt = itemThis < itemNext; + int rangeThis = isLt ? max - itemThis : itemThis - min; + int rangeNext = isLt ? itemNext - min : max - itemNext; + int rangeFinal = (int) Math.ceil(thresh * (Math.min(rangeThis, rangeNext) + 1)); + randOfRange = random.nextInt(rangeFinal); + randRom = isLt ? 1 : -1; + int iValue = list.get(i) + randRom * randOfRange; + nextValue = list.get(nextIndex) + randRom * randOfRange * -1; + if (iValue > max) { + surplus += (iValue - max); + list.set(i, max); + } else if (iValue < min) { + list.set(i, min); + lack += (min - iValue); + } else { + list.set(i, iValue); + } + list.set(nextIndex, nextValue); + } + if (nextValue > max) { + surplus += (nextValue - max); + list.set(nextIndex, max); + } + if (nextValue < min) { + lack += (min - nextValue); + list.set(nextIndex, min); + } + if (surplus - lack > 0) { + //分少了 给低于max的凑到max + for (int i = 0; i < list.size(); i++) { + int value = list.get(i); + if (value < max) { + int tmp = max - value; + if (surplus >= tmp) { + surplus -= tmp; + list.set(i, max); + } else { + list.set(i, value + surplus); + return list.get(random.nextInt(list.size() - 1)); + } + } + } + } else if (lack - surplus > 0) { + //分多了 给超过高于min的人凑到min + for (int i = 0; i < list.size(); i++) { + int value = list.get(i); + if (value > min) { + int tmp = value - min; + if (lack >= tmp) { + lack -= tmp; + list.set(i, min); + } else { + list.set(i, min + tmp - lack); + return list.get(random.nextInt(list.size() - 1)); + } + } + } + } + return list.get(random.nextInt(list.size() - 1)); + } } -- Gitblit v1.7.1