main.py 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  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 = True
  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. with mss() as sct:
  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*10)*pw))
  95. trigger_feather = (dino_max_y, int(dino_max_x + int(coef*12)*pw))
  96. jumping = False
  97. taking = False
  98. laing = False
  99. print(ph, pw)
  100. start = time()
  101. start2= time()
  102. if DEBUG: cv2.imshow('View', rgbScreen)
  103. while True:
  104. binScreen = take_binaryScreenshot(sct, playing_bbox)
  105. binScreen = to_bbox(binScreen)
  106. labels, labeledScreen = cv2.connectedComponents(binScreen.astype('uint8'))
  107. if not jumping and binScreen[trigger_second] != 0 or binScreen[trigger_feather] != 0:
  108. print('jumping')
  109. gui.keyDown('space')
  110. jumping = True
  111. elif jumping and binScreen[trigger_second[0], trigger_second[1]+(int(coef-1.2)*pw)] == 0 and binScreen[trigger_feather[0], trigger_feather[1]+(int(coef-1.2)*pw)] == 0:
  112. print('taking')
  113. gui.keyUp('space')
  114. gui.keyDown('down')
  115. jumping = False
  116. taking = True
  117. if taking and binScreen[dino_max_y-ph, dino_max_x] != 0:
  118. print('take off')
  119. gui.keyUp('down')
  120. taking = False
  121. if time() - start2 > 15/coef:
  122. print(coef)
  123. print('speeded')
  124. coef += 0.2
  125. start2 = time()
  126. if time() - start > 15:
  127. print(time() - start)
  128. trigger_second = (trigger_second[0], trigger_second[1]+pw)
  129. trigger_feather = (trigger_feather[0], trigger_feather[1]+pw)
  130. start = time()
  131. if DEBUG:
  132. rgbScreen = binary_to_RGB(binScreen)
  133. cv2.circle(rgbScreen, trigger_feather[::-1], radius=2, color=(255, 0, 0), thickness=2)
  134. cv2.circle(rgbScreen, trigger_second[::-1], radius=2, color=(0, 255, 0), thickness=2)
  135. cv2.imshow('View', rgbScreen)
  136. if cv2.waitKey(1) == ord('q'): break
  137. cv2.destroyAllWindows()