Skip to main content

A wrapper for pywinauto that make the ability to control any window with python easily

Project description

PyWinController

Overview

PyWinController is a Python module that provides an interface for interacting with Windows applications using pywinauto. It enables window manipulation, keyboard inputs, and mouse interactions.

Requirements

  • Python 3.x
  • pywinauto
  • pynput (optional)

Installation

pip install pywincontroller

Classes

COORDS

Represents a coordinate with x and y values.

Attributes:

  • x (int): X-coordinate.
  • y (int): Y-coordinate.

RECT

Represents a rectangular area in a window.

Attributes:

  • left, top, right, bottom (int): Define the position and boundaries.
  • width, height (int): Computed if not explicitly set.
  • middle (COORDS): Midpoint of the rectangle.

Methods:

  • width(): Returns the rectangle's width.
  • height(): Returns the rectangle's height.
  • mid_point(): Computes the midpoint coordinates.

WinController

Controls a Windows application window.

Attributes:

  • main_process (str): Path of the main executable.
  • process_name (str): Name of the window process.
  • input_per_sec (int): Amount of inputs per second / refresh rate between 2 actions.
  • actions (dict): Mapping of action names to key bindings.

Methods:

  • update_window(): Updates window dimensions.
  • to_image(): Captures a screenshot.
  • stop(): Stops interactions and the frame update.
  • focus(): Sets focus to the application window.
  • type_keys(keys, ...): Simulates keyboard input.
  • press(button, action): Simulates key press.
  • release(button, action): Releases a key.
  • release_all(): Releases all pressed keys.
  • move_cursor(x, y, key_pressed): Moves the cursor.
  • drag_cursor(x, y, button, key_pressed): Drags the cursor.
  • click(button, double): Clicks the mouse button.
  • press_cursor(button, coords, key_pressed): Presses a mouse button at given coordinates.
  • release_cursor(button, coords, key_pressed): Releases a mouse button at given coordinates.
  • do(actions, buttons): Performs a series of actions.
  • undo(actions, buttons): Reverts performed actions.

Callback / Decorator :

  • on_update(callback): Registers an update callback function.
  • on_input(callback, keyboard: bool = True, mouse: bool = False, core: str = "pywinauto") # core="pynput"

Usage Example

from pywincontroller import WinController, RECT


class MarioBros(WinController):
    def __init__(self, input_per_sec: int = 3):
        WinController.__init__(self, main_process="Mesen", process_name="Mesen - Super Mario Bros. (Europe) (Rev A)", input_per_sec=input_per_sec)

        self.actions: dict = {
            "JUMP": "k",
            "FIRE": "j",

            "START": "i",
            "SELECT": "u",

            "UP": "z",
            "DOWN": "s",
            "LEFT": "q",
            "RIGHT": "d",
        }

    def to_image(self):
        top_crop: int = 120
        return self.main_win.capture_as_image(RECT(left=self.left+10, top=self.top+top_crop, width=self.width-30, height=self.height-top_crop-20))

    def get_timer(self):
        return self.main_win.capture_as_image(RECT(left=self.left+422, top=self.top+101, width=50, height=18))

    def get_score(self):
        return self.main_win.capture_as_image(RECT(left=self.left+52, top=self.top+101, width=102, height=18))

    def get_coins(self):
        return self.main_win.capture_as_image(RECT(left=self.left+212, top=self.top+101, width=38, height=18))



mb = MarioBros(input_per_sec=3)
mb.focus()
iter = 0


@mb.on_update()
async def main():
    global iter

    if iter % 5:
        # to do an action
        mb.do(["JUMP"])

    else:
        # to do nothing
        mb.do("")

    iter += 1

    if iter >= 100:
        mb.stop()

    print(iter)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pywincontroller-1.3.1.tar.gz (9.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pywincontroller-1.3.1-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

File details

Details for the file pywincontroller-1.3.1.tar.gz.

File metadata

  • Download URL: pywincontroller-1.3.1.tar.gz
  • Upload date:
  • Size: 9.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.11

File hashes

Hashes for pywincontroller-1.3.1.tar.gz
Algorithm Hash digest
SHA256 e3c44679455b1a097f7ba1f4d1a208b0bbf8a34c7a67fdd04a29c27e6dcc6a37
MD5 fff578a50556678e4968c41a6bdcf7ad
BLAKE2b-256 de2a1c16901a5b73435dc81cd719ca192395e97046b4870c380b26d8e3b83899

See more details on using hashes here.

File details

Details for the file pywincontroller-1.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for pywincontroller-1.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ec8376912a98a3fb5d9429439fdb5818ca0f68b3bb7f2410f1f3d701d3bad3a7
MD5 40da78cea2f55e55b9059b60a45fce5d
BLAKE2b-256 67aecd1b76d307fe9e4f1a6835c7c819fbb9da95cf186346f33e9ff9c6ba2267

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page