Подтвердить что ты не робот

Обнаружение щелчков мыши в окнах с использованием python

Как я могу обнаружить щелчки мыши независимо от того, в каком окне находится мышь?

Perferabliy в python, но если кто-то может объяснить это в любом langauge, я мог бы понять это.

Я нашел это на сайте microsoft: http://msdn.microsoft.com/en-us/library/ms645533(VS.85).aspx

Но я не вижу, как я могу обнаружить или получить перечисленные уведомления.

Пробовал использовать pygame pygame.mouse.get_pos() следующим образом:

import pygame
pygame.init()
while True:
    print pygame.mouse.get_pos()

Это просто возвращает 0,0. Я не знаком с pygame, что-то не хватает?

В любом случае я бы предпочел метод без необходимости установки стороннего модуля. (кроме pywin32 http://sourceforge.net/projects/pywin32/)

4b9b3361

Ответ 1

Единственный способ обнаружить события мыши вне вашей программы - установить крюк Windows с помощью SetWindowsHookEx. Модуль pyHook инкапсулирует подробные детали. Здесь образец, который будет печатать местоположение каждого щелчка мыши:

import pyHook
import pythoncom

def onclick(event):
    print event.Position
    return True

hm = pyHook.HookManager()
hm.SubscribeMouseAllButtonsDown(onclick)
hm.HookMouse()
pythoncom.PumpMessages()
hm.UnhookMouse()

Вы можете проверить example.py script, который установлен с модулем для получения дополнительной информации о параметре event.

pyHook может быть сложно использовать в чистом Python script, потому что для него требуется активный насос сообщений. Из учебника :

Любое приложение, которое желает получить уведомления о глобальных событиях ввода должен иметь насос сообщений Windows. Самый простой способ получить один из них - используйте метод PumpMessages в Пакет расширений Win32 для Python. [...] При запуске эта программа просто сидит простаивает и ждет событий Windows. Если вы используете инструментарий GUI (например, wxPython), этот цикл не нужен поскольку набор инструментов предоставляет свои собственные.

Ответ 2

Я использую win32api. Он работает при нажатии на любое окно.

# Code to check if left or right mouse buttons were pressed
import win32api
import time

state_left = win32api.GetKeyState(0x01)  # Left button down = 0 or 1. Button up = -127 or -128
state_right = win32api.GetKeyState(0x02)  # Right button down = 0 or 1. Button up = -127 or -128

while True:
    a = win32api.GetKeyState(0x01)
    b = win32api.GetKeyState(0x02)

    if a != state_left:  # Button state changed
        state_left = a
        print(a)
        if a < 0:
            print('Left Button Pressed')
        else:
            print('Left Button Released')

    if b != state_right:  # Button state changed
        state_right = b
        print(b)
        if b < 0:
            print('Right Button Pressed')
        else:
            print('Right Button Released')
    time.sleep(0.001)

Ответ 3

Windows MFC, включая графическое программирование, доступна с помощью python с помощью расширений Python для Windows от Марка Хэммонда. Отрывок из книги О'Рейли от Хаммонда и Робинсона book показывает, как подключить сообщения мыши,.eg:

self.HookMessage(self.OnMouseMove,win32con.WM_MOUSEMOVE)

Raw MFC нелегко или очевидно, но поиск в Интернете для примеров python может привести к некоторым полезным примерам.

Ответ 4

Способ работы с окнами - обрабатывать сообщение WM_LBUTTONDBLCLK.

Чтобы это послать, ваш класс окна должен быть создан с помощью стиля CS_DBLCLKS.

Я боюсь, что не знаю, как применить это в Python, но, надеюсь, он может дать вам несколько советов.

Ответ 5

Это была жаркая минута, так как этот вопрос задавали, но я решил поделиться своим решением: я просто использовал встроенный модуль ctypes. (Я использую Python 3.3 btw)

import ctypes
import time

def DetectClick(button, watchtime = 5):
    '''Waits watchtime seconds. Returns True on click, False otherwise'''
    if button in (1, '1', 'l', 'L', 'left', 'Left', 'LEFT'):
        bnum = 0x01
    elif button in (2, '2', 'r', 'R', 'right', 'Right', 'RIGHT'):
        bnum = 0x02

    start = time.time()
    while 1:
        if ctypes.windll.user32.GetKeyState(bnum) not in [0, 1]:
            # ^ this returns either 0 or 1 when button is not being held down
            return True
        elif time.time() - start >= watchtime:
            break
        time.sleep(0.001)
    return False