From 984dc83c2e93ee05d8ea57db5beec76a773d4716 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期五, 04 七月 2025 18:08:49 +0800
Subject: [PATCH] 部分代码

---
 ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TStudyServiceImpl.java | 1136 ++++++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 992 insertions(+), 144 deletions(-)

diff --git a/ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TStudyServiceImpl.java b/ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TStudyServiceImpl.java
index 60558ec..2f5da68 100644
--- a/ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TStudyServiceImpl.java
+++ b/ruoyi-service/ruoyi-study/src/main/java/com/ruoyi/study/service/impl/TStudyServiceImpl.java
@@ -1,8 +1,11 @@
 package com.ruoyi.study.service.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.common.core.constant.Constants;
+import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.exception.GlobalException;
+import com.ruoyi.common.core.web.domain.BaseModel;
 import com.ruoyi.study.domain.*;
 import com.ruoyi.study.dto.StudyWeekDTO;
 import com.ruoyi.study.mapper.TStudyMapper;
@@ -11,6 +14,8 @@
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
+import java.math.BigDecimal;
+import java.math.RoundingMode;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -45,6 +50,8 @@
     private ITGameService gameService;
     @Resource
     private ITStoryListenService storyListenService;
+    @Resource
+    private ITSubjectRecordDetailService subjectRecordDetailService;
 
     private final static Map<Integer, Integer> GAME_DIFFICULTY_MAP = new HashMap<>();
 
@@ -65,44 +72,76 @@
             Integer id = item.getId();
             // 计算总积分
             int total = 0;
+            List<Integer> dayList = new ArrayList<>();
             // 有问有答
-            List<TStudyAnswer> answerList = studyAnswerService.lambdaQuery().eq(TStudyAnswer::getStudyId, id)
+            List<TStudyAnswer> answerList = studyAnswerService.lambdaQuery()
+                    .eq(TStudyAnswer::getStudyId, id)
+                    .eq(TStudyAnswer::getWeek, week)
                     .eq(TStudyAnswer::getDisabled, 0).list();
