LISHUZUOXUN_yangjiang/PureBackend/pull_up_backend.py

59 lines
2.4 KiB
Python
Raw Normal View History

2024-09-23 14:54:15 +08:00
# coding: gb2312
import traceback
from LogRecord.log_recorder import GLOBAL_LOG
from PureBackend.base_driver import MODEL_MEDIAPIPE
from PureBackend.exam_driver import ExamDriver
from PureBackend.general import *
class PullupBackend(ExamDriver):
def __init__(self, master_mode=True, positioning=True, camera=True, model=MODEL_MEDIAPIPE, speaker=True,
multi_positioning_mode=True, device_type=UNKNOWN, pure_mode=False):
super().__init__(master_mode, positioning, camera, model, speaker, multi_positioning_mode, device_type,
pure_mode)
if model == MODEL_MEDIAPIPE:
from Exercise3.pull_up_1 import PullUp_1
from Exercise3.pull_up_2 import PullUp_2
from Exercise3.pull_up_3 import PullUp_3
else:
from Exercise_mn.pull_up_1 import PullUp_1
from Exercise_mn.pull_up_2 import PullUp_2
from Exercise_mn.pull_up_3 import PullUp_3
self.pull_up_1 = PullUp_1
self.pull_up_2 = PullUp_2
self.pull_up_3 = PullUp_3
# ׼<><D7BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
def active_pull_up(self, person_id, band_id):
if self.project:
self.project.kill()
if person_id:
info = self.manager.select_a_person(person_id)[0]
else:
if band_id:
raw_info = self.manager.select_a_person_from_band(band_id)
if not raw_info:
GLOBAL_LOG.write(f"׼<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϸ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: <20><><EFBFBD>ֻ<EFBFBD>û<EFBFBD><C3BB>ƥ<EFBFBD><C6A5><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ա", need_print=True)
return False
info = raw_info[0]
else:
GLOBAL_LOG.write(f"׼<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϸ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: <20><><EFBFBD><EFBFBD>ȱʧ", need_print=True)
return False
try:
train_info = self.get_train_info()
difficulty = train_info[DIFFICULTY]
standards = train_info[STANDARDS]
if difficulty == DIFFICULT_HARD:
self.project = self.pull_up_1(info, camera=self.camera)
elif difficulty == DIFFICULT_EASY:
self.project = self.pull_up_2(info, camera=self.camera)
elif difficulty == COMMON_EASY:
self.project = self.pull_up_3(info, camera=self.camera)
self.exercise_tag = PULLUP
return True
except Exception as e:
GLOBAL_LOG.write(f"׼<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϸ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>{str(e)}<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Դ<EFBFBD><EFBFBD>{traceback.format_exc()}")
return False