本文整理汇总了Python中urwid.ListBox.keypress方法的典型用法代码示例。如果您正苦于以下问题:Python ListBox.keypress方法的具体用法?Python ListBox.keypress怎么用?Python ListBox.keypress使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类urwid.ListBox
的用法示例。
在下文中一共展示了ListBox.keypress方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: keypress
# 需要导入模块: from urwid import ListBox [as 别名]
# 或者: from urwid.ListBox import keypress [as 别名]
def keypress(self, size, key):
key = self.body.keypress(size, key)
if key == 'home':
pos = self.body.get_home()
if pos:
self.change_focus(size, pos, coming_from='below')
elif key == 'end':
pos = self.body.get_end()
if pos:
self.change_focus(size, pos, coming_from='above')
elif key:
return ListBox.keypress(self, size, key)
示例2: TreeBox
# 需要导入模块: from urwid import ListBox [as 别名]
# 或者: from urwid.ListBox import keypress [as 别名]
class TreeBox(WidgetWrap):
"""
A widget representing something in a nested tree display.
This is essentially a ListBox with the ability to move the focus based on
directions in the Tree.
TreeBox interprets `left/right` as well as page `up/down` to move the focus
to parent/first child and next/previous sibling respectively. All other
keys are passed to the underlying ListBox.
"""
_selectable = True
def __init__(self, walker, **kwargs):
"""
:param walker: tree of widgets to be displayed.
In case we are given a raw `TreeWalker`, it will be used though
`TreeListWalker` which means no decoration.
:type walker: TreeWalker or TreeListWalker
"""
if not isinstance(walker, TreeListWalker):
walker = TreeListWalker(walker)
self._walker = walker
self._outer_list = ListBox(walker)
self.__super.__init__(self._outer_list)
# Widget API
def get_focus(self):
return self._outer_list.get_focus()
def keypress(self, size, key):
key = self._outer_list.keypress(size, key)
if key in ['left', 'right', '[', ']', '-', '+', 'C', 'E']:
if key == 'left':
self.focus_parent()
elif key == 'right':
self.focus_first_child()
elif key == '[':
self.focus_prev_sibling()
elif key == ']':
self.focus_next_sibling()
if isinstance(self._walker, CollapseMixin):
if key == '-':
w, focuspos = self._walker.get_focus()
self._walker.collapse(focuspos)
elif key == '+':
w, focuspos = self._walker.get_focus()
self._walker.expand(focuspos)
elif key == 'C':
self._walker.collapse_all()
elif key == 'E':
self._walker.expand_all()
# This is a hack around ListBox misbehaving:
# it seems impossible to set the focus without calling keypress as
# otherwise the change becomes visible only after the next render()
return self._outer_list.keypress(size, None)
else:
return self._outer_list.keypress(size, key)
# Tree based focus movement
def focus_parent(self):
w, focuspos = self._walker.get_focus()
parent = self._walker.parent_position(focuspos)
if parent is not None:
self._outer_list.set_focus(parent)
def focus_first_child(self):
w, focuspos = self._walker.get_focus()
child = self._walker.first_child_position(focuspos)
if child is not None:
self._outer_list.set_focus(child)
def focus_next_sibling(self):
w, focuspos = self._walker.get_focus()
sib = self._walker.next_sibling_position(focuspos)
if sib is not None:
self._outer_list.set_focus(sib)
def focus_prev_sibling(self):
w, focuspos = self._walker.get_focus()
sib = self._walker.prev_sibling_position(focuspos)
if sib is not None:
self._outer_list.set_focus(sib)
示例3: TreeBox
# 需要导入模块: from urwid import ListBox [as 别名]
# 或者: from urwid.ListBox import keypress [as 别名]
class TreeBox(WidgetWrap):
"""
A widget that displays a given :class:`Tree`.
This is essentially a :class:`ListBox` with the ability to move the focus
based on directions in the Tree and to collapse/expand subtrees if
possible.
TreeBox interprets `left/right` as well as `page up/`page down` to move the
focus to parent/first child and next/previous sibling respectively. All
other keys are passed to the underlying ListBox.
"""
def __init__(self, tree, focus=None):
"""
:param tree: tree of widgets to be displayed.
:type tree: Tree
:param focus: initially focussed position
"""
self._tree = tree
self._walker = TreeListWalker(tree)
self._outer_list = ListBox(self._walker)
if focus is not None:
self._outer_list.set_focus(focus)
self.__super.__init__(self._outer_list)
# Widget API
def get_focus(self):
return self._outer_list.get_focus()
def set_focus(self, pos):
return self._outer_list.set_focus(pos)
def refresh(self):
self._walker.clear_cache()
signals.emit_signal(self._walker, "modified")
def keypress(self, size, key):
key = self._outer_list.keypress(size, key)
if key in ["left", "right", "[", "]", "-", "+", "C", "E"]:
if key == "left":
self.focus_parent()
elif key == "right":
self.focus_first_child()
elif key == "[":
self.focus_prev_sibling()
elif key == "]":
self.focus_next_sibling()
elif key == "-":
self.collapse_focussed()
elif key == "+":
self.expand_focussed()
elif key == "C":
self.collapse_all()
elif key == "E":
self.expand_all()
# This is a hack around ListBox misbehaving:
# it seems impossible to set the focus without calling keypress as
# otherwise the change becomes visible only after the next render()
return self._outer_list.keypress(size, None)
else:
return self._outer_list.keypress(size, key)
# Collapse operations
def collapse_focussed(self):
"""
Collapse currently focussed position; works only if the underlying
tree allows it.
"""
if implementsCollapseAPI(self._tree):
w, focuspos = self.get_focus()
self._tree.collapse(focuspos)
self._walker.clear_cache()
self.refresh()
def expand_focussed(self):
"""
Expand currently focussed position; works only if the underlying
tree allows it.
"""
if implementsCollapseAPI(self._tree):
w, focuspos = self.get_focus()
self._tree.expand(focuspos)
self._walker.clear_cache()
self.refresh()
def collapse_all(self):
"""
Collapse all positions; works only if the underlying tree allows it.
"""
if implementsCollapseAPI(self._tree):
self._tree.collapse_all()
self.set_focus(self._tree.root)
self._walker.clear_cache()
self.refresh()
def expand_all(self):
"""
Expand all positions; works only if the underlying tree allows it.
"""
if implementsCollapseAPI(self._tree):
#.........这里部分代码省略.........