-            Optional<TStudyAnswer> answerOptional = answerList.stream().findAny();
-            if (answerOptional.isPresent()) {
-                total += answerOptional.get().getIntegral();
+            for (TStudyAnswer data : answerList) {
+                Integer day = data.getDay();
+                if (!dayList.contains(day)) {
+                    total += data.getIntegral();
+                    dayList.add(day);
+                }
             }
+            dayList.clear();
             // 归纳判断
-            List<TStudyInduction> inductionList = studyInductionService.lambdaQuery().eq(TStudyInduction::getStudyId, id)
+            List<TStudyInduction> inductionList = studyInductionService.lambdaQuery()
+                    .eq(TStudyInduction::getStudyId, id)
+                    .eq(TStudyInduction::getWeek, week)
                     .eq(TStudyInduction::getDisabled, 0).list();
-            Optional<TStudyInduction> inductionOptional = inductionList.stream().findAny();
-            if (inductionOptional.isPresent()) {
-                total += inductionOptional.get().getIntegral();
+            for (TStudyInduction data : inductionList) {
+                Integer day = data.getDay();
+                if (!dayList.contains(day)) {
+                    total += data.getIntegral();
+                    dayList.add(day);
+                }
             }
+            dayList.clear();
             // 看图选音
-            List<TStudyLook> lookList = studyLookService.lambdaQuery().eq(TStudyLook::getStudyId, id)
+            List<TStudyLook> lookList = studyLookService.lambdaQuery()
+                    .eq(TStudyLook::getStudyId, id)
+                    .eq(TStudyLook::getWeek, week)
                     .eq(TStudyLook::getDisabled, 0).list();
-            Optional<TStudyLook> lookOptional = lookList.stream().findAny();
-            if (lookOptional.isPresent()) {
-                total += lookOptional.get().getIntegral();
+            for (TStudyLook data : lookList) {
+                Integer day = data.getDay();
+                if (!dayList.contains(day)) {
+                    total += data.getIntegral();
+                    dayList.add(day);
+                }
             }
+            dayList.clear();
             // 听音选图
-            List<TStudyListen> listenList = studyListenService.lambdaQuery().eq(TStudyListen::getStudyId, id)
+            List<TStudyListen> listenList = studyListenService.lambdaQuery()
+                    .eq(TStudyListen::getStudyId, id)
+                    .eq(TStudyListen::getWeek, week)
                     .eq(TStudyListen::getDisabled, 0).list();
-            Optional<TStudyListen> listenOptional = listenList.stream().findAny();
-            if (listenOptional.isPresent()) {
-                total += listenOptional.get().getIntegral();
+            for (TStudyListen data : listenList) {
+                Integer day = data.getDay();
+                if (!dayList.contains(day)) {
+                    total += data.getIntegral();
+                    dayList.add(day);
+                }
             }
+            dayList.clear();
             // 音图相配
-            List<TStudyPair> pairList = studyPairService.lambdaQuery().eq(TStudyPair::getStudyId, id)
+            List<TStudyPair> pairList = studyPairService.lambdaQuery()
+                    .eq(TStudyPair::getStudyId, id)
+                    .eq(TStudyPair::getWeek, week)
                     .eq(TStudyPair::getDisabled, 0).list();
-            Optional<TStudyPair> pairOptional = pairList.stream().findAny();
-            if (pairOptional.isPresent()) {
-                total += pairOptional.get().getIntegral();
+            for (TStudyPair data : pairList) {
+                Integer day = data.getDay();
+                if (!dayList.contains(day)) {
+                    total += data.getIntegral();
+                    dayList.add(day);
+                }
             }
+            dayList.clear();
             // 自主游戏
             List<TGame> gameList = gameService.lambdaQuery().eq(TGame::getStudyId, id)
-                    .eq(TGame::getDisabled, 0).list();
+                    .eq(TGame::getDisabled, 0)
+                    .eq(TGame::getWeek, week).list();
             // 自主游戏-超级听力
             List<String> gameIntegral = gameList.stream().map(TGame::getIntegral).collect(Collectors.toList());
             for (String s : gameIntegral) {
@@ -117,25 +156,115 @@
                 }
             }
             // 自主故事
-            List<TStoryListen> storyListenList = storyListenService.lambdaQuery().eq(TStoryListen::getStudyId, id)
+            List<TStoryListen> storyListenList = storyListenService.lambdaQuery()
+                    .eq(TStoryListen::getStudyId, id)
+                    .eq(TStoryListen::getWeek, week)
                     .eq(TStoryListen::getDisabled, 0).list();
             // 自主故事 - 框架记忆
             total += storyListenList.stream().map(TStoryListen::getIntegral).mapToInt(Integer::intValue).sum();
             // 自主故事 - 看图配音
             total += storyListenList.stream().map(TStoryListen::getLookIntegral).mapToInt(Integer::intValue).sum();
             // 判断周目是否可以进入学习
-            Boolean canStudy = checkWeekCanStudy(userId, item);
+            Boolean canStudy = checkWeekCanStudy(userId, item, week);
             result.add(new StudyWeekDTO(week, type, quarter, title, total, canStudy));
         }
         return result;
     }
 
+    @Override
+    public TUserStudy studySchedule(TUserStudy studyRecord, Integer week) {
+        // 剩余周目
+        List<TStudy> studyList = this.lambdaQuery().eq(TStudy::getDisabled, 0)
+                .eq(TStudy::getType, Constants.ONE)
+                .orderByAsc(TStudy::getWeek).list();
+        // 已学习到的周目
+        Integer studyWeek = studyRecord.getWeek();
+        // 学习到的季度
+        Integer studyQuarter = 1;
+        // 当前所点击进入的周目所属季度
+        Integer currentQuarter = 1;
+        // 根据季度分组封装
+        Map<Integer, List<TStudy>> integerListMap = getIntegerListMap(studyList);
+        for (Map.Entry<Integer, List<TStudy>> map : integerListMap.entrySet()) {
+            List<TStudy> list = map.getValue();
+            for (TStudy study : list) {
+                Integer itemWeek = study.getWeek();
+                if (studyWeek.equals(itemWeek)) {
+                    studyQuarter = map.getKey();
+                    break;
+                }
+            }
+            for (TStudy study : list) {
+                Integer itemWeek = study.getWeek();
+                if (week.equals(itemWeek)) {
+                    currentQuarter = map.getKey();
+                    break;
+                }
+            }
+        }
+        // 已学习季度 大于当前周目所属季度,所有学习均已完成
+        if (studyQuarter > currentQuarter) {
+            studyRecord.setWeek(week);
+            studyRecord.setDay(Constants.SIX);
+            studyRecord.setListen(Constants.ONE_HUNDRED);
+            studyRecord.setLook(Constants.ONE_HUNDRED);
+            studyRecord.setInduction(Constants.ONE_HUNDRED);
+            studyRecord.setAnswer(Constants.ONE_HUNDRED);
+            studyRecord.setPair(Constants.ONE_HUNDRED);
+            studyRecord.setGameDifficulty(Constants.TWO);
+            studyRecord.setComputeSchedule(Constants.ONE_HUNDRED);
+        } else if (studyQuarter < currentQuarter) {
+            studyRecord.setWeek(week);
+            studyRecord.setDay(Constants.ONE);
+            studyRecord.setListen(Constants.BURDEN_ONE);
+            studyRecord.setLook(Constants.BURDEN_ONE);
+            studyRecord.setInduction(Constants.BURDEN_ONE);
+            studyRecord.setAnswer(Constants.BURDEN_ONE);
+            studyRecord.setPair(Constants.BURDEN_ONE);
+            studyRecord.setGameDifficulty(null);
+            studyRecord.setComputeSchedule(Constants.ZERO);
+        } else {
+            List<TStudy> tStudies = integerListMap.get(studyQuarter);
+            List<Integer> weekList = tStudies.stream().map(TStudy::getWeek).collect(Collectors.toList());
+            int i = weekList.indexOf(studyWeek);
+            int i1 = weekList.indexOf(week);
+            if (i > i1) {
+                studyRecord.setWeek(week);
+                studyRecord.setDay(Constants.SIX);
+                studyRecord.setListen(Constants.ONE_HUNDRED);
+                studyRecord.setLook(Constants.ONE_HUNDRED);
+                studyRecord.setInduction(Constants.ONE_HUNDRED);
+                studyRecord.setAnswer(Constants.ONE_HUNDRED);
+                studyRecord.setPair(Constants.ONE_HUNDRED);
+                studyRecord.setGameDifficulty(Constants.TWO);
+                studyRecord.setComputeSchedule(Constants.ONE_HUNDRED);
+            } else if (i < i1) {
+                studyRecord.setWeek(week);
+                studyRecord.setDay(Constants.ONE);
+                studyRecord.setListen(Constants.BURDEN_ONE);
+                studyRecord.setLook(Constants.BURDEN_ONE);
+                studyRecord.setInduction(Constants.BURDEN_ONE);
+                studyRecord.setAnswer(Constants.BURDEN_ONE);
+                studyRecord.setPair(Constants.BURDEN_ONE);
+                studyRecord.setGameDifficulty(null);
+                studyRecord.setComputeSchedule(Constants.ZERO);
+            }
+        }
+        return studyRecord;
+    }
+
     /**
      * @param userId 用户id
+     * @param week   该季度下的周目
      * @return 当前周目是否学习
      */
-    private Boolean checkWeekCanStudy(Integer userId, TStudy study) {
-        TUserStudy userStudy = userStudyService.lambdaQuery().eq(TUserStudy::getUserId, userId)
+    private Boolean checkWeekCanStudyNew(Integer userId, TStudy study, Integer week) {
+        // 剩余周目
+        List<TStudy> studyList = this.lambdaQuery().eq(TStudy::getDisabled, 0)
+                .eq(TStudy::getType, Constants.ONE)
+                .orderByAsc(TStudy::getWeek).list();
+        TUserStudy userStudy = userStudyService.lambdaQuery()
+                .eq(TUserStudy::getUserId, userId)
                 .eq(TUserStudy::getDisabled, 0).one();
         if (null == userStudy) {
             userStudy = new TUserStudy();
@@ -156,13 +285,122 @@
             userStudy.setPair(Constants.BURDEN_ONE);
             userStudyService.save(userStudy);
         }
-        // 学习记录所属周目大于当前学习周目,判断为已学习
-        return userStudy.getWeek() >= study.getWeek();
+        // 获取当前学习周目为哪一个季度
+        TStudy studyQuarterVo = this.lambdaQuery()
+                .eq(TStudy::getWeek, userStudy.getWeek())
+                .eq(TStudy::getDisabled, 0).one();
+        // 已学习到的周目
+        Integer studyWeek = userStudy.getWeek();
+        // 学习到的季度
+        Integer studyQuarter = studyQuarterVo.getQuarter();
+        // 当前所点击进入的周目所属季度
+        Integer currentQuarter = 1;
+        // 根据季度分组封装
+        Map<Integer, List<TStudy>> integerListMap = getIntegerListMap(studyList);
+        for (Map.Entry<Integer, List<TStudy>> map : integerListMap.entrySet()) {
+            List<TStudy> list = map.getValue();
+//            for (TStudy data : list) {
+//                Integer itemWeek = data.getWeek();
+//                if (studyWeek.equals(itemWeek)) {
+//                    studyQuarter = map.getKey();
+//                    break;
+//                }
+//            }
+            for (TStudy data : list) {
+                Integer itemWeek = data.getWeek();
+                if (week.equals(itemWeek)) {
+                    currentQuarter = map.getKey();
+                    break;
+                }
+            }
+        }
+        // 已学习季度 大于当前周目所属季度,所有学习均已完成
+        if (studyQuarter > currentQuarter) {
+            return Boolean.TRUE;
+        } else if (studyQuarter < currentQuarter) {
+            return Boolean.FALSE;
+        } else {
+            List<TStudy> tStudies = integerListMap.get(studyQuarter);
+            List<Integer> weekList = tStudies.stream().map(TStudy::getWeek).collect(Collectors.toList());
+            int i = weekList.indexOf(studyWeek);
+            int i1 = weekList.indexOf(week);
+            if (i >= i1) {
+                return Boolean.TRUE;
+            } else {
+                return Boolean.FALSE;
+            }
+        }
     }
 
-    @Override
-    public TUserStudy studySchedule(String userId) {
-        return userStudyService.studySchedule(userId);
+    /**
+     * @param userId 用户id
+     * @return 当前周目是否学习
+     */
+    private Boolean checkWeekCanStudy(Integer userId, TStudy study, Integer week) {
+        // 剩余周目
+        List<TStudy> studyList = this.lambdaQuery().eq(TStudy::getDisabled, 0)
+                .eq(TStudy::getType, Constants.ONE)
+                .orderByAsc(TStudy::getWeek).list();
+        TUserStudy userStudy = userStudyService.lambdaQuery()
+                .eq(TUserStudy::getUserId, userId)
+                .eq(TUserStudy::getDisabled, 0).one();
+        if (null == userStudy) {
+            userStudy = new TUserStudy();
+            userStudy.setUserId(userId);
+            // 学习周目
+            TStudy tStudy = this.lambdaQuery().eq(TStudy::getQuarter, Constants.ONE)
+                    .orderByAsc(TStudy::getWeek).last("limit 1").one();
+            userStudy.setWeek(tStudy.getWeek());
+            userStudy.setDay(Constants.ONE);
+            userStudy.setTotalStudy(Constants.ZERO);
+            userStudy.setTodayStudy(Constants.ZERO);
+            userStudy.setWeekStudy(Constants.ZERO);
+            userStudy.setMonthStudy(Constants.ZERO);
+            userStudy.setListen(Constants.BURDEN_ONE);
+            userStudy.setLook(Constants.BURDEN_ONE);
+            userStudy.setInduction(Constants.BURDEN_ONE);
+            userStudy.setAnswer(Constants.BURDEN_ONE);
+            userStudy.setPair(Constants.BURDEN_ONE);
+            userStudyService.save(userStudy);
+        }
+        // 获取当前学习周目为哪一个季度
+        TStudy studyQuarterVo = this.lambdaQuery()
+                .eq(TStudy::getWeek, userStudy.getWeek())
+                .eq(TStudy::getDisabled, 0).one();
+        // 已学习到的周目
+        Integer studyWeek = userStudy.getWeek();
+        // 学习到的季度
+        Integer studyQuarter = studyQuarterVo.getQuarter();
+        // 当前所点击进入的周目所属季度
+        Integer currentQuarter = 1;
+        // 根据季度分组封装
+        Map<Integer, List<TStudy>> integerListMap = getIntegerListMap(studyList);
+        for (Map.Entry<Integer, List<TStudy>> map : integerListMap.entrySet()) {
+            List<TStudy> list = map.getValue();
+            for (TStudy data : list) {
+                Integer itemWeek = data.getWeek();
+                if (week.equals(itemWeek)) {
+                    currentQuarter = map.getKey();
+                    break;
+                }
+            }
+        }
+        // 已学习季度 大于当前周目所属季度,所有学习均已完成
+        if (studyQuarter > currentQuarter) {
+            return Boolean.TRUE;
+        } else if (studyQuarter < currentQuarter) {
+            return Boolean.FALSE;
+        } else {
+            List<TStudy> tStudies = integerListMap.get(studyQuarter);
+            List<Integer> weekList = tStudies.stream().map(TStudy::getWeek).collect(Collectors.toList());
+            int i = weekList.indexOf(studyWeek);
+            int i1 = weekList.indexOf(week);
+            if (i >= i1) {
+                return Boolean.TRUE;
+            } else {
+                return Boolean.FALSE;
+            }
+        }
     }
 
     @Override
@@ -187,7 +425,7 @@
     }
 
     @Override
-    public StudyListenResultVO listenSelectPicture(Integer week, Integer day, List<TStudyListen> studyListens) {
+    public StudyListenResultVO listenSelectPicture(Integer week, Integer day, List<TStudyListen> studyListens, Integer userid) {
         if (studyListens.isEmpty()) {
             throw new GlobalException("当前学习周目题目数量不足!");
         }
@@ -205,22 +443,103 @@
         learnStudy.setIntegral(total);
         // 语音及图片
         List<List<TSubject>> subjectList = new ArrayList<>();
-        for (TStudyListen studyListen : studyListens) {
-            List<String> subjectIds = Arrays.stream(studyListen.getSubject().split(",")).collect(Collectors.toList());
-            List<TSubject> list = new ArrayList<>();
-            // 图片及语音集合
-            for (String id : subjectIds) {
-                TSubject data = subjectService.lambdaQuery().eq(TSubject::getId, id)
-                        .eq(TSubject::getDisabled, 0).one();
-                list.add(data);
+
+        StudyListenResultVO studyListenResultVO = new StudyListenResultVO(learnStudy, subjectList);
+        List<TSubjectRecordDetail> subjectRecordDetails = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week).ne(BaseModel::getDisabled, 0).list();
+        List<TSubjectRecordDetail> listenList = subjectRecordDetails.stream().filter(e -> e.getType() == 1).collect(Collectors.toList());
+        int listenPass = (int) listenList.stream().filter(e -> e.getStatus() == 2).count();
+        int listenSize = listenList.size();
+        if (listenSize!=0){
+            // 计算当前通关率
+            double listenRate = (double) listenPass /listenSize;
+            TStudyListen one = studyListenService.lambdaQuery().eq(TStudyListen::getWeek, week)
+                    .eq(TStudyListen::getDay, 1).last("limit 1").one();
+            if (one!=null){
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    // 清空答题记录
+                    subjectRecordDetailService.remove(new LambdaQueryWrapper<TSubjectRecordDetail>()
+                            .eq(TSubjectRecordDetail::getUserId, userid)
+                            .eq(TSubjectRecordDetail::getWeek, week)
+                            .eq(TSubjectRecordDetail::getDay,day)
+                            .eq(TSubjectRecordDetail::getType
+                            ,1));
+                }
             }
-            subjectList.add(list);
         }
-        return new StudyListenResultVO(learnStudy, subjectList);
+        List<TSubjectRecordDetail> list = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week)
+                .eq(TSubjectRecordDetail::getDay, day)
+                .eq(TSubjectRecordDetail::getType, 1).list();
+        if (list.isEmpty()) {
+            List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
+            for (TStudyListen studyListen : studyListens) {
+                List<String> subjectIds = Arrays.stream(studyListen.getSubject().split(",")).collect(Collectors.toList());
+                List<TSubject> subs = new ArrayList<>();
+                // 图片及语音集合
+                for (String id : subjectIds) {
+                    TSubject data = subjectService.lambdaQuery().eq(TSubject::getId, id)
+                            .eq(TSubject::getDisabled, 0).one();
+                    subs.add(data);
+                    TSubjectRecordDetail tSubjectRecordDetail = new TSubjectRecordDetail();
+                    tSubjectRecordDetail.setUserId(userid);
+                    tSubjectRecordDetail.setWeek(week);
+                    tSubjectRecordDetail.setDay(day);
+                    tSubjectRecordDetail.setType(1);
+                    tSubjectRecordDetail.setStatus(1);
+                    tSubjectRecordDetail.setObjectId(studyListen.getId());
+                    tSubjectRecordDetails.add(tSubjectRecordDetail);
+                }
+                subjectList.add(subs);
+            }
+            subjectRecordDetailService.saveBatch(tSubjectRecordDetails);
+            studyListenResultVO.setList(tSubjectRecordDetails);
+            studyListenResultVO.setAccuracy(new BigDecimal("0.00"));
+
+        } else {
+
+            List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
+            for (TStudyListen studyListen : studyListens) {
+                List<String> subjectIds = Arrays.stream(studyListen.getSubject().split(",")).collect(Collectors.toList());
+                List<TSubject> subs = new ArrayList<>();
+                // 图片及语音集合
+                for (String id : subjectIds) {
+                    TSubject data = subjectService.lambdaQuery().eq(TSubject::getId, id)
+                            .eq(TSubject::getDisabled, 0).one();
+                    subs.add(data);
+                }
+                subjectList.add(subs);
+                List<TSubjectRecordDetail> tSubjectRecordDetail1 = list.stream().filter(e -> e.getObjectId().equals(studyListen.getId())).collect(Collectors.toList());
+
+                if (tSubjectRecordDetail1.isEmpty()){
+                    for (int i = 0; i < 4; i++) {
+                        TSubjectRecordDetail tSubjectRecordDetail = new TSubjectRecordDetail();
+                        tSubjectRecordDetail.setUserId(userid);
+                        tSubjectRecordDetail.setWeek(week);
+                        tSubjectRecordDetail.setDay(day);
+                        tSubjectRecordDetail.setType(1);
+                        tSubjectRecordDetail.setStatus(1);
+                        tSubjectRecordDetail.setObjectId(studyListen.getId());
+                        tSubjectRecordDetails.add(tSubjectRecordDetail);
+                    }
+                    subjectRecordDetailService.saveBatch(tSubjectRecordDetails);
+                }else{
+                    tSubjectRecordDetails.addAll(tSubjectRecordDetail1);
+                }
+            }
+
+            studyListenResultVO.setList(tSubjectRecordDetails);
+            // 计算正确率
+            BigDecimal accuracy = new BigDecimal(tSubjectRecordDetails.stream().filter(tSubjectRecordDetail -> tSubjectRecordDetail.getStatus().equals(2)).count())
+                    .divide(new BigDecimal(tSubjectRecordDetails.size()), 2, RoundingMode.HALF_UP);
+            studyListenResultVO.setAccuracy(accuracy);
+        }
+        studyListenResultVO.setSubjectList(subjectList);
+        return studyListenResultVO;
     }
 
     @Override
-    public StudyLookResultVO pictureSelectVoice(Integer week, Integer day, List<TStudyLook> lookList) {
+    public R<StudyLookResultVO> pictureSelectVoice(Integer week, Integer day, List<TStudyLook> lookList, Integer userid) {
         if (lookList.isEmpty()) {
             throw new GlobalException("当前学习周目题目数量不足!");
         }
@@ -238,26 +557,128 @@
         learnStudy.setIntegral(total);
         // 语音及图片
         List<List<TSubject>> subjectList = new ArrayList<>();
-        for (TStudyLook studyLook : lookList) {
-            List<String> sortList = Arrays.stream(studyLook.getSort().split(",")).collect(Collectors.toList());
-            List<String> subjectIds = Arrays.stream(studyLook.getSubject().split(",")).collect(Collectors.toList());
-            List<TSubject> list = new ArrayList<>();
-            // 图片及语音集合
-            for (int i = 0; i < subjectIds.size(); i++) {
-                TSubject data = subjectService.lambdaQuery().eq(TSubject::getId, subjectIds.get(i))
-                        .eq(TSubject::getDisabled, 0).one();
-                data.setSort(Integer.parseInt(sortList.get(i)));
-                list.add(data);
+
+        StudyLookResultVO studyListenResultVO = new StudyLookResultVO(learnStudy, subjectList);
+        List<TSubjectRecordDetail> subjectRecordDetails = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week).ne(BaseModel::getDisabled, 0).list();
+        List<TSubjectRecordDetail> listenList = subjectRecordDetails.stream().filter(e -> e.getType() == 1).collect(Collectors.toList());
+        int listenPass = (int) listenList.stream().filter(e -> e.getStatus() == 2).count();
+        int listenSize = listenList.size();
+        if (listenSize!=0){
+            // 先计算上一天的通关率 设置为两位小数
+            double listenRate = (double) listenPass /listenSize;
+            BigDecimal divide = new BigDecimal(listenPass).divide(new BigDecimal(listenSize), 2, RoundingMode.HALF_UP);
+            TStudyListen one = studyListenService.lambdaQuery().eq(TStudyListen::getWeek, week)
+                    .eq(TStudyListen::getDay, 1).last("limit 1").one();
+            if (one!=null){
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    return R.fail("听音选图未达到通关率"+one.getRate()+"%,"+"当前通关率:"+divide+"%");
+                }
             }
-            // 根据顺序排序
-            list.sort(Comparator.comparingInt(TSubject::getSort));
-            subjectList.add(list);
         }
-        return new StudyLookResultVO(learnStudy, subjectList);
+        List<TSubjectRecordDetail> lookList1 = subjectRecordDetails.stream().filter(e -> e.getType() == 2).collect(Collectors.toList());
+        int lookPass = (int) lookList1.stream().filter(e -> e.getStatus() == 2).count();
+        int lookSize = lookList1.size();
+        if (lookSize!=0){
+            // 计算当前通关率
+            double listenRate = (double) lookPass /lookSize;
+            TStudyLook one = studyLookService.lambdaQuery().eq(TStudyLook::getWeek, week)
+                    .eq(TStudyLook::getDay, 2).last("limit 1").one();
+            if (one!=null){
+                // 通关率未达标
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    // 清空答题记录
+                    subjectRecordDetailService.remove(new LambdaQueryWrapper<TSubjectRecordDetail>()
+                            .eq(TSubjectRecordDetail::getUserId, userid)
+                            .eq(TSubjectRecordDetail::getWeek, week)
+                            .eq(TSubjectRecordDetail::getDay,day)
+                            .eq(TSubjectRecordDetail::getType
+                                    ,2));
+                }
+            }
+        }
+        List<TSubjectRecordDetail> list = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week)
+                .eq(TSubjectRecordDetail::getDay, day)
+                .eq(TSubjectRecordDetail::getType, 2).list();
+        if (list.isEmpty()) {
+            List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
+            for (TStudyLook studyLook : lookList) {
+                List<String> sortList = Arrays.stream(studyLook.getSort().split(",")).collect(Collectors.toList());
+                List<String> subjectIds = Arrays.stream(studyLook.getSubject().split(",")).collect(Collectors.toList());
+                List<TSubject> subjects = new ArrayList<>();
+                // 图片及语音集合
+                for (int i = 0; i < subjectIds.size(); i++) {
+                    TSubject data = subjectService.lambdaQuery().eq(TSubject::getId, subjectIds.get(i))
+                            .eq(TSubject::getDisabled, 0).one();
+                    data.setSort(Integer.parseInt(sortList.get(i)));
+                    subjects.add(data);
+                }
+                // 根据顺序排序
+                subjects.sort(Comparator.comparingInt(TSubject::getSort));
+                subjectList.add(subjects);
+                TSubjectRecordDetail tSubjectRecordDetail = new TSubjectRecordDetail();
+                tSubjectRecordDetail.setUserId(userid);
+                tSubjectRecordDetail.setWeek(week);
+                tSubjectRecordDetail.setDay(day);
+                tSubjectRecordDetail.setType(2);
+                tSubjectRecordDetail.setStatus(1);
+                tSubjectRecordDetail.setObjectId(studyLook.getId());
+                tSubjectRecordDetails.add(tSubjectRecordDetail);
+            }
+
+            studyListenResultVO.setSubjectList(subjectList);
+            subjectRecordDetailService.saveBatch(tSubjectRecordDetails);
+            studyListenResultVO.setList(tSubjectRecordDetails);
+            studyListenResultVO.setAccuracy(new BigDecimal("0.00"));
+
+        } else {
+            List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
+            List<Integer> collect1 = lookList.stream().map(TStudyLook::getId).collect(Collectors.toList());
+            List<TSubjectRecordDetail> collect3 = list.stream().filter(e -> !collect1.contains(e.getObjectId())).collect(Collectors.toList());
+            subjectRecordDetailService.removeBatchByIds(collect3);
+            for (TStudyLook studyLook : lookList) {
+                List<String> sortList = Arrays.stream(studyLook.getSort().split(",")).collect(Collectors.toList());
+                List<String> subjectIds = Arrays.stream(studyLook.getSubject().split(",")).collect(Collectors.toList());
+                List<TSubject> subjects = new ArrayList<>();
+                // 图片及语音集合
+                for (int i = 0; i < subjectIds.size(); i++) {
+                    TSubject data = subjectService.lambdaQuery().eq(TSubject::getId, subjectIds.get(i))
+                            .eq(TSubject::getDisabled, 0).one();
+                    data.setSort(Integer.parseInt(sortList.get(i)));
+                    subjects.add(data);
+                }
+                // 根据顺序排序
+                subjects.sort(Comparator.comparingInt(TSubject::getSort));
+                subjectList.add(subjects);
+                List<TSubjectRecordDetail> tSubjectRecordDetail1 = list.stream().filter(e -> e.getObjectId().equals(studyLook.getId())).collect(Collectors.toList());
+                if (tSubjectRecordDetail1.isEmpty()){
+                    TSubjectRecordDetail tSubjectRecordDetail = new TSubjectRecordDetail();
+                    tSubjectRecordDetail.setUserId(userid);
+                    tSubjectRecordDetail.setWeek(week);
+                    tSubjectRecordDetail.setDay(day);
+                    tSubjectRecordDetail.setType(3);
+                    tSubjectRecordDetail.setStatus(1);
+                    tSubjectRecordDetail.setObjectId(studyLook.getId());
+                    tSubjectRecordDetails.add(tSubjectRecordDetail);
+                    subjectRecordDetailService.save(tSubjectRecordDetail);
+                }else{
+                    tSubjectRecordDetails.addAll(tSubjectRecordDetail1);
+                }
+
+
+            }
+
+            studyListenResultVO.setAccuracy(new BigDecimal(tSubjectRecordDetails.stream().filter(tSubjectRecordDetail -> tSubjectRecordDetail.getStatus().equals(2)).count())
+                    .divide(new BigDecimal(tSubjectRecordDetails.size()), 2, RoundingMode.HALF_UP));
+            studyListenResultVO.setList(tSubjectRecordDetails);
+            studyListenResultVO.setSubjectList(subjectList);
+        }
+        return R.ok(studyListenResultVO);
     }
 
     @Override
-    public StudyInductionResultVO induceExclude(Integer week, Integer day, List<TStudyInduction> inductionList) {
+    public R<StudyInductionResultVO> induceExclude(Integer week, Integer day, List<TStudyInduction> inductionList, Integer userid) {
         if (inductionList.isEmpty()) {
             throw new GlobalException("当前学习周目题目数量不足!");
         }
@@ -275,45 +696,166 @@
         learnStudy.setIntegral(total);
         // 语音及图片
         List<List<TSubject>> subjectList = new ArrayList<>();
-        for (TStudyInduction data : inductionList) {
-            List<String> subjectIds = Arrays.stream(data.getSubject().split(",")).collect(Collectors.toList());
-            List<TSubject> subjectLists = new ArrayList<>();
-            // 第一组题 固定下标为0,1,2的题
-            for (int i = 0; i < Constants.THREE; i++) {
-                String id = subjectIds.get(i);
-                if (!id.startsWith("-")) {
-                    subjectLists.add(subjectService.getById(id));
+
+        StudyInductionResultVO studyListenResultVO = new StudyInductionResultVO(learnStudy, subjectList);
+
+        List<TSubjectRecordDetail> list = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week)
+                .eq(TSubjectRecordDetail::getDay, day)
+                .eq(TSubjectRecordDetail::getType, 3).list();
+        List<TSubjectRecordDetail> subjectRecordDetails = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week).ne(BaseModel::getDisabled, 0).list();
+        List<TSubjectRecordDetail> listenList = subjectRecordDetails.stream().filter(e -> e.getType() == 2).collect(Collectors.toList());
+        int listenPass = (int) listenList.stream().filter(e -> e.getStatus() == 2).count();
+        int listenSize = listenList.size();
+        if (listenSize!=0){
+            // 先计算上一天的通关率 设置为两位小数
+            double listenRate = (double) listenPass /listenSize;
+            BigDecimal divide = new BigDecimal(listenPass).divide(new BigDecimal(listenSize), 2, RoundingMode.HALF_UP);
+            TStudyLook one = studyLookService.lambdaQuery().eq(TStudyLook::getWeek, week)
+                    .eq(TStudyLook::getDay, 2).last("limit 1").one();
+            if (one!=null){
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    return R.fail("看图选音未达到通关率"+one.getRate()+"%,"+"当前通关率:"+divide+"%");
                 }
             }
-            for (int i = 0; i < Constants.THREE; i++) {
-                String id = subjectIds.get(i);
-                if (id.startsWith("-")) {
-                    id = id.replace("-", "");
-                    subjectLists.add(subjectService.getById(id));
-                }
-            }
-            // 第二组题,固定下标为3,4的题
-            for (int i = Constants.THREE; i < Constants.FIVE; i++) {
-                String id = subjectIds.get(i);
-                if (!id.startsWith("-")) {
-                    subjectLists.add(subjectService.getById(id));
-                }
-            }
-            for (int i = Constants.THREE; i < Constants.FIVE; i++) {
-                String id = subjectIds.get(i);
-                if (id.startsWith("-")) {
-                    id = id.replace("-", "");
-                    subjectLists.add(subjectService.getById(id));
-                }
-            }
-            subjectLists.add(subjectService.getById(subjectIds.get(subjectIds.size() - 1).replace("-", "")));
-            subjectList.add(subjectLists);
         }
-        return new StudyInductionResultVO(learnStudy, subjectList);
+        List<TSubjectRecordDetail> lookList1 = subjectRecordDetails.stream().filter(e -> e.getType() == 3).collect(Collectors.toList());
+        int lookPass = (int) lookList1.stream().filter(e -> e.getStatus() == 2).count();
+        int lookSize = lookList1.size();
+        if (lookSize!=0){
+            // 计算当前通关率
+            double listenRate = (double) lookPass /lookSize;
+            TStudyInduction one = studyInductionService.lambdaQuery().eq(TStudyInduction::getWeek, week)
+                    .eq(TStudyInduction::getDay, 3).last("limit 1").one();
+            if (one!=null){
+                // 通关率未达标
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    // 清空答题记录
+                    subjectRecordDetailService.remove(new LambdaQueryWrapper<TSubjectRecordDetail>()
+                            .eq(TSubjectRecordDetail::getUserId, userid)
+                            .eq(TSubjectRecordDetail::getWeek, week)
+                            .eq(TSubjectRecordDetail::getDay,day)
+                            .eq(TSubjectRecordDetail::getType
+                                    ,3));
+                }
+            }
+        }
+        if (list.isEmpty()) {
+            List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
+            for (TStudyInduction data : inductionList) {
+                List<String> subjectIds = Arrays.stream(data.getSubject().split(",")).collect(Collectors.toList());
+                List<TSubject> subjectLists = new ArrayList<>();
+                // 第一组题 固定下标为0,1,2的题
+                for (int i = 0; i < Constants.THREE; i++) {
+                    String id = subjectIds.get(i);
+                    if (!id.startsWith("-")) {
+                        subjectLists.add(subjectService.getById(id));
+                    }
+                }
+                for (int i = 0; i < Constants.THREE; i++) {
+                    String id = subjectIds.get(i);
+                    if (id.startsWith("-")) {
+                        id = id.replace("-", "");
+                        subjectLists.add(subjectService.getById(id));
+                    }
+                }
+                // 第二组题,固定下标为3,4的题
+                for (int i = Constants.THREE; i < Constants.FIVE; i++) {
+                    String id = subjectIds.get(i);
+                    if (!id.startsWith("-")) {
+                        subjectLists.add(subjectService.getById(id));
+                    }
+                }
+                for (int i = Constants.THREE; i < Constants.FIVE; i++) {
+                    String id = subjectIds.get(i);
+                    if (id.startsWith("-")) {
+                        id = id.replace("-", "");
+                        subjectLists.add(subjectService.getById(id));
+                    }
+                }
+                subjectLists.add(subjectService.getById(subjectIds.get(subjectIds.size() - 1).replace("-", "")));
+                subjectList.add(subjectLists);
+                TSubjectRecordDetail tSubjectRecordDetail = new TSubjectRecordDetail();
+                tSubjectRecordDetail.setUserId(userid);
+                tSubjectRecordDetail.setWeek(week);
+                tSubjectRecordDetail.setObjectId(data.getId());
+                tSubjectRecordDetail.setDay(day);
+                tSubjectRecordDetail.setType(3);
+                tSubjectRecordDetail.setStatus(1);
+                tSubjectRecordDetails.add(tSubjectRecordDetail);
+            }
+            studyListenResultVO.setSubjectList(subjectList);
+
+            subjectRecordDetailService.saveBatch(tSubjectRecordDetails);
+            studyListenResultVO.setList(tSubjectRecordDetails);
+            studyListenResultVO.setAccuracy(new BigDecimal("0.00"));
+
+        } else {
+            List<Integer> collect1 = inductionList.stream().map(TStudyInduction::getId).collect(Collectors.toList());
+            List<TSubjectRecordDetail> collect3 = list.stream().filter(e -> !collect1.contains(e.getObjectId())).collect(Collectors.toList());
+            subjectRecordDetailService.removeBatchByIds(collect3);
+            List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
+            for (TStudyInduction data : inductionList) {
+                List<String> subjectIds = Arrays.stream(data.getSubject().split(",")).collect(Collectors.toList());
+                List<TSubject> subjectLists = new ArrayList<>();
+                // 第一组题 固定下标为0,1,2的题
+                for (int i = 0; i < Constants.THREE; i++) {
+                    String id = subjectIds.get(i);
+                    if (!id.startsWith("-")) {
+                        subjectLists.add(subjectService.getById(id));
+                    }
+                }
+                for (int i = 0; i < Constants.THREE; i++) {
+                    String id = subjectIds.get(i);
+                    if (id.startsWith("-")) {
+                        id = id.replace("-", "");
+                        subjectLists.add(subjectService.getById(id));
+                    }
+                }
+                // 第二组题,固定下标为3,4的题
+                for (int i = Constants.THREE; i < Constants.FIVE; i++) {
+                    String id = subjectIds.get(i);
+                    if (!id.startsWith("-")) {
+                        subjectLists.add(subjectService.getById(id));
+                    }
+                }
+                for (int i = Constants.THREE; i < Constants.FIVE; i++) {
+                    String id = subjectIds.get(i);
+                    if (id.startsWith("-")) {
+                        id = id.replace("-", "");
+                        subjectLists.add(subjectService.getById(id));
+                    }
+                }
+                subjectLists.add(subjectService.getById(subjectIds.get(subjectIds.size() - 1).replace("-", "")));
+                subjectList.add(subjectLists);
+
+                TSubjectRecordDetail tSubjectRecordDetail1 = list.stream().filter(e -> e.getObjectId().equals(data.getId())).findFirst().orElse(null);
+                if (tSubjectRecordDetail1==null){
+                    TSubjectRecordDetail tSubjectRecordDetail = new TSubjectRecordDetail();
+                    tSubjectRecordDetail.setUserId(userid);
+                    tSubjectRecordDetail.setWeek(week);
+                    tSubjectRecordDetail.setDay(day);
+                    tSubjectRecordDetail.setType(3);
+                    tSubjectRecordDetail.setStatus(1);
+                    tSubjectRecordDetail.setObjectId(data.getId());
+                    subjectRecordDetailService.save(tSubjectRecordDetail);
+
+                    tSubjectRecordDetails.add(tSubjectRecordDetail);
+                }else{
+                    tSubjectRecordDetails.add(tSubjectRecordDetail1);
+                }
+            }
+            studyListenResultVO.setList(tSubjectRecordDetails);
+            studyListenResultVO.setAccuracy(new BigDecimal(tSubjectRecordDetails.stream().filter(tSubjectRecordDetail -> tSubjectRecordDetail.getStatus().equals(2)).count())
+                    .divide(new BigDecimal(tSubjectRecordDetails.size()), 2, RoundingMode.HALF_UP));
+        }
+        studyListenResultVO.setSubjectList(subjectList);
+        return R.ok(studyListenResultVO);
     }
 
     @Override
-    public StudyAnswerResultVO questionsAndAnswers(Integer week, Integer day, List<TStudyAnswer> answerList) {
+    public R<StudyAnswerResultVO> questionsAndAnswers(Integer week, Integer day, List<TStudyAnswer> answerList, Integer userid) {
         if (answerList.isEmpty()) {
             throw new GlobalException("当前学习周目题目数量不足!");
         }
@@ -331,16 +873,132 @@
         learnStudy.setIntegral(total);
         // 题目语音及图片信息
         List<List<QuestionsAnswersSubjectVO>> subjectList = new ArrayList<>();
-        for (int i = 0; i < answerList.size(); i += Constants.TWO) {
-            List<QuestionsAnswersSubjectVO> voList = new ArrayList<>();
-            // 一组题目为四道题,
-            TStudyAnswer one = answerList.get(i);
-            TStudyAnswer two = answerList.get(i + 1);
-            voAdd(voList, one);
-            voAdd(voList, two);
-            subjectList.add(voList);
+
+        StudyAnswerResultVO studyListenResultVO = new StudyAnswerResultVO(learnStudy, subjectList);
+
+        List<TSubjectRecordDetail> list = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week)
+                .eq(TSubjectRecordDetail::getDay, day)
+                .eq(TSubjectRecordDetail::getType, 4).list();
+        List<TSubjectRecordDetail> subjectRecordDetails = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week).ne(BaseModel::getDisabled, 0).list();
+        List<TSubjectRecordDetail> listenList = subjectRecordDetails.stream().filter(e -> e.getType() == 3).collect(Collectors.toList());
+        int listenPass = (int) listenList.stream().filter(e -> e.getStatus() == 2).count();
+        int listenSize = listenList.size();
+        if (listenSize!=0){
+            // 先计算上一天的通关率 设置为两位小数
+            double listenRate = (double) listenPass /listenSize;
+            BigDecimal divide = new BigDecimal(listenPass).divide(new BigDecimal(listenSize), 2, RoundingMode.HALF_UP);
+            TStudyInduction one = studyInductionService.lambdaQuery().eq(TStudyInduction::getWeek, week)
+                    .eq(TStudyInduction::getDay, 3).last("limit 1").one();
+            if (one!=null){
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    return R.fail("归纳排除未达到通关率"+one.getRate()+"%,"+"当前通关率:"+divide+"%");
+                }
+            }
         }
-        return new StudyAnswerResultVO(learnStudy, subjectList);
+        List<TSubjectRecordDetail> lookList1 = subjectRecordDetails.stream().filter(e -> e.getType() == 4).collect(Collectors.toList());
+        int lookPass = (int) lookList1.stream().filter(e -> e.getStatus() == 2).count();
+        int lookSize = lookList1.size();
+        if (lookSize!=0){
+            // 计算当前通关率
+            double listenRate = (double) lookPass /lookSize;
+            TStudyAnswer one = studyAnswerService.lambdaQuery().eq(TStudyAnswer::getWeek, week)
+                    .eq(TStudyAnswer::getDay, 4).last("limit 1").one();
+            if (one!=null){
+                // 通关率未达标
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    // 清空答题记录
+                    subjectRecordDetailService.remove(new LambdaQueryWrapper<TSubjectRecordDetail>()
+                            .eq(TSubjectRecordDetail::getUserId, userid)
+                            .eq(TSubjectRecordDetail::getWeek, week)
+                            .eq(TSubjectRecordDetail::getDay,day)
+                            .eq(TSubjectRecordDetail::getType
+                                    ,4));
+                }
+            }
+        }
+        if (list.isEmpty()) {
+            List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
+            for (int i = 0; i < answerList.size(); i += Constants.TWO) {
+                List<QuestionsAnswersSubjectVO> voList = new ArrayList<>();
+                // 一组题目为四道题,
+                TStudyAnswer one = answerList.get(i);
+                TStudyAnswer two = answerList.get(i + 1);
+                voAdd(voList, one);
+                voAdd(voList, two);
+                subjectList.add(voList);
+            }
+            for (int i = 0; i < answerList.size(); i += 4) {
+                // 一组题目为四道题,
+                TStudyAnswer one = answerList.get(i);
+                TStudyAnswer two = answerList.get(i + 1);
+                TStudyAnswer three = answerList.get(i + 2);
+                TStudyAnswer four = answerList.get(i + 3);
+                TSubjectRecordDetail tSubjectRecordDetail = new TSubjectRecordDetail();
+                tSubjectRecordDetail.setUserId(userid);
+                tSubjectRecordDetail.setWeek(week);
+                tSubjectRecordDetail.setDay(day);
+                tSubjectRecordDetail.setType(4);
+                tSubjectRecordDetail.setStatus(1);
+                tSubjectRecordDetail.setOne(one.getId());
+                tSubjectRecordDetail.setTwo(two.getId());
+                tSubjectRecordDetail.setThree(three.getId());
+                tSubjectRecordDetail.setFour(four.getId());
+                tSubjectRecordDetails.add(tSubjectRecordDetail);
+            }
+            subjectRecordDetailService.saveBatch(tSubjectRecordDetails);
+            studyListenResultVO.setList(tSubjectRecordDetails);
+            studyListenResultVO.setAccuracy(new BigDecimal("0.00"));
+
+        } else {
+            List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
+            for (int i = 0; i < answerList.size(); i += Constants.TWO) {
+                List<QuestionsAnswersSubjectVO> voList = new ArrayList<>();
+                // 一组题目为四道题,
+                TStudyAnswer one = answerList.get(i);
+                TStudyAnswer two = answerList.get(i + 1);
+                voAdd(voList, one);
+                voAdd(voList, two);
+                subjectList.add(voList);
+            }
+
+
+            List<TSubjectRecordDetail> tSubjectRecordDetails1 = new ArrayList<TSubjectRecordDetail>();
+
+            for (int i = 0; i < answerList.size(); i += 4) {
+                TStudyAnswer one = answerList.get(i);
+                TStudyAnswer two = answerList.get(i + 1);
+                TStudyAnswer three = answerList.get(i + 2);
+                TStudyAnswer four = answerList.get(i + 3);
+                TSubjectRecordDetail tSubjectRecordDetail = new TSubjectRecordDetail();
+                tSubjectRecordDetail.setUserId(userid);
+                tSubjectRecordDetail.setWeek(week);
+                tSubjectRecordDetail.setDay(day);
+                tSubjectRecordDetail.setType(4);
+                int size = list.size();
+                if (size-1>=i/4){
+                    tSubjectRecordDetail.setStatus(list.get(i/4).getStatus());
+                }else{
+                    tSubjectRecordDetail.setStatus(1);
+                }
+                tSubjectRecordDetail.setOne(one.getId());
+                tSubjectRecordDetail.setTwo(two.getId());
+                tSubjectRecordDetail.setThree(three.getId());
+                tSubjectRecordDetail.setFour(four.getId());
+                tSubjectRecordDetails.add(tSubjectRecordDetail);
+                tSubjectRecordDetails1.add(tSubjectRecordDetail);
+            }
+            List<Long> collect = list.stream().map(TSubjectRecordDetail::getId).collect(Collectors.toList());
+            subjectRecordDetailService.removeBatchByIds(collect);
+            subjectRecordDetailService.saveBatch(tSubjectRecordDetails1);
+
+            studyListenResultVO.setList(tSubjectRecordDetails);
+            studyListenResultVO.setAccuracy(new BigDecimal(tSubjectRecordDetails.stream().filter(tSubjectRecordDetail -> tSubjectRecordDetail.getStatus().equals(2)).count())
+                    .divide(new BigDecimal(tSubjectRecordDetails.size()), 2, RoundingMode.HALF_UP));
+        }
+        studyListenResultVO.setSubjectList(subjectList);
+        return R.ok(studyListenResultVO);
     }
 
     private void voAdd(List<QuestionsAnswersSubjectVO> voList, TStudyAnswer one) {
@@ -382,7 +1040,7 @@
     }
 
     @Override
