diff --git a/join_room.py b/join_room.py index d297d7b..141f6db 100644 --- a/join_room.py +++ b/join_room.py @@ -30,6 +30,7 @@ def send_error(message): set_global_variable(window) def send_info(message): + print(message) window = get_global_variable() window.evaluate_js(f"showInfo('{message}');", callback) focus_webview() @@ -61,12 +62,12 @@ def yuzu_ready(): break if not found: - send_error("Yuzu doesn't seem to be launched.") + send_error("Yuzu doesn't seem to be launched.") return False return yuzu_window - def focus_yuzu(): + def focus_yuzu_window(): yuzu_window = yuzu_ready() if yuzu_window != False: try: @@ -74,10 +75,29 @@ def focus_yuzu(): except gw.PyGetWindowException: pass win32gui.ShowWindow(yuzu_window._hWnd, 9) # Restore window if minimized + return True - return False + def focus_yuzu(): + print('1') + if not 'yuzu' in gw.getActiveWindow().title.lower(): + print('2') + windows = gw.getAllWindows() + + for window in windows: + title = window.title.lower() + if "yuzu" in title and not "yuzu 1" in title: + try: + window.activate() # Focus window + except gw.PyGetWindowException: + pass + win32gui.ShowWindow(window._hWnd, 9) # Restore window if minimized + pyautogui.press("esc") + return focus_yuzu_window() + + return True + def focus_webview(): windows = gw.getAllWindows() @@ -103,7 +123,13 @@ def handle_room_failed(ip, port, username, password): answer = messagebox.askyesno("Failed to join the room.", "Retry?") if answer: - macro(ip, port, username, password) + if focus_yuzu() == True: + time.sleep(0.5) + macro(ip, str(port), username, password) + + print("Room joined") + else: + print("Failed to join room") else: send_info( f" Go on Yuzu -> Ctrl+C, and then enter:

Adress: {ip}
Port: {port}
Password: {password}
" @@ -112,6 +138,9 @@ def handle_room_failed(ip, port, username, password): def macro(ip, port, username, password): pyautogui.press("esc") + pyautogui.press("esc") + pyautogui.press("esc") + time.sleep(0.1) pyautogui.hotkey("ctrl", "c") window_rect = pyautogui.getActiveWindow()