2022-01-31 17:48:51 +00:00
|
|
|
import logging
|
|
|
|
import traceback
|
2020-06-01 12:58:18 +00:00
|
|
|
import typing
|
|
|
|
from threading import Thread
|
|
|
|
from typing import Callable
|
|
|
|
|
2022-02-01 11:51:58 +00:00
|
|
|
import cv2
|
2022-01-31 17:48:51 +00:00
|
|
|
from playsound import playsound
|
|
|
|
|
2022-02-01 11:51:58 +00:00
|
|
|
from fishy.engine.common.window import WindowClient
|
2020-10-17 19:06:07 +00:00
|
|
|
from fishy.gui.funcs import GUIFuncsMock
|
2022-01-31 17:48:51 +00:00
|
|
|
from fishy.helper import helper
|
2022-02-01 16:50:57 +00:00
|
|
|
from fishy.helper.helper import print_exc
|
2020-10-17 08:06:49 +00:00
|
|
|
|
2020-06-01 12:58:18 +00:00
|
|
|
if typing.TYPE_CHECKING:
|
|
|
|
from fishy.gui import GUI
|
|
|
|
|
|
|
|
|
2022-01-31 17:48:51 +00:00
|
|
|
class IEngine:
|
2020-06-01 12:58:18 +00:00
|
|
|
|
2020-10-17 19:06:07 +00:00
|
|
|
def __init__(self, gui_ref: 'Callable[[], GUI]'):
|
2020-06-01 12:58:18 +00:00
|
|
|
self.get_gui = gui_ref
|
2022-01-31 17:48:51 +00:00
|
|
|
# 0 - off, 1 - running, 2 - quitting
|
|
|
|
self.state = 0
|
2020-06-03 01:41:54 +00:00
|
|
|
self.window = None
|
2022-02-02 23:20:36 +00:00
|
|
|
self.thread: Thread = None
|
2020-06-01 12:58:18 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def gui(self):
|
2020-10-17 08:06:49 +00:00
|
|
|
if self.get_gui is None:
|
|
|
|
return GUIFuncsMock()
|
|
|
|
|
2020-06-01 12:58:18 +00:00
|
|
|
return self.get_gui().funcs
|
|
|
|
|
2022-02-01 11:27:14 +00:00
|
|
|
@property
|
|
|
|
def start(self):
|
|
|
|
return self.state == 1
|
|
|
|
|
2020-06-01 12:58:18 +00:00
|
|
|
def toggle_start(self):
|
2022-02-01 11:27:14 +00:00
|
|
|
if self.state == 0:
|
|
|
|
self.turn_on()
|
|
|
|
else:
|
2022-02-01 16:50:57 +00:00
|
|
|
self.turn_off()
|
2022-01-31 17:48:51 +00:00
|
|
|
|
|
|
|
def turn_on(self):
|
|
|
|
self.state = 1
|
|
|
|
self.thread = Thread(target=self._crash_safe)
|
|
|
|
self.thread.start()
|
|
|
|
|
2022-02-02 23:20:36 +00:00
|
|
|
def join(self):
|
|
|
|
if self.thread:
|
|
|
|
self.thread.join()
|
|
|
|
|
2022-01-31 17:48:51 +00:00
|
|
|
def turn_off(self):
|
|
|
|
"""
|
|
|
|
this method only signals the thread to close using start flag,
|
|
|
|
its the responsibility of the thread to shut turn itself off
|
|
|
|
"""
|
2022-02-01 11:27:14 +00:00
|
|
|
if self.state == 1:
|
|
|
|
logging.info("turning off...")
|
|
|
|
self.state = 2
|
|
|
|
else:
|
|
|
|
logging.error("engine already signaled to turn off")
|
|
|
|
# todo: implement force turn off on repeated calls
|
2022-01-31 17:48:51 +00:00
|
|
|
|
|
|
|
# noinspection PyBroadException
|
|
|
|
def _crash_safe(self):
|
2022-02-01 11:51:58 +00:00
|
|
|
self.window = WindowClient(color=cv2.COLOR_RGB2GRAY, show_name="fishy debug")
|
2022-01-31 17:48:51 +00:00
|
|
|
self.gui.bot_started(True)
|
|
|
|
try:
|
|
|
|
self.run()
|
|
|
|
except Exception:
|
2022-02-01 16:50:57 +00:00
|
|
|
print_exc()
|
2022-01-31 17:48:51 +00:00
|
|
|
self.state = 0
|
|
|
|
self.gui.bot_started(False)
|
2022-02-01 11:51:58 +00:00
|
|
|
self.window.destroy()
|
2020-06-01 12:58:18 +00:00
|
|
|
|
|
|
|
def run(self):
|
2022-01-31 17:48:51 +00:00
|
|
|
raise NotImplementedError
|