-    public StudyPairResultVO pictureMateVoice(Integer week, Integer day, List<TStudyPair> pair) {
+    public R<StudyPairResultVO> pictureMateVoice(Integer week, Integer day, List<TStudyPair> pair, Integer userid) {
         if (pair.isEmpty()) {
             throw new GlobalException("当前学习周目题目数量不足!");
         }
@@ -400,18 +1058,115 @@
         learnStudy.setIntegral(total);
         // 语音及图片
         List<List<TSubject>> subjectList = new ArrayList<>();
-        for (TStudyPair data : pair) {
-            List<String> subjectIds = Arrays.stream(data.getSubject().split(",")).collect(Collectors.toList());
-            List<TSubject> subjectLists = new ArrayList<>();
-            for (String id : subjectIds) {
-                if (id.startsWith("-")) {
-                    id = id.replace("-", "");
+
+        StudyPairResultVO studyListenResultVO = new StudyPairResultVO(learnStudy, subjectList);
+
+        List<TSubjectRecordDetail> list = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week)
+                .eq(TSubjectRecordDetail::getDay, day)
+                .eq(TSubjectRecordDetail::getType, 5).list();
+        List<TSubjectRecordDetail> subjectRecordDetails = subjectRecordDetailService.lambdaQuery().eq(TSubjectRecordDetail::getUserId, userid)
+                .eq(TSubjectRecordDetail::getWeek, week).ne(BaseModel::getDisabled, 0).list();
+        List<TSubjectRecordDetail> listenList = subjectRecordDetails.stream().filter(e -> e.getType() == 4).collect(Collectors.toList());
+        int listenPass = (int) listenList.stream().filter(e -> e.getStatus() == 2).count();
+        int listenSize = listenList.size();
+        if (listenSize!=0){
+            // 先计算上一天的通关率 设置为两位小数
+            double listenRate = (double) listenPass /listenSize;
+            BigDecimal divide = new BigDecimal(listenPass).divide(new BigDecimal(listenSize), 2, RoundingMode.HALF_UP);
+            TStudyAnswer one = studyAnswerService.lambdaQuery().eq(TStudyAnswer::getWeek, week)
+                    .eq(TStudyAnswer::getDay, 4).last("limit 1").one();
+            if (one!=null){
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    return R.fail("归纳排除未达到通关率"+one.getRate()+"%,"+"当前通关率:"+divide+"%");
                 }
-                subjectLists.add(subjectService.getById(id));
             }
-            subjectList.add(subjectLists);
         }
-        return new StudyPairResultVO(learnStudy, subjectList);
+        List<TSubjectRecordDetail> lookList1 = subjectRecordDetails.stream().filter(e -> e.getType() == 5).collect(Collectors.toList());
+        int lookPass = (int) lookList1.stream().filter(e -> e.getStatus() == 2).count();
+        int lookSize = lookList1.size();
+        if (lookSize!=0){
+            // 计算当前通关率
+            double listenRate = (double) lookPass /lookSize;
+            TStudyPair one = studyPairService.lambdaQuery().eq(TStudyPair::getWeek, week)
+                    .eq(TStudyPair::getDay, 5).last("limit 1").one();
+            if (one!=null){
+                // 通关率未达标
+                if (listenRate<(Double.parseDouble(one.getRate())/100)){
+                    // 清空答题记录
+                    subjectRecordDetailService.remove(new LambdaQueryWrapper<TSubjectRecordDetail>()
+                            .eq(TSubjectRecordDetail::getUserId, userid)
+                            .eq(TSubjectRecordDetail::getWeek, week)
+                            .eq(TSubjectRecordDetail::getDay,day)
+                            .eq(TSubjectRecordDetail::getType
+                                    ,5));
+                }
+            }
+        }
+        if (list.isEmpty()) {
+            List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
+            for (TStudyPair data : pair) {
+                TSubjectRecordDetail tSubjectRecordDetail = new TSubjectRecordDetail();
+                tSubjectRecordDetail.setUserId(userid);
+                tSubjectRecordDetail.setWeek(week);
+                tSubjectRecordDetail.setDay(day);
+                tSubjectRecordDetail.setType(5);
+                tSubjectRecordDetail.setStatus(1);
+                tSubjectRecordDetail.setObjectId(data.getId());
+                tSubjectRecordDetails.add(tSubjectRecordDetail);
+
+                List<String> subjectIds = Arrays.stream(data.getSubject().split(",")).collect(Collectors.toList());
+                List<TSubject> subjectLists = new ArrayList<>();
+                for (String id : subjectIds) {
+                    if (id.startsWith("-")) {
+                        id = id.replace("-", "");
+                    }
+                    subjectLists.add(subjectService.getById(id));
+                }
+                subjectList.add(subjectLists);
+            }
+            studyListenResultVO.setSubjectList(subjectList);
+            subjectRecordDetailService.saveBatch(tSubjectRecordDetails);
+            studyListenResultVO.setList(tSubjectRecordDetails);
+            studyListenResultVO.setAccuracy(new BigDecimal("0.00"));
+
+        } else {
+            List<Integer> collect1 = pair.stream().map(TStudyPair::getId).collect(Collectors.toList());
+            List<TSubjectRecordDetail> collect3 = list.stream().filter(e -> !collect1.contains(e.getObjectId())).collect(Collectors.toList());
+            subjectRecordDetailService.removeBatchByIds(collect3);
+            List<TSubjectRecordDetail> tSubjectRecordDetails = new ArrayList<>();
+            for (TStudyPair data : pair) {
+                List<String> subjectIds = Arrays.stream(data.getSubject().split(",")).collect(Collectors.toList());
+                List<TSubject> subjectLists = new ArrayList<>();
+                for (String id : subjectIds) {
+                    if (id.startsWith("-")) {
+                        id = id.replace("-", "");
+                    }
+                    subjectLists.add(subjectService.getById(id));
+                }
+                subjectList.add(subjectLists);
+                List<TSubjectRecordDetail> tSubjectRecordDetail1 = list.stream().filter(e -> e.getObjectId().equals(data.getId())).collect(Collectors.toList());
+
+                if (tSubjectRecordDetail1.isEmpty()){
+                    TSubjectRecordDetail tSubjectRecordDetail = new TSubjectRecordDetail();
+                    tSubjectRecordDetail.setUserId(userid);
+                    tSubjectRecordDetail.setWeek(week);
+                    tSubjectRecordDetail.setDay(day);
+                    tSubjectRecordDetail.setType(5);
+                    tSubjectRecordDetail.setStatus(1);
+                    tSubjectRecordDetail.setObjectId(data.getId());
+                    tSubjectRecordDetails.add(tSubjectRecordDetail);
+                    subjectRecordDetailService.save(tSubjectRecordDetail);
+                }else{
+                    tSubjectRecordDetails.addAll(tSubjectRecordDetail1);
+                }
+            }
+            studyListenResultVO.setList(tSubjectRecordDetails);
+            studyListenResultVO.setSubjectList(subjectList);
+            studyListenResultVO.setAccuracy(new BigDecimal(tSubjectRecordDetails.stream().filter(tSubjectRecordDetail -> tSubjectRecordDetail.getStatus().equals(2)).count())
+                    .divide(new BigDecimal(tSubjectRecordDetails.size()), 2, RoundingMode.HALF_UP));
+        }
+        return R.ok(studyListenResultVO);
     }
 
     @Override
@@ -432,8 +1187,6 @@
             itemList.add(study);
             studyMap.put(quarter, itemList);
         }
-        // 临时判断参数
-        boolean itemBool = false;
         // 学习进度所属季度
         int studyQuarter = 1;
         // 当前进入周目所属季度
@@ -465,7 +1218,7 @@
                 defaultSchedule = 100;
             } else if (studyIndex < weekIndex) {
                 defaultSchedule = 0;
-            }else {
+            } else {
                 // 根据day初始化学习进度
                 if (Constants.ONE.equals(day)) {
                     defaultSchedule = 0;
@@ -587,7 +1340,11 @@
         } else {
             throw new GlobalException("题目信息异常!");
         }
-        return (int) (sum * ((double) accuracy / 100));
+        if (accuracy >= 100) {
+            return sum;
+        } else {
+            return (int) (sum * ((double) accuracy / 100));
+        }
     }
 
     @Override
