StarRailCopilot/tasks/combat/fuel.py

211 lines
7.3 KiB
Python
Raw Normal View History

import module.config.server as server
2024-07-18 16:03:50 +00:00
from module.base.timer import Timer
from module.base.utils import area_offset, crop
2024-06-27 22:29:39 +00:00
from module.logger import logger
from module.ocr.ocr import Digit
from tasks.base.assets.assets_base_popup import GET_REWARD, POPUP_CANCEL, POPUP_CONFIRM
2024-06-27 22:29:39 +00:00
from tasks.base.ui import UI
from tasks.combat.assets.assets_combat_finish import COMBAT_AGAIN, COMBAT_EXIT
from tasks.combat.assets.assets_combat_fuel import *
from tasks.combat.assets.assets_combat_prepare import COMBAT_PREPARE
from tasks.item.slider import Slider
2024-06-27 22:29:39 +00:00
class Fuel(UI):
fuel_trailblaze_power = 60
2024-06-29 08:18:06 +00:00
def _use_fuel_finish(self):
"""
Two possible finish states after using fuel/extract trailblaze power:
1. COMBAT_PREPARE
2. COMBAT_AGAIN
"""
if self.appear(COMBAT_AGAIN):
if self.image_color_count(COMBAT_AGAIN, color=(227, 227, 228), threshold=221, count=50):
logger.info(f'Use fuel finished at COMBAT_AGAIN')
return True
if self.appear(COMBAT_PREPARE):
if self.image_color_count(COMBAT_PREPARE.button, color=(230, 230, 230), threshold=240, count=400):
logger.info(f'Use fuel finished at COMBAT_AGAIN')
return True
return False
2024-07-18 15:27:41 +00:00
def _fuel_confirm(self, skip_first_screenshot=True):
"""
Pages:
in: fuel popup
out: _use_fuel_finish
"""
logger.info('Fuel confirm')
self.interval_clear([POPUP_CONFIRM, POPUP_CANCEL, GET_REWARD])
while 1:
if skip_first_screenshot:
skip_first_screenshot = False
else:
self.device.screenshot()
if self._use_fuel_finish():
break
if self.handle_popup_confirm():
continue
if self.handle_reward():
continue
self._fuel_wait_leave()
2024-07-18 15:27:41 +00:00
def _fuel_cancel(self, skip_first_screenshot=True):
"""
Pages:
in: fuel popup
out: _use_fuel_finish
"""
logger.info('Fuel cancel')
self.interval_clear([POPUP_CONFIRM, POPUP_CANCEL, GET_REWARD])
while 1:
if skip_first_screenshot:
skip_first_screenshot = False
else:
self.device.screenshot()
if self._use_fuel_finish():
break
if self.handle_popup_cancel():
continue
if self.handle_reward():
continue
self._fuel_wait_leave()
def _fuel_wait_leave(self):
# Blur disappears before popup
# so there's a short period of time that COMBAT_AGAIN is unclickable
# This is equivalent to poor sleep
timer = self.get_interval_timer(COMBAT_AGAIN, interval=5, renew=True)
timer.set_current(4.4)
timer = self.get_interval_timer(COMBAT_EXIT, interval=5, renew=True)
timer.set_current(4.4)
def extract_reserved_trailblaze_power(self, current, skip_first_screenshot=True):
2024-06-27 22:29:39 +00:00
"""
Extract reserved trailblaze power from previous combat.
Returns:
bool: If extracted
2024-06-27 22:29:39 +00:00
"""
logger.info('Extract reserved trailblaze power')
reserved = Digit(OCR_RESERVED_TRAILBLAZE_POWER).ocr_single_line(self.device.image)
2024-07-18 15:27:41 +00:00
if reserved <= 0:
2024-06-27 22:29:39 +00:00
logger.info('No reserved trailblaze power')
return False
2024-06-27 22:29:39 +00:00
2024-07-18 15:27:41 +00:00
self.interval_clear([POPUP_CONFIRM, POPUP_CANCEL, GET_REWARD])
2024-06-27 22:29:39 +00:00
while 1:
if skip_first_screenshot:
skip_first_screenshot = False
else:
self.device.screenshot()
2024-07-18 15:27:41 +00:00
if self.appear(POPUP_CONFIRM):
2024-06-29 08:18:06 +00:00
break
2024-06-27 22:29:39 +00:00
if self.appear_then_click(EXTRACT_RESERVED_TRAILBLAZE_POWER):
continue
if self.appear_then_click(RESERVED_TRAILBLAZE_POWER_ENTRANCE):
continue
2024-07-18 15:27:41 +00:00
count = min(reserved, self.config.stored.TrailblazePower.FIXED_TOTAL - current)
logger.info(f'Having {reserved} reserved, going to use {count}')
self.set_reserved_trailblaze_power(count, total=reserved)
2024-07-18 15:27:41 +00:00
self._fuel_confirm()
return True
2024-06-27 22:29:39 +00:00
def set_reserved_trailblaze_power(self, count, total):
slider = Slider(main=self, slider=RESERVED_SLIDER)
slider.set(count, total)
self.ui_ensure_index(
count, letter=Digit(OCR_EXTRACT_RESERVED_TRAILBLAZE_POWER_COUNT, lang=server.lang),
next_button=RESERVED_PLUS, prev_button=RESERVED_MINUS,
skip_first_screenshot=True
)
2024-07-18 16:03:50 +00:00
def set_fuel_count(self, count):
slider = Slider(main=self, slider=FUEL_SLIDER)
2024-07-18 16:03:50 +00:00
# Can only use 5 fuel at one time
slider.set(count, 5)
self.ui_ensure_index(
count, letter=Digit(OCR_FUEL_COUNT, lang=server.lang),
next_button=FUEL_PLUS, prev_button=FUEL_MINUS,
skip_first_screenshot=True
)
def use_fuel(self, current, skip_first_screenshot=True):
"""
Args:
current:
skip_first_screenshot:
Returns:
bool: If used
"""
2024-07-18 15:27:41 +00:00
limit = self.config.stored.TrailblazePower.FIXED_TOTAL
use = (limit - current) // self.fuel_trailblaze_power
if use == 0:
logger.info(f"Current trailblaze power is near {limit}, no need to use fuel")
return False
2024-06-27 22:29:39 +00:00
logger.info("Use Fuel")
2024-07-18 16:03:50 +00:00
timeout = Timer(1, count=3)
has_fuel = False
2024-06-27 22:29:39 +00:00
while 1:
if skip_first_screenshot:
skip_first_screenshot = False
else:
self.device.screenshot()
if self.appear(FUEL_SELECTED):
2024-07-18 16:03:50 +00:00
logger.info('Fuel selected')
2024-06-27 22:29:39 +00:00
break
2024-07-18 16:03:50 +00:00
if self.appear(POPUP_CONFIRM):
timeout.start()
if self.appear(FUEL_SELECTED) or self.appear(FUEL):
has_fuel = True
if not has_fuel and timeout.reached():
logger.info("No fuel found")
return False
2024-06-27 22:29:39 +00:00
if self.appear_then_click(FUEL):
2024-07-18 16:03:50 +00:00
has_fuel = True
2024-06-27 22:29:39 +00:00
continue
2024-07-18 16:03:50 +00:00
if not self.appear(POPUP_CONFIRM) and self.appear_then_click(FUEL_ENTRANCE):
2024-06-27 22:29:39 +00:00
continue
offset = FUEL_SELECTED.button_offset
2024-07-18 15:27:41 +00:00
image = crop(self.device.image, area_offset(OCR_FUEL.area, offset), copy=False)
count = Digit(OCR_FUEL).ocr_single_line(image, direct_ocr=True)
2024-06-27 22:29:39 +00:00
2024-07-18 15:27:41 +00:00
reserve = self.config.TrailblazePower_FuelReserve
available_count = max(count - reserve, 0)
use = min(use, available_count)
logger.info(f'Having {count} fuel, reserve {reserve} fuel, going to use {use} fuel')
if use <= 0:
logger.info("Fuel remain is under the reserve threshold, stop using fuel")
self._fuel_cancel()
return False
2024-06-27 22:29:39 +00:00
2024-07-18 15:27:41 +00:00
skip_first_screenshot = True
2024-06-27 22:29:39 +00:00
while 1:
if skip_first_screenshot:
skip_first_screenshot = False
else:
self.device.screenshot()
if self.appear(USING_FUEL):
2024-06-27 22:29:39 +00:00
break
2024-07-18 15:27:41 +00:00
if self.appear(FUEL) and self.handle_popup_confirm():
2024-06-29 08:18:06 +00:00
continue
2024-07-18 16:03:50 +00:00
if self.appear(FUEL_SELECTED) and self.handle_popup_confirm():
continue
2024-07-18 16:03:50 +00:00
self.set_fuel_count(use)
2024-07-18 15:27:41 +00:00
self._fuel_confirm()
return True