main.py 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. import webbrowser
  2. from mss import mss
  3. import numpy as np
  4. from time import sleep, time
  5. import pyautogui as gui
  6. import sched
  7. import cv2
  8. cv2.namedWindow('View', cv2.WINDOW_NORMAL)
  9. DEFAULT_MONITOR = 3
  10. DEBUG = False
  11. scheduler = sched.scheduler(time, sleep)
  12. dilation_kernel = np.array([[0,0,0], [1, 1, 1], [0,0,0]]).astype('uint8')
  13. def take_screenshot(sct, monitor=DEFAULT_MONITOR):
  14. monitor = sct.monitors[monitor]
  15. image = np.array(sct.grab(monitor))
  16. return image
  17. def take_binaryScreenshot(sct, monitor: dict):
  18. image = np.array(sct.grab(monitor))
  19. binaryScreen = np.zeros(image.shape[:-1])
  20. binaryScreen[np.all(image == (83, 83, 83, 0), axis=2)] = 1
  21. binaryScreen = cv2.erode(binaryScreen, None, iterations=1)
  22. binaryScreen = cv2.dilate(binaryScreen, None, iterations=1)
  23. return binaryScreen
  24. def binary_to_RGB(image):
  25. rgb_image = np.zeros((*image.shape, 3))
  26. rgb_image[image == 1] = (255, 255, 255)
  27. return rgb_image
  28. def open_dino(sct):
  29. prevScreen = take_screenshot(sct)
  30. webbrowser.open('https://chromedino.com/')
  31. sleep(1)
  32. Screen = take_screenshot(sct)
  33. while np.any(Screen != prevScreen):
  34. cv2.imshow('View', Screen)
  35. cv2.waitKey(1)
  36. sleep(1)
  37. prevScreen = Screen.copy()
  38. Screen = take_screenshot(sct)
  39. print('loaded')
  40. def shortest_jump():
  41. with gui.hold('space'):
  42. sleep(0.1)
  43. take_down()
  44. def short_jump():
  45. with gui.hold('space'):
  46. sleep(0.15)
  47. take_down()
  48. def long_jump():
  49. with gui.hold('space'):
  50. sleep(0.2)
  51. take_down()
  52. def take_down():
  53. with gui.hold('down'):
  54. sleep(0.04)
  55. def jump(sec):
  56. print('jump suka jump')
  57. with gui.hold('space'):
  58. sleep(sec)
  59. take_down()
  60. def get_playing_bbox(sct):
  61. Screen = take_screenshot(sct)
  62. binaryScreen = np.zeros(Screen.shape[:-1])
  63. binaryScreen[np.all(Screen == (83, 83, 83, 0), axis=2)] = 1
  64. short_jump()
  65. sleep(1)
  66. binScreen = take_binaryScreenshot(sct, sct.monitors[DEFAULT_MONITOR])
  67. x, y = np.where(binScreen == 1)
  68. mw = (y.max()-y.min()) // 100
  69. mh = (x.max()-x.min()) // 100
  70. playing_bbox = {'left':y.min()-2*mw, 'top':x.min()+15*mh, 'width':(y.max()-y.min())+4*mw, 'height':(x.max()-x.min())+10*mh}
  71. return playing_bbox, mw, mh
  72. def to_bbox(bin_image):
  73. bin_image = cv2.dilate(bin_image, dilation_kernel, iterations=4)
  74. labels, labeledScreen = cv2.connectedComponents(bin_image.astype('uint8'))
  75. for label in range(1, labels):
  76. x,y = np.where(labeledScreen==label)
  77. bin_image[x.min():x.max()+1, y.min():y.max()+1] = 1
  78. return bin_image
  79. if __name__ == '__main__':
  80. sct = mss()
  81. open_dino(sct)
  82. gui.hotkey('fn', 'f11')
  83. playing_bbox, pw, ph = get_playing_bbox(sct)
  84. binScreen = take_binaryScreenshot(sct, playing_bbox)
  85. binScreen = to_bbox(binScreen)
  86. labels, labeledScreen = cv2.connectedComponents(binScreen.astype('uint8'))
  87. if DEBUG: rgbScreen = binary_to_RGB(binScreen)
  88. dino_label = min(range(1,labels), key=lambda x: np.where(labeledScreen==x)[1].min())
  89. dino_pos = np.where(labeledScreen==dino_label)
  90. dino_max_x = dino_pos[1].max()
  91. dino_min_y = dino_pos[0].max()
  92. dino_max_y = dino_pos[0].min()
  93. coef = 1
  94. trigger_second = (int(dino_pos[0].mean()), int(dino_max_x + int(coef*7)*pw))
  95. trigger_feather = (dino_max_y, int(dino_max_x + int(coef*10)*pw))
  96. jumping = False
  97. taking = False
  98. print(ph, pw)
  99. start = time()
  100. if DEBUG: cv2.imshow('View', rgbScreen)
  101. while True:
  102. binScreen = take_binaryScreenshot(sct, playing_bbox)
  103. binScreen = to_bbox(binScreen)
  104. labels, labeledScreen = cv2.connectedComponents(binScreen.astype('uint8'))
  105. if not jumping and binScreen[trigger_second] != 0 or binScreen[trigger_feather] != 0:
  106. print('jumping')
  107. gui.keyDown('space')
  108. jumping = True
  109. elif jumping and binScreen[trigger_second[0], trigger_second[1]+(int(coef-1)*pw)] == 0 and binScreen[trigger_feather[0], trigger_feather[1]+(int(coef-1)*pw)] == 0:
  110. print('taking')
  111. gui.keyUp('space')
  112. gui.keyDown('down')
  113. jumping = False
  114. taking = True
  115. if taking and binScreen[dino_max_y-ph, dino_max_x] != 0:
  116. print('take off')
  117. gui.keyUp('down')
  118. taking = False
  119. if time() - start > 15:
  120. print(time() - start)
  121. coef += 0.1
  122. trigger_second = (trigger_second[0], trigger_second[1]+pw)
  123. trigger_feather = (trigger_feather[0], trigger_feather[1]+pw)
  124. start = time()
  125. if DEBUG:
  126. rgbScreen = binary_to_RGB(binScreen)
  127. cv2.circle(rgbScreen, trigger_feather[::-1], radius=2, color=(255, 0, 0), thickness=2)
  128. cv2.circle(rgbScreen, trigger_second[::-1], radius=2, color=(0, 255, 0), thickness=2)
  129. cv2.imshow('View', rgbScreen)
  130. if cv2.waitKey(1) == ord('q'): break
  131. cv2.destroyAllWindows()