@@ -597,6 +1354,71 @@
         // 已学习到的周目
         Integer studyWeek = studyRecord.getWeek();
         // 根据季度分组封装
+        Map<Integer, List<TStudy>> itemMap = getIntegerListMap(studyList);
+        // 计算已学习周目
+        boolean v = false;
+        for (Map.Entry<Integer, List<TStudy>> map : itemMap.entrySet()) {
+            List<TStudy> list = map.getValue();
+            for (int i = 0; i < list.size(); i++) {
+                TStudy item = list.get(i);
+                if (item.getWeek().equals(studyWeek)) {
+                    Integer listen = studyRecord.getListen();
+                    Integer answer = studyRecord.getAnswer();
+                    Integer look = studyRecord.getLook();
+                    Integer induction = studyRecord.getInduction();
+                    Integer pair = studyRecord.getPair();
+                    Integer gameDifficulty = studyRecord.getGameDifficulty();
+                    // 听音选图、看图选音、音图相配、有问有答、归纳排除的进度是否 100%,并且超级听力的游戏难度是否为2
+                    boolean isStudy = Constants.ONE_HUNDRED.equals(listen) && Constants.ONE_HUNDRED.equals(look) &&
+                            Constants.ONE_HUNDRED.equals(induction) && Constants.ONE_HUNDRED.equals(pair) &&
+                            Constants.ONE_HUNDRED.equals(answer) && Constants.TWO.equals(gameDifficulty);
+                    // 并且超级听力难度2已通过
+                    TStudy study = this.lambdaQuery().eq(TStudy::getWeek, studyRecord.getWeek())
+                            .eq(TStudy::getDisabled, 0)
+                            .one();
+                    TGame game = gameService.lambdaQuery()
+                            .eq(TGame::getStudyId, study.getId())
+                            .eq(TGame::getDisabled, 0)
+                            .eq(TGame::getWeek, study.getWeek())
+                            .one();
+                    if (null != game) {
+                        String rate = game.getRate().split(",")[2];
+                        List<TGameRecord> gameRecordList = gameRecordService.lambdaQuery()
+                                .eq(TGameRecord::getGameDifficulty, Constants.TWO)
+                                .ge(TGameRecord::getAccuracy, rate)
+                                .eq(TGameRecord::getUserId, studyRecord.getUserId())
+                                .eq(TGameRecord::getGameId, game.getId())
+                                .list();
+                        if (gameRecordList.isEmpty()) {
+                            isStudy = false;
+                        }
+                        List<TGameRecord> recordList = gameRecordService.lambdaQuery()
+                                .ge(TGameRecord::getAccuracy, game.getAnswerRate())
+                                .eq(TGameRecord::getUserId, studyRecord.getUserId())
+                                .eq(TGameRecord::getGameId, game.getId())
+                                .last("and gameDifficulty is null")
+                                .list();
+                        if (recordList.isEmpty()) {
+                            isStudy = false;
+                        }
+                    }
+                    if (isStudy) {
+                        residueWeek++;
+                    }
+                    v = true;
+                    break;
+                } else {
+                    residueWeek++;
+                }
+            }
+            if (v) {
+                break;
+            }
+        }
+        return studyList.size() - residueWeek;
+    }
+
+    private Map<Integer, List<TStudy>> getIntegerListMap(List<TStudy> studyList) {
         Map<Integer, List<TStudy>> studyMap = new HashMap<>(8);
         for (TStudy study : studyList) {
             Integer quarter = study.getQuarter();
@@ -619,37 +1441,7 @@
             List<TStudy> itemList = studyMap.get(key);
             itemMap.put(key, itemList);
         }
-        // 计算已学习周目
-        boolean v = false;
-        for (Map.Entry<Integer, List<TStudy>> map : itemMap.entrySet()) {
-            List<TStudy> list = map.getValue();
-            for (int i = 0; i < list.size(); i++) {
-                TStudy item = list.get(i);
-                if (item.getWeek().equals(studyWeek)) {
-                    Integer listen = studyRecord.getListen();
-                    Integer answer = studyRecord.getAnswer();
-                    Integer look = studyRecord.getLook();
-                    Integer induction = studyRecord.getInduction();
-                    Integer pair = studyRecord.getPair();
-                    Integer gameDifficulty = studyRecord.getGameDifficulty();
-                    // 听音选图、看图选音、音图相配、有问有答、归纳排除的进度是否 100%,并且超级听力的游戏难度是否为2
-                    boolean isStudy = Constants.ONE_HUNDRED.equals(listen) && Constants.ONE_HUNDRED.equals(look) &&
-                            Constants.ONE_HUNDRED.equals(induction) && Constants.ONE_HUNDRED.equals(pair) &&
-                            Constants.ONE_HUNDRED.equals(answer) && Constants.TWO.equals(gameDifficulty);
-                    if (isStudy) {
-                        residueWeek++;
-                    }
-                    v = true;
-                    break;
-                } else {
-                    residueWeek++;
-                }
-            }
-            if (v) {
-                break;
-            }
-        }
-        return studyList.size() - residueWeek;
+        return itemMap;
     }
 
     @Override
