Complete the key logic
This commit is contained in:
parent
0984938f95
commit
c4fbb41bcd
@ -30,6 +30,9 @@ from model.ShellModel import ShellModel
|
|||||||
from sugar.graphics import animator
|
from sugar.graphics import animator
|
||||||
from sugar.graphics import units
|
from sugar.graphics import units
|
||||||
|
|
||||||
|
STATE_SHOWING = 0
|
||||||
|
STATE_HIDING = 1
|
||||||
|
|
||||||
class _Animation(animator.Animation):
|
class _Animation(animator.Animation):
|
||||||
def __init__(self, frame, end):
|
def __init__(self, frame, end):
|
||||||
start = frame.get_current_position()
|
start = frame.get_current_position()
|
||||||
@ -42,18 +45,31 @@ class _Animation(animator.Animation):
|
|||||||
class _KeyListener(object):
|
class _KeyListener(object):
|
||||||
def __init__(self, frame):
|
def __init__(self, frame):
|
||||||
self._frame = frame
|
self._frame = frame
|
||||||
self._frame_active = False
|
self._hide_sid = 0
|
||||||
|
|
||||||
def key_press(self):
|
def key_press(self):
|
||||||
if self._frame_active:
|
if self._frame.get_state() == STATE_SHOWING:
|
||||||
self._frame.hide()
|
self._hide_frame()
|
||||||
self._frame_active = False
|
|
||||||
else:
|
else:
|
||||||
self._frame.show()
|
self._show_frame()
|
||||||
self._frame_active = True
|
|
||||||
|
|
||||||
def key_release(self):
|
def key_release(self):
|
||||||
pass
|
self._hide_frame()
|
||||||
|
|
||||||
|
def _hide_frame_timeout_cb(self):
|
||||||
|
self._frame.hide()
|
||||||
|
return False
|
||||||
|
|
||||||
|
def _show_frame(self):
|
||||||
|
if self._hide_sid != 0:
|
||||||
|
gobject.source_remove(self._hide_sid)
|
||||||
|
self._frame.show()
|
||||||
|
|
||||||
|
def _hide_frame(self):
|
||||||
|
if self._hide_sid != 0:
|
||||||
|
gobject.source_remove(self._hide_sid)
|
||||||
|
self._hide_sid = gobject.timeout_add(
|
||||||
|
100, self._hide_frame_timeout_cb)
|
||||||
|
|
||||||
class Frame(object):
|
class Frame(object):
|
||||||
def __init__(self, shell):
|
def __init__(self, shell):
|
||||||
@ -64,6 +80,7 @@ class Frame(object):
|
|||||||
|
|
||||||
self._shell = shell
|
self._shell = shell
|
||||||
self._current_position = 0.0
|
self._current_position = 0.0
|
||||||
|
self._state = STATE_HIDING
|
||||||
|
|
||||||
self._event_frame = EventFrame()
|
self._event_frame = EventFrame()
|
||||||
self._event_frame.connect('enter-edge', self._enter_edge_cb)
|
self._event_frame.connect('enter-edge', self._enter_edge_cb)
|
||||||
@ -90,15 +107,15 @@ class Frame(object):
|
|||||||
|
|
||||||
self._key_listener = _KeyListener(self)
|
self._key_listener = _KeyListener(self)
|
||||||
|
|
||||||
def is_visible(self):
|
|
||||||
return self._top_panel.props.visible
|
|
||||||
|
|
||||||
def get_popup_context(self):
|
def get_popup_context(self):
|
||||||
return self._popup_context
|
return self._popup_context
|
||||||
|
|
||||||
def get_current_position(self):
|
def get_current_position(self):
|
||||||
return self._current_position
|
return self._current_position
|
||||||
|
|
||||||
|
def get_state(self):
|
||||||
|
return self._state
|
||||||
|
|
||||||
def move(self, pos):
|
def move(self, pos):
|
||||||
self._current_position = pos
|
self._current_position = pos
|
||||||
self._update_position()
|
self._update_position()
|
||||||
@ -187,15 +204,25 @@ class Frame(object):
|
|||||||
screen_w - units.grid_to_pixels(1), 0)
|
screen_w - units.grid_to_pixels(1), 0)
|
||||||
|
|
||||||
def hide(self):
|
def hide(self):
|
||||||
|
if self._state == STATE_HIDING:
|
||||||
|
return
|
||||||
|
|
||||||
anim = animator.Animator(0.5, 30, animator.EASE_OUT_EXPO)
|
anim = animator.Animator(0.5, 30, animator.EASE_OUT_EXPO)
|
||||||
anim.add(_Animation(self, 0.0))
|
anim.add(_Animation(self, 0.0))
|
||||||
anim.start()
|
anim.start()
|
||||||
|
|
||||||
|
self._state = STATE_HIDING
|
||||||
|
|
||||||
def show(self):
|
def show(self):
|
||||||
|
if self._state == STATE_SHOWING:
|
||||||
|
return
|
||||||
|
|
||||||
anim = animator.Animator(0.5, 30, animator.EASE_OUT_EXPO)
|
anim = animator.Animator(0.5, 30, animator.EASE_OUT_EXPO)
|
||||||
anim.add(_Animation(self, 1.0))
|
anim.add(_Animation(self, 1.0))
|
||||||
anim.start()
|
anim.start()
|
||||||
|
|
||||||
|
self._state = STATE_SHOWING
|
||||||
|
|
||||||
def _size_changed_cb(self, screen):
|
def _size_changed_cb(self, screen):
|
||||||
self._update_position()
|
self._update_position()
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user