mirror of
https://github.com/LmeSzinc/StarRailCopilot.git
synced 2024-11-25 10:01:10 +00:00
107 lines
3.6 KiB
Python
107 lines
3.6 KiB
Python
from datetime import timedelta
|
|
|
|
from module.config.stored.classes import now
|
|
from module.logger import logger
|
|
from module.ocr.ocr import Duration
|
|
from tasks.assignment.assets.assets_assignment_claim import *
|
|
from tasks.assignment.assets.assets_assignment_ui import EVENT_COMPLETED
|
|
from tasks.assignment.dispatch import AssignmentDispatch
|
|
from tasks.assignment.keywords import AssignmentEntry
|
|
from tasks.base.page import page_assignment
|
|
|
|
|
|
class AssignmentClaim(AssignmentDispatch):
|
|
def claim(self, assignment: AssignmentEntry, duration_expected: int, should_redispatch: bool):
|
|
"""
|
|
Args:
|
|
assignment (AssignmentEntry):
|
|
duration_expected (int): user specified duration
|
|
should_redispatch (bool):
|
|
|
|
Pages:
|
|
in: CLAIM
|
|
out: DISPATCHED or EMPTY_SLOT
|
|
"""
|
|
redispatched = False
|
|
self._wait_for_report()
|
|
if should_redispatch:
|
|
redispatched = self._is_duration_expected(duration_expected)
|
|
self._exit_report(redispatched)
|
|
if redispatched:
|
|
self._wait_until_assignment_started()
|
|
future = now() + timedelta(hours=duration_expected)
|
|
logger.info(f'Assignment redispatched, will finish at {future}')
|
|
self.dispatched[assignment] = future
|
|
self.has_new_dispatch = True
|
|
elif should_redispatch:
|
|
# Re-select duration and dispatch
|
|
self.goto_entry(assignment)
|
|
self.dispatch(assignment, duration_expected)
|
|
|
|
def _wait_for_report(self):
|
|
"""
|
|
Pages:
|
|
in: CLAIM
|
|
out: REPORT
|
|
"""
|
|
skip_first_screenshot = True
|
|
while 1:
|
|
if skip_first_screenshot:
|
|
skip_first_screenshot = False
|
|
else:
|
|
self.device.screenshot()
|
|
# End
|
|
# Neither CLOSE_REPORT nor REDISPATCH is shown
|
|
# If it is an EVENT assignment
|
|
if self.appear(REPORT):
|
|
logger.info('Assignment report appears')
|
|
break
|
|
# Claim rewards
|
|
if self.appear_then_click(CLAIM, interval=2):
|
|
continue
|
|
|
|
def _exit_report(self, should_redispatch: bool):
|
|
"""
|
|
Args:
|
|
should_redispatch (bool): determined by user config and duration in report
|
|
|
|
Pages:
|
|
in: REPORT
|
|
out: page_assignment
|
|
"""
|
|
click_button = REDISPATCH if should_redispatch else CLOSE_REPORT
|
|
skip_first_screenshot = True
|
|
while 1:
|
|
if skip_first_screenshot:
|
|
skip_first_screenshot = False
|
|
else:
|
|
self.device.screenshot()
|
|
# End
|
|
if self.appear(page_assignment.check_button):
|
|
logger.info('Assignment report is closed')
|
|
break
|
|
if self.appear(EVENT_COMPLETED):
|
|
logger.info('Event completed')
|
|
return
|
|
# Close report
|
|
if self.appear(REPORT, interval=1):
|
|
self.device.click(click_button)
|
|
continue
|
|
# Ensure report totally disappears
|
|
self._wait_until_entry_loaded()
|
|
|
|
def _is_duration_expected(self, duration: int) -> bool:
|
|
"""
|
|
Check whether duration in assignment report page
|
|
is the same as user specified
|
|
|
|
Args:
|
|
duration (int): user specified duration
|
|
|
|
Returns:
|
|
bool: If same.
|
|
"""
|
|
duration_reported: timedelta = Duration(
|
|
OCR_ASSIGNMENT_REPORT_TIME).ocr_single_line(self.device.image)
|
|
return duration_reported.total_seconds() == duration * 3600
|