fishyboteso/fishy.py

242 lines
6.7 KiB
Python
Raw Normal View History

2018-05-03 16:37:18 +00:00
"""Fishy
Usage:
fishy.py -h | --help
fishy.py -v | --version
fishy.py -c | --configwin
fishy.py -f | --fish [--ip=IPADDRESS] [HOOK_THRESHOLD] [--check-frequency=<hz>]
2018-05-03 16:37:18 +00:00
Options:
-h, --help Show this screen.
-v, --version Show version.
-c, --configwin Configure the game window.
-f, --fish Start fishing.
--check-frequency=<hz> Sleep after loop in s [default: 10].
2018-05-03 16:37:18 +00:00
"""
VERSION = "0.1.0"
print("Fishy " + VERSION + " for Elder Scrolls Online")
2018-05-03 16:37:18 +00:00
try:
from docopt import docopt
2018-05-03 16:37:18 +00:00
arguments = docopt(__doc__)
if arguments["--version"]:
quit()
2018-05-03 16:37:18 +00:00
print("Loading, Please Wait...")
import imutils as imutils
import numpy as np
from PIL import ImageGrab
import cv2
import pyautogui
import time
import fishy_network as net
from fishy_config import config_win
from pynput.keyboard import Key, Listener
from decimal import Decimal
except Exception:
raise
2018-05-03 16:37:18 +00:00
controls = {"stop": [Key.f11, "f11"], "debug": [Key.f10, "f10"], "pause": [Key.f9, "f9"]}
2018-05-03 16:37:18 +00:00
stop = False
pause = False
debug = False
IMG_SIZE = 100
LR = 1e-3
STICK_TIMEOUT = 30.0
NONE_TIMEOUT = 5.0
2018-05-03 16:37:18 +00:00
IP_ADDRESS = arguments["--ip"]
bbox = (0, 31, 800, 600)
pixelLoc = [[240, 0], [241, 1]]
2018-05-03 16:37:18 +00:00
def process_img(original_img):
"""
Convert image into hsv and crop it to select the required pixel
:param original_img: image grabbed from screen
:return: processed image in hsv
"""
original_img = cv2.cvtColor(original_img, cv2.COLOR_BGR2HSV)
# y:y+h, x:x+w
croped_img = original_img[pixelLoc[0][1]:pixelLoc[1][1], pixelLoc[0][0]:pixelLoc[1][0]]
return croped_img
2018-05-03 16:37:18 +00:00
def process_show(original_img):
"""
Converts image into rgb and crop it to select the required pixel then scale it up for debuging
:param original_img: image grabbed from screen
:return: proessed image in rgb
"""
original_img = cv2.cvtColor(original_img, cv2.COLOR_BGR2RGB)
# y:y+h, x:x+w
croped_img = original_img[pixelLoc[0][1]:pixelLoc[1][1], pixelLoc[0][0]:pixelLoc[1][0]]
croped_img = imutils.resize(croped_img, width=200)
return croped_img
2018-05-03 16:37:18 +00:00
def round_float(v, ndigits=2, rt_str=False):
d = Decimal(v)
v_str = ("{0:.%sf}" % ndigits).format(round(d, ndigits))
if rt_str:
return v_str
return Decimal(v_str)
2018-05-03 16:37:18 +00:00
def pullStick(fishCaught, timeToHook):
"""
Hooks the fish
:param fishCaught: fish cout to be displayed
:param timeToHook: time took to hook the fish
:return: void
"""
print("HOOOOOOOOOOOOOOOOOOOOOOOK....... " + str(fishCaught) + " caught " + " in " + str(round_float(timeToHook)) + " secs")
pyautogui.press('e')
# Timer(0.5, pressE).start()
2018-05-03 16:37:18 +00:00
time.sleep(0.5)
pyautogui.press('e')
2018-05-03 16:37:18 +00:00
def on_release(key):
"""
Read input
:param key: key released
:return: void
"""
2018-05-03 16:37:18 +00:00
global stop, pause, debug
if controls["pause"][0] == key:
pause = not pause
if pause:
print("PAUSED")
else:
print("STARTED")
elif controls["debug"][0] == key:
debug = not debug
elif controls["stop"][0] == key:
stop = True
2018-05-03 16:37:18 +00:00
def startFishing():
"""
Starts the fishing codde
:return: void
"""
2018-05-03 16:37:18 +00:00
global stop, pause, debug
2018-05-03 16:37:18 +00:00
pause = True
showedControls = True
debug = False
stop = False
holeDepleteSent = True
timerStarted = False
use_net = False
hooked = False
2018-05-03 16:37:18 +00:00
fishCaught = 0
prevLabel = 0
labelNum = 3
hVals = [60, 18, 100]
current_thresh = 0
2018-05-03 16:37:18 +00:00
stickInitTime = time.time()
ctrl_help = controls["pause"][1] + ": start or p" \
"ause\n" + controls["debug"][1] + ": start deb" \
"ug\n" + controls["stop"][1] + ": quit\n"
print(ctrl_help)
2018-05-03 16:37:18 +00:00
if IP_ADDRESS is not None:
use_net = True
net.initialize(IP_ADDRESS)
threshold = 3 if arguments["HOOK_THRESHOLD"] is None else int(arguments["HOOK_THRESHOLD"])
sleepFor = (1 / float(arguments["--check-frequency"]))
2018-05-03 16:37:18 +00:00
with Listener(on_release=on_release):
while not stop:
time.sleep(sleepFor)
# image grab
screen = np.array(ImageGrab.grab(bbox=bbox))
2018-05-03 16:37:18 +00:00
new_screen = process_img(screen)
hueValue = new_screen[0][0][0]
2018-05-03 16:37:18 +00:00
# find currentlable
currentLabel = 3
for i, val in enumerate(hVals):
if hueValue == val:
currentLabel = i
2018-05-03 16:37:18 +00:00
# check if it passes threshold, if so change labelNum
if prevLabel == currentLabel:
current_thresh += 1
else:
current_thresh = 0
prevLabel = currentLabel
if current_thresh >= threshold:
labelNum = currentLabel
2018-05-03 16:37:18 +00:00
# use label num
2018-05-03 16:37:18 +00:00
if not pause:
# fish caught
if labelNum == 0:
if not hooked:
fishCaught += 1
2018-05-03 16:37:18 +00:00
timeToHook = time.time() - stickInitTime
pullStick(fishCaught, timeToHook)
hooked = True
2018-05-03 16:37:18 +00:00
# fishing
2018-05-03 16:37:18 +00:00
if labelNum == 1:
hooked = False
if not timerStarted:
2018-05-03 16:37:18 +00:00
stickInitTime = time.time()
timerStarted = True
if (time.time() - stickInitTime) >= STICK_TIMEOUT:
print("STICK TIMED OUT, THROWING AGAIN")
pyautogui.press('e')
2018-05-03 16:37:18 +00:00
timerStarted = False
else:
timerStarted = False
# looking on hole
2018-05-03 16:37:18 +00:00
if labelNum == 2:
pass
# not looking on hole
if labelNum == 3:
if not holeDepleteSent:
if fishCaught > 0:
2018-05-03 16:37:18 +00:00
print("HOLE DEPLETED")
if use_net:
net.sendHoleDeplete(fishCaught)
fishCaught = 0
holeDepleteSent = True
else:
holeDepleteSent = False
2018-05-03 16:37:18 +00:00
if debug:
print(str(labelNum) + ":" + str(hueValue))
cv2.imshow('image', process_show(screen))
2018-05-03 16:37:18 +00:00
showedControls = False
else:
if not showedControls:
showedControls = True
print(ctrl_help)
cv2.destroyAllWindows()
2018-05-03 16:37:18 +00:00
cv2.waitKey(25)
if arguments["--configwin"]:
config_win()
2018-05-03 16:37:18 +00:00
elif arguments["--fish"]:
startFishing()