main.py 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  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. 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*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. if DEBUG: cv2.imshow('View', rgbScreen)
  102. while True:
  103. binScreen = take_binaryScreenshot(sct, playing_bbox)
  104. binScreen = to_bbox(binScreen)
  105. labels, labeledScreen = cv2.connectedComponents(binScreen.astype('uint8'))
  106. if not jumping and binScreen[trigger_second] != 0 or binScreen[trigger_feather] != 0:
  107. print('jumping')
  108. gui.keyDown('space')
  109. jumping = True
  110. 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:
  111. print('taking')
  112. gui.keyUp('space')
  113. gui.keyDown('down')
  114. jumping = False
  115. taking = True
  116. if taking and binScreen[dino_max_y-ph, dino_max_x] != 0:
  117. print('take off')
  118. gui.keyUp('down')
  119. taking = False
  120. if time() - start > 15:
  121. print(time() - start)
  122. coef += 0.1
  123. trigger_second = (trigger_second[0], trigger_second[1]+pw)
  124. trigger_feather = (trigger_feather[0], trigger_feather[1]+pw)
  125. start = time()
  126. if DEBUG:
  127. rgbScreen = binary_to_RGB(binScreen)
  128. cv2.circle(rgbScreen, trigger_feather[::-1], radius=2, color=(255, 0, 0), thickness=2)
  129. cv2.circle(rgbScreen, trigger_second[::-1], radius=2, color=(0, 255, 0), thickness=2)
  130. cv2.imshow('View', rgbScreen)
  131. if cv2.waitKey(1) == ord('q'): break
  132. cv2.destroyAllWindows()