@@ -665,4 +1457,60 @@
         }
     }
 
+    @Override
+    public Integer userGameDifficulty(TUserStudy studyRecord, Integer week) {
+        List<TStudy> studyList = this.lambdaQuery().eq(TStudy::getDisabled, 0)
+                .eq(TStudy::getType, 1)
+                .orderByAsc(TStudy::getWeek).list();
+        // 基础学习进度
+        Integer day = studyRecord.getDay();
+        Integer studyWeek = studyRecord.getWeek();
+        Map<Integer, List<TStudy>> studyMap = new HashMap<>(8);
+        for (TStudy study : studyList) {
+            Integer quarter = study.getQuarter();
+            List<TStudy> itemList = studyMap.get(quarter);
+            if (null == itemList) {
+                itemList = new ArrayList<>();
+            }
+            itemList.add(study);
+            studyMap.put(quarter, itemList);
+        }
+        // 学习进度所属季度
+        int studyQuarter = 1;
+        // 当前进入周目所属季度
+        int thisQuarter = 1;
+        for (Map.Entry<Integer, List<TStudy>> map : studyMap.entrySet()) {
+            Integer key = map.getKey();
+            List<TStudy> list = map.getValue();
+            List<Integer> collect = list.stream().map(TStudy::getWeek).collect(Collectors.toList());
+            if (collect.contains(studyWeek)) {
+                studyQuarter = key;
+            }
+            if (collect.contains(week)) {
+                thisQuarter = key;
+            }
+        }
+        // 默认进度为 0
+        int defaultSchedule;
+        // 季度判断
+        if (studyQuarter > thisQuarter) {
+            defaultSchedule = 2;
+        } else if (studyQuarter < thisQuarter) {
+            defaultSchedule = 0;
+        } else {
+            List<TStudy> tStudies = studyMap.get(studyQuarter);
+            List<Integer> weekList = tStudies.stream().map(TStudy::getWeek).collect(Collectors.toList());
+            int studyIndex = weekList.indexOf(studyWeek);
+            int weekIndex = weekList.indexOf(week);
+            if (studyIndex > weekIndex) {
+                defaultSchedule = 2;
+            } else if (studyIndex < weekIndex) {
+                defaultSchedule = 0;
+            } else {
+                defaultSchedule = studyRecord.getGameDifficulty();
+            }
+        }
+        return defaultSchedule;
+    }
+
 }

--
Gitblit v1.7.1