本文整理匯總了Python中Xlib.X.KeyPress方法的典型用法代碼示例。如果您正苦於以下問題:Python X.KeyPress方法的具體用法?Python X.KeyPress怎麽用?Python X.KeyPress使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Xlib.X
的用法示例。
在下文中一共展示了X.KeyPress方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: listen
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def listen(self):
self.grab()
while True:
evt = self.disp.next_event()
if evt.type in [X.KeyPress, X.KeyRelease]:
keycode = evt.detail
keysym = self.disp.keycode_to_keysym(keycode, 0)
char = XK.keysym_to_string(keysym)
self.disp.allow_events(X.ReplayKeyboard, X.CurrentTime)
self.mode(self, evt, char)
if evt.type == X.DestroyNotify:
if evt.window.id == self.id:
self.ungrab()
return
示例2: normal_mode
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def normal_mode(self, event, char):
events.append(event)
if event.type == X.KeyPress and char:
pressed.add(event_to_string(self, event))
return
if event.type != X.KeyRelease:
return
handled = False
if len(pressed) > 1:
paste_style(self, pressed)
handled = True
elif len(pressed) == 1:
# Get the only element in pressed
ev = next(iter(pressed))
handled = handle_single_key(self, ev)
# replay events to Inkscape if we couldn't handle them
if not handled:
replay(self)
events.clear()
pressed.clear()
示例3: __init__
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def __init__(self):
threading.Thread.__init__(self)
self.finished = threading.Event()
# Give these some initial values
self.mouse_position_x = 0
self.mouse_position_y = 0
self.ison = {"shift":False, "caps":False}
# Compile our regex statements.
self.isshift = re.compile('^Shift')
self.iscaps = re.compile('^Caps_Lock')
self.shiftablechar = re.compile('^[a-z0-9]$|^minus$|^equal$|^bracketleft$|^bracketright$|^semicolon$|^backslash$|^apostrophe$|^comma$|^period$|^slash$|^grave$')
self.logrelease = re.compile('.*')
self.isspace = re.compile('^space$')
# Assign default function actions (do nothing).
self.KeyDown = lambda x: True
self.KeyUp = lambda x: True
self.MouseAllButtonsDown = lambda x: True
self.MouseAllButtonsUp = lambda x: True
self.contextEventMask = [X.KeyPress,X.MotionNotify]
# Hook to our display.
self.local_dpy = display.Display()
self.record_dpy = display.Display()
示例4: makekeyhookevent
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def makekeyhookevent(self, keysym, event):
storewm = self.xwindowinfo()
if event.type == X.KeyPress:
MessageName = "key down"
elif event.type == X.KeyRelease:
MessageName = "key up"
return pyxhookkeyevent(
storewm["handle"],
storewm["name"],
storewm["class"],
self.lookup_keysym(keysym),
self.asciivalue(keysym),
False,
event.detail,
MessageName
)
示例5: __sendKeyPressEvent
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def __sendKeyPressEvent(self, keyCode, modifiers, theWindow=None):
if theWindow is None:
focus = self.localDisplay.get_input_focus().focus
else:
focus = theWindow
keyEvent = event.KeyPress(
detail=keyCode,
time=X.CurrentTime,
root=self.rootWindow,
window=focus,
child=X.NONE,
root_x=1,
root_y=1,
event_x=1,
event_y=1,
state=modifiers,
same_screen=1
)
focus.send_event(keyEvent)
示例6: run
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def run(self):
# Create a recording context; we only want key and mouse events
self.ctx = self.recordDisplay.record_create_context(
0,
[record.AllClients],
[{
'core_requests': (0, 0),
'core_replies': (0, 0),
'ext_requests': (0, 0, 0, 0),
'ext_replies': (0, 0, 0, 0),
'delivered_events': (0, 0),
'device_events': (X.KeyPress, X.ButtonPress), #X.KeyRelease,
'errors': (0, 0),
'client_started': False,
'client_died': False,
}])
# Enable the context; this only returns after a call to record_disable_context,
# while calling the callback function in the meantime
logger.info("XRecord interface thread starting")
self.recordDisplay.record_enable_context(self.ctx, self.__processEvent)
# Finally free the context
self.recordDisplay.record_free_context(self.ctx)
self.recordDisplay.close()
示例7: __processEvent
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def __processEvent(self, reply):
if reply.category != record.FromServer:
return
if reply.client_swapped:
return
if not len(reply.data) or str_or_bytes_to_bytes(reply.data)[0] < 2:
# not an event
return
data = reply.data
while len(data):
event, data = rq.EventField(None).parse_binary_value(data, self.recordDisplay.display, None, None)
if event.type == X.KeyPress:
self.handle_keypress(event.detail)
elif event.type == X.KeyRelease:
self.handle_keyrelease(event.detail)
elif event.type == X.ButtonPress:
self.handle_mouseclick(event.detail, event.root_x, event.root_y)
示例8: handle_event
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def handle_event(self, event):
# KeyPress event
if event.type == X.KeyPress:
keyname = xrobot.get_keyname(event)
self.keyPressed.emit(keyname)
# KeyRelease event
elif event.type == X.KeyRelease:
keyname = xrobot.get_keyname(event)
self.keyReleased.emit(keyname)
# ButtonPress event
elif event.type == X.ButtonPress:
self.buttonPressed.emit(event.root_x, event.root_y, event.time)
# ButtonRelease event
elif event.type == X.ButtonRelease:
self.buttonReleased.emit(event.root_x, event.root_y, event.time)
# MotionNotify event
elif event.type == X.MotionNotify:
self.cursorPositionChanged.emit(event.root_x, event.root_y)
示例9: press
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def press(self, key, mask=X.NONE):
keycode = self.string_to_keycode(key)
self.inkscape.send_event(self.event(event.KeyPress, keycode, mask), propagate=True)
self.inkscape.send_event(self.event(event.KeyRelease, keycode, mask), propagate=True)
self.disp.flush()
self.disp.sync()
示例10: _check_event
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def _check_event(self, source, condition, handle=None):
""" Check keyboard event has all the right buttons pressed. """
handle = handle or self.root.display
for _ in range(0, handle.pending_events()):
event = handle.next_event()
if event.type == X.KeyPress:
command = self.keys[event.detail]
self._handle_event(command)
return True
示例11: key_down
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def key_down(self, key):
"""Performs a keyboard key press without the release. This will put that key in a held down state.
:param key: The key to be pressed down. The valid names are listed in Key class
:return: None.
"""
if isinstance(key, Key) or isinstance(key, KeyModifier):
key = key.value.x11key
if self.keyboard_mapping(key) is None:
return
if isinstance(key, int):
fake_input(self.display, X.KeyPress, key)
self.display.sync()
return
needs_shift = is_shift_character(key)
if needs_shift:
fake_input(self.display, X.KeyPress, self.keyboard_mapping("shift"))
fake_input(self.display, X.KeyPress, self.keyboard_mapping(key))
if needs_shift:
fake_input(self.display, X.KeyRelease, self.keyboard_mapping("shift"))
self.display.sync()
示例12: run
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def run(self):
# Check if the extension is present
if not self.record_dpy.has_extension("RECORD"):
print ("RECORD extension not found")
sys.exit(1)
r = self.record_dpy.record_get_version(0, 0)
print ("RECORD extension version %d.%d" % (r.major_version, r.minor_version))
# Create a recording context; we only want key and mouse events
self.ctx = self.record_dpy.record_create_context(
0,
[record.AllClients],
[{
'core_requests': (0, 0),
'core_replies': (0, 0),
'ext_requests': (0, 0, 0, 0),
'ext_replies': (0, 0, 0, 0),
'delivered_events': (0, 0),
'device_events': tuple(self.contextEventMask), #(X.KeyPress, X.ButtonPress),
'errors': (0, 0),
'client_started': False,
'client_died': False,
}])
# Enable the context; this only returns after a call to record_disable_context,
# while calling the callback function in the meantime
self.record_dpy.record_enable_context(self.ctx, self.processevents)
# Finally free the context
self.record_dpy.record_free_context(self.ctx)
示例13: HookKeyboard
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def HookKeyboard(self):
pass
# We don't need to do anything here anymore, since the default mask
# is now set to contain X.KeyPress
#self.contextEventMask[0] = X.KeyPress
示例14: processevents
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def processevents(self, reply):
if reply.category != record.FromServer:
return
if reply.client_swapped:
print ("* received swapped protocol data, cowardly ignored")
return
if not len(reply.data) or reply.data[0] < 2:
# not an event
return
data = reply.data
while len(data):
event, data = rq.EventField(None).parse_binary_value(data, self.record_dpy.display, None, None)
if event.type == X.KeyPress:
hookevent = self.keypressevent(event)
self.KeyDown(hookevent)
elif event.type == X.KeyRelease:
hookevent = self.keyreleaseevent(event)
self.KeyUp(hookevent)
elif event.type == X.ButtonPress:
hookevent = self.buttonpressevent(event)
self.MouseAllButtonsDown(hookevent)
elif event.type == X.ButtonRelease:
hookevent = self.buttonreleaseevent(event)
self.MouseAllButtonsUp(hookevent)
elif event.type == X.MotionNotify:
# use mouse moves to record mouse position, since press and release events
# do not give mouse position info (event.root_x and event.root_y have
# bogus info).
self.mousemoveevent(event)
#print "processing events...", event.type
示例15: makekeyhookevent
# 需要導入模塊: from Xlib import X [as 別名]
# 或者: from Xlib.X import KeyPress [as 別名]
def makekeyhookevent(self, keysym, event):
storewm = self.xwindowinfo()
if event.type == X.KeyPress:
MessageName = "key down"
elif event.type == X.KeyRelease:
MessageName = "key up"
return pyxhookkeyevent(storewm["handle"], storewm["name"], storewm["class"], self.lookup_keysym(keysym), self.asciivalue(keysym), False, event.detail, MessageName)