2020-05-14 02:03:13 +00:00
|
|
|
import time
|
2020-05-19 03:11:58 +00:00
|
|
|
import typing
|
|
|
|
from collections import Callable
|
2020-05-14 02:03:13 +00:00
|
|
|
from threading import Thread
|
|
|
|
|
|
|
|
import cv2
|
|
|
|
import logging
|
|
|
|
|
|
|
|
import pywintypes
|
|
|
|
|
2020-05-19 03:11:58 +00:00
|
|
|
from fishy.tech.funcs import EngineFuncs
|
2020-05-14 02:03:13 +00:00
|
|
|
from . import fishing_event
|
|
|
|
from .fishing_event import HookEvent, StickEvent, LookEvent, IdleEvent
|
|
|
|
from .fishing_mode import FishingMode
|
|
|
|
from .pixel_loc import PixelLoc
|
|
|
|
from .window import Window
|
|
|
|
|
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
|
|
|
|
|
|
|
def _wait_and_check(gui):
|
|
|
|
time.sleep(10)
|
|
|
|
if not fishing_event._FishingStarted:
|
2020-05-19 03:11:58 +00:00
|
|
|
gui.show_error("Doesn't look like fishing has started\n\n"
|
|
|
|
"Make sure ProvisionsChalutier addon is visible clearly on top "
|
|
|
|
"left corner of the screen, either,\n"
|
|
|
|
"1) Outdated addons are disabled\n"
|
|
|
|
"2) Other addons are overlapping ProvisionsChalutier\n"
|
|
|
|
"3) Post processing (re shader) is on\n\n"
|
|
|
|
"If fixing those doesnt work, try running the bot as admin")
|
2020-05-14 02:03:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
class Engine:
|
2020-05-19 03:11:58 +00:00
|
|
|
def __init__(self, config, gui_ref: 'Callable[[], GUI]'):
|
|
|
|
self.funcs = EngineFuncs(self)
|
|
|
|
self.get_gui = gui_ref
|
|
|
|
|
2020-05-14 02:03:13 +00:00
|
|
|
self.start = False
|
|
|
|
self.fishPixWindow = None
|
|
|
|
self.fishy_thread = None
|
|
|
|
self.config = config
|
2020-05-19 03:11:58 +00:00
|
|
|
self.event_handler_running = True
|
|
|
|
self.gui_events = []
|
|
|
|
|
|
|
|
@property
|
|
|
|
def gui(self):
|
|
|
|
return self.get_gui().funcs
|
2020-05-14 02:03:13 +00:00
|
|
|
|
|
|
|
def start_fishing(self, action_key: str, borderless: bool, collect_r: bool):
|
|
|
|
"""
|
|
|
|
Starts the fishing
|
|
|
|
code explained in comments in detail
|
|
|
|
"""
|
|
|
|
|
|
|
|
# initialize widow
|
|
|
|
# noinspection PyUnresolvedReferences
|
|
|
|
try:
|
|
|
|
Window.init(borderless)
|
|
|
|
except pywintypes.error:
|
|
|
|
logging.info("Game window not found")
|
|
|
|
self.start = False
|
|
|
|
return
|
|
|
|
|
|
|
|
# initializes fishing modes and their callbacks
|
|
|
|
FishingMode("hook", 0, HookEvent(action_key, collect_r))
|
|
|
|
FishingMode("stick", 1, StickEvent())
|
|
|
|
FishingMode("look", 2, LookEvent(action_key))
|
|
|
|
FishingMode("idle", 3, IdleEvent(self.config.get("uid")))
|
|
|
|
|
|
|
|
self.fishPixWindow = Window(color=cv2.COLOR_RGB2HSV)
|
|
|
|
|
|
|
|
# check for game window and stuff
|
2020-05-19 03:11:58 +00:00
|
|
|
self.gui.bot_started(True)
|
2020-05-14 02:03:13 +00:00
|
|
|
logging.info("Starting the bot engine, look at the fishing hole to start fishing")
|
|
|
|
Thread(target=_wait_and_check, args=(self.gui,)).start()
|
|
|
|
while self.start:
|
|
|
|
# Services to be ran in the start of the main loop
|
|
|
|
Window.loop()
|
|
|
|
|
|
|
|
# get the PixelLoc and find the color values, to give it to `FishingMode.Loop`
|
|
|
|
self.fishPixWindow.crop = PixelLoc.val
|
|
|
|
hue_value = self.fishPixWindow.get_capture()[0][0][0]
|
|
|
|
FishingMode.loop(hue_value)
|
|
|
|
# Services to be ran in the end of the main loop
|
|
|
|
Window.loop_end()
|
|
|
|
logging.info("Fishing engine stopped")
|
2020-05-19 03:11:58 +00:00
|
|
|
self.gui.bot_started(False)
|
2020-05-14 02:03:13 +00:00
|
|
|
|
|
|
|
def start_event_handler(self):
|
2020-05-19 03:11:58 +00:00
|
|
|
while self.event_handler_running:
|
2020-05-14 02:03:13 +00:00
|
|
|
while len(self.gui_events) > 0:
|
|
|
|
event = self.gui_events.pop(0)
|
2020-05-19 03:11:58 +00:00
|
|
|
event()
|
2020-05-14 02:03:13 +00:00
|
|
|
|
|
|
|
def _show_pixel_vals(self):
|
|
|
|
def show():
|
|
|
|
freq = 0.5
|
|
|
|
t = 0
|
|
|
|
while t < 10.0:
|
|
|
|
t += freq
|
|
|
|
logging.debug(str(FishingMode.CurrentMode.label) + ":" + str(self.fishPixWindow.get_capture()[0][0]))
|
|
|
|
time.sleep(freq)
|
|
|
|
|
|
|
|
logging.debug("Will display pixel values for 10 seconds")
|
|
|
|
time.sleep(5)
|
|
|
|
Thread(target=show, args=()).start()
|
2020-05-19 03:11:58 +00:00
|
|
|
|
|
|
|
|
|
|
|
|