2021-05-09 07:05:51 +00:00
|
|
|
import logging
|
2020-05-14 02:03:13 +00:00
|
|
|
import time
|
2020-05-19 03:11:58 +00:00
|
|
|
import typing
|
2020-05-14 02:03:13 +00:00
|
|
|
from threading import Thread
|
2021-05-09 07:05:51 +00:00
|
|
|
from typing import Callable, Optional
|
2020-05-14 02:03:13 +00:00
|
|
|
|
2021-11-21 11:07:09 +00:00
|
|
|
from fishy.engine.semifisher.fishing_mode import FishingMode
|
2021-11-21 07:12:14 +00:00
|
|
|
|
2020-10-17 10:52:04 +00:00
|
|
|
from fishy.engine.common.IEngine import IEngine
|
2021-11-21 07:12:14 +00:00
|
|
|
from fishy.engine.common.qr_detection import get_qr_location, get_values_from_image, image_pre_process
|
2021-05-09 07:05:51 +00:00
|
|
|
from fishy.engine.common.window import WindowClient
|
|
|
|
from fishy.engine.semifisher import fishing_event, fishing_mode
|
2021-04-15 18:26:35 +00:00
|
|
|
from fishy.engine.semifisher.fishing_event import FishEvent
|
2022-02-01 16:50:57 +00:00
|
|
|
from fishy.helper.helper import print_exc
|
2021-04-09 18:50:53 +00:00
|
|
|
|
2020-05-19 03:11:58 +00:00
|
|
|
if typing.TYPE_CHECKING:
|
|
|
|
from fishy.gui import GUI
|
|
|
|
|
2020-05-14 02:03:13 +00:00
|
|
|
|
2020-06-01 12:58:18 +00:00
|
|
|
class SemiFisherEngine(IEngine):
|
2020-10-17 19:45:57 +00:00
|
|
|
def __init__(self, gui_ref: Optional['Callable[[], GUI]']):
|
2020-10-17 19:06:07 +00:00
|
|
|
super().__init__(gui_ref)
|
2021-11-21 07:12:14 +00:00
|
|
|
self.window = None
|
2022-02-20 17:01:46 +00:00
|
|
|
self.values = None
|
2022-02-03 00:21:31 +00:00
|
|
|
self.name = "SemiFisher"
|
2020-05-19 03:11:58 +00:00
|
|
|
|
2020-06-01 12:58:18 +00:00
|
|
|
def run(self):
|
2020-05-14 02:03:13 +00:00
|
|
|
"""
|
|
|
|
Starts the fishing
|
|
|
|
code explained in comments in detail
|
|
|
|
"""
|
2020-11-30 21:04:33 +00:00
|
|
|
if self.get_gui:
|
|
|
|
logging.info("Starting the bot engine, look at the fishing hole to start fishing")
|
2021-04-17 16:34:10 +00:00
|
|
|
Thread(target=self._wait_and_check).start()
|
|
|
|
|
2022-02-20 18:59:37 +00:00
|
|
|
time.sleep(0.2)
|
2022-02-01 16:50:57 +00:00
|
|
|
capture = self.window.get_capture()
|
|
|
|
if capture is None:
|
|
|
|
logging.error("couldn't get game capture")
|
|
|
|
return
|
|
|
|
|
|
|
|
self.window.crop = get_qr_location(capture)
|
2022-01-31 17:49:24 +00:00
|
|
|
if not self.window.crop:
|
|
|
|
logging.error("FishyQR not found, try to drag it around and try again")
|
|
|
|
return
|
2021-11-21 07:12:14 +00:00
|
|
|
|
2022-01-31 17:49:24 +00:00
|
|
|
fishing_event.init()
|
2022-02-01 11:51:58 +00:00
|
|
|
# noinspection PyBroadException
|
|
|
|
try:
|
|
|
|
self._engine_loop()
|
|
|
|
except Exception:
|
|
|
|
logging.error("exception occurred while running engine loop")
|
2022-02-01 16:50:57 +00:00
|
|
|
print_exc()
|
2022-02-01 11:51:58 +00:00
|
|
|
|
|
|
|
fishing_event.unsubscribe()
|
|
|
|
|
|
|
|
def _engine_loop(self):
|
2022-01-31 17:49:24 +00:00
|
|
|
skip_count = 0
|
|
|
|
while self.state == 1 and WindowClient.running():
|
2021-11-21 07:12:14 +00:00
|
|
|
capture = self.window.processed_image(func=image_pre_process)
|
2020-06-25 01:22:39 +00:00
|
|
|
|
2021-11-21 07:12:14 +00:00
|
|
|
# if window server crashed
|
2022-02-01 16:50:57 +00:00
|
|
|
if capture is None:
|
2022-01-31 17:49:24 +00:00
|
|
|
logging.error("Couldn't capture window stopping engine")
|
2022-02-01 11:51:58 +00:00
|
|
|
return
|
2020-05-14 02:03:13 +00:00
|
|
|
|
2021-11-21 07:12:14 +00:00
|
|
|
# crop qr and get the values from it
|
2022-02-20 17:01:46 +00:00
|
|
|
self.values = get_values_from_image(capture)
|
2022-01-31 17:49:24 +00:00
|
|
|
# if fishyqr fails to get read multiple times, stop the bot
|
2022-02-20 17:01:46 +00:00
|
|
|
if not self.values:
|
2022-01-31 17:49:24 +00:00
|
|
|
if skip_count >= 5:
|
2022-02-01 16:50:57 +00:00
|
|
|
logging.error("Couldn't read values from FishyQR, Stopping engine...")
|
2022-02-01 11:51:58 +00:00
|
|
|
return
|
2022-02-20 18:59:37 +00:00
|
|
|
skip_count += 1
|
|
|
|
time.sleep(0.1)
|
2022-01-31 17:49:24 +00:00
|
|
|
else:
|
|
|
|
skip_count = 0
|
|
|
|
|
2022-02-20 17:01:46 +00:00
|
|
|
if self.values:
|
|
|
|
fishing_mode.loop(self.values[3])
|
2021-05-07 01:35:06 +00:00
|
|
|
time.sleep(0.1)
|
2020-10-17 16:04:44 +00:00
|
|
|
|
2020-06-25 01:22:39 +00:00
|
|
|
def _wait_and_check(self):
|
|
|
|
time.sleep(10)
|
2022-01-31 17:49:24 +00:00
|
|
|
if not FishEvent.FishingStarted and self.state == 1:
|
2021-05-09 09:44:19 +00:00
|
|
|
logging.warning("Doesn't look like fishing has started \n"
|
2021-11-21 11:07:09 +00:00
|
|
|
"Check out #faqs on our discord channel to troubleshoot the issue")
|
2020-06-25 01:22:39 +00:00
|
|
|
|
2022-01-31 17:49:24 +00:00
|
|
|
# TODO: remove this, no longer needed
|
2022-02-20 17:01:46 +00:00
|
|
|
def show_qr_vals(self):
|
2020-05-14 02:03:13 +00:00
|
|
|
def show():
|
|
|
|
freq = 0.5
|
|
|
|
t = 0
|
2022-02-20 17:01:46 +00:00
|
|
|
while t < 25.0:
|
2020-05-14 02:03:13 +00:00
|
|
|
t += freq
|
2022-02-20 17:01:46 +00:00
|
|
|
logging.info(str(self.values))
|
2020-05-14 02:03:13 +00:00
|
|
|
time.sleep(freq)
|
2022-02-20 17:01:46 +00:00
|
|
|
logging.info("Displaying QR values stopped")
|
2020-05-14 02:03:13 +00:00
|
|
|
|
2022-02-20 17:01:46 +00:00
|
|
|
logging.info("Will display QR values for 25 seconds")
|
2020-05-14 02:03:13 +00:00
|
|
|
time.sleep(5)
|
|
|
|
Thread(target=show, args=()).start()
|
2020-05-19 03:11:58 +00:00
|
|
|
|
|
|
|
|
2020-10-17 16:04:44 +00:00
|
|
|
if __name__ == '__main__':
|
|
|
|
logging.getLogger("").setLevel(logging.DEBUG)
|
|
|
|
# noinspection PyTypeChecker
|
2020-10-17 19:06:07 +00:00
|
|
|
fisher = SemiFisherEngine(None)
|
2020-10-17 16:04:44 +00:00
|
|
|
fisher.toggle_start()
|