You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
98 lines
2.5 KiB
98 lines
2.5 KiB
# coding=utf-8
|
|
# pynput
|
|
# Copyright (C) 2015-2022 Moses Palmér
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify it under
|
|
# the terms of the GNU Lesser General Public License as published by the Free
|
|
# Software Foundation, either version 3 of the License, or (at your option) any
|
|
# later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful, but WITHOUT
|
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
|
|
# details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
"""
|
|
The module containing mouse classes.
|
|
|
|
See the documentation for more information.
|
|
"""
|
|
|
|
# pylint: disable=C0103
|
|
# Button, Controller and Listener are not constants
|
|
|
|
from pynput._util import backend, Events
|
|
|
|
|
|
backend = backend(__name__)
|
|
Button = backend.Button
|
|
Controller = backend.Controller
|
|
Listener = backend.Listener
|
|
del backend
|
|
|
|
|
|
class Events(Events):
|
|
"""A mouse event listener supporting synchronous iteration over the events.
|
|
|
|
Possible events are:
|
|
|
|
:class:`Events.Move`
|
|
The mouse was moved.
|
|
|
|
:class:`Events.Click`
|
|
A mouse button was pressed or released.
|
|
|
|
:class:`Events.Scroll`
|
|
The device was scrolled.
|
|
"""
|
|
_Listener = Listener
|
|
|
|
class Move(Events.Event):
|
|
"""A move event.
|
|
"""
|
|
def __init__(self, x, y):
|
|
#: The X screen coordinate.
|
|
self.x = x
|
|
|
|
#: The Y screen coordinate.
|
|
self.y = y
|
|
|
|
class Click(Events.Event):
|
|
"""A click event.
|
|
"""
|
|
def __init__(self, x, y, button, pressed):
|
|
#: The X screen coordinate.
|
|
self.x = x
|
|
|
|
#: The Y screen coordinate.
|
|
self.y = y
|
|
|
|
#: The button.
|
|
self.button = button
|
|
|
|
#: Whether the button was pressed.
|
|
self.pressed = pressed
|
|
|
|
class Scroll(Events.Event):
|
|
"""A scroll event.
|
|
"""
|
|
def __init__(self, x, y, dx, dy):
|
|
#: The X screen coordinate.
|
|
self.x = x
|
|
|
|
#: The Y screen coordinate.
|
|
self.y = y
|
|
|
|
#: The number of horisontal steps.
|
|
self.dx = dx
|
|
|
|
#: The number of vertical steps.
|
|
self.dy = dy
|
|
|
|
def __init__(self):
|
|
super(Events, self).__init__(
|
|
on_move=self.Move,
|
|
on_click=self.Click,
|
|
on_scroll=self.Scroll)
|
|
|