- Furhter accleration work in input queue

This commit is contained in:
noisymime 2008-04-04 14:13:47 +00:00
parent 61910fcbe8
commit f9f73c1962
3 changed files with 71 additions and 12 deletions

View File

@ -21,8 +21,14 @@ class InputQueue(gobject.GObject):
}
accelerating = False
acceleration_factor = 10 #Timelines will run at regular speed times this
acceleration_threshold = 5 #The queue size at which accleration kicks in
current_acceleration_factor = 1
acceleration_factor_base = 10 #Timelines will run at regular speed times this when accelerated
acceleration_threshold = 3 #The queue size at which accleration kicks in (Make this higher to increase the delay before acceleration takes place)
acceleration_time = 1000 #Time (in ms) it takes for the queue to accelerate/decelerate from nothing to full
acceleration_steps = 5 #The number of steps in the acceleration process
queue_max_size = 10
release_timeout = 500 #The time (in ms) that the queue waits for key-events before timing out
def __init__(self):
gobject.GObject.__init__(self)
@ -37,16 +43,23 @@ class InputQueue(gobject.GObject):
self.action_south = None
self.action_west = None
gtk.settings_get_default().set_long_property("gtk-timeout-repeat", 5000, "gloss")
self.current_acceleration_step = 0
self.stage = clutter.stage_get_default()
self.poll_time = None
self.release_timeout_id = None
#gtk.settings_get_default().set_long_property("gtk-timeout-repeat", 5000, "gloss")
def set_timeline(self, timeline):
self.timeline = timeline
self.base_fps = self.timeline.get_speed()
if self.accelerating:
fps = self.timeline.get_speed() * self.acceleration_factor
fps = self.timeline.get_speed() * self.current_acceleration_factor
if fps < 1: fps = self.base_fps
self.timeline.set_speed(fps)
self.timeline.connect('completed', self.flush_queue)
def input(self, event):
self.actor = event.source
if not self.timeline.is_playing():
if (event.keyval == clutter.keysyms.Left) and (not self.action_west is None): self.action_west()
if (event.keyval == clutter.keysyms.Right) and (not self.action_east is None): self.action_east()
@ -57,6 +70,12 @@ class InputQueue(gobject.GObject):
self.emit("entering-queue")
#Poll for key release
if self.accelerating:
if not self.release_timeout_id is None:
gobject.source_remove(self.release_timeout_id)
self.release_timeout_id = gobject.timeout_add(self.release_timeout, self.decelerate)
if event.keyval == clutter.keysyms.Left:
self.queue_west += 1
return True
@ -80,6 +99,11 @@ class InputQueue(gobject.GObject):
if (direction == self.WEST): self.action_west = function
def flush_queue(self, data):
if self.queue_north > self.queue_max_size: self.queue_north = self.queue_max_size
if self.queue_east > self.queue_max_size: self.queue_east = self.queue_max_size
if self.queue_south > self.queue_max_size: self.queue_south = self.queue_max_size
if self.queue_west > self.queue_max_size: self.queue_west = self.queue_max_size
#Consolodate north/south, east/west volumes
if self.queue_north > self.queue_south:
self.queue_north = self.queue_north - self.queue_south
@ -99,11 +123,9 @@ class InputQueue(gobject.GObject):
absolute_queue_size = self.queue_north + self.queue_east + self.queue_south + self.queue_west
if absolute_queue_size > self.acceleration_threshold:
self.accelerating = True
else:
self.accelerating = False
print "Queue Size: N=%s E=%s S=%s W=%s" % (self.queue_north, self.queue_east, self.queue_south, self.queue_west)
if not self.accelerating:
self.accelerate()
#print "Queue Size: N=%s E=%s S=%s W=%s" % (self.queue_north, self.queue_east, self.queue_south, self.queue_west)
if self.queue_north > 0:
self.queue_north -= 1
@ -128,8 +150,42 @@ class InputQueue(gobject.GObject):
self.emit("queue-flushed")
def is_in_queue(self):
if (self.queue_north > 0) or (self.queue_south > 0) or (self.queue_east > 0) or (self.queue_west > 0):
return True
else:
return False
def accelerate(self):
self.accelerating = True
if self.current_acceleration_step < self.acceleration_steps:
self.current_acceleration_step +=1
print "accelerating: %s" % str(self.current_acceleration_step)
self.current_acceleration_factor = self.current_acceleration_step * (self.acceleration_factor_base / self.acceleration_steps)
fps = self.base_fps * self.current_acceleration_factor
if fps < 1: fps = self.base_fps
self.timeline.set_speed(fps)
if self.current_acceleration_step == 1: gobject.timeout_add( (self.acceleration_time / self.acceleration_steps), self.accelerate)
return True
print "Acceleration finished"
return False
def decelerate(self, actor = None, event = None):
#print "Key released: %s" % str(gtk.gdk.keyval_name(event.keyval))
if self.current_acceleration_step > 0:
self.current_acceleration_step -= 1
print "decelerating: %s" % str(self.current_acceleration_step)
self.current_acceleration_factor = self.current_acceleration_step * (self.acceleration_factor_base / self.acceleration_steps)
fps = self.base_fps * self.current_acceleration_factor
if fps < 1: fps = self.base_fps
self.timeline.set_speed(fps)
if self.current_acceleration_step == (self.acceleration_steps-1): gobject.timeout_add( (self.acceleration_time / self.acceleration_steps), self.decelerate)
return True
self.accelerating = False
print "Deceleration finished"
return False

View File

@ -2,6 +2,7 @@ import eyeD3
import os
import pygtk
import gtk
import gobject
class song:
filename = None

View File

@ -135,7 +135,9 @@ class Module:
def update_for_albums(self, data, artist = None):
if not artist == self.artistImageRow.get_current_object(): return
if self.backend.handler_is_connected(self.conn_id): self.backend.disconnect(self.conn_id)
if not self.backend.handler_is_connected(self.conn_id):
return
self.backend.disconnect(self.conn_id)
albums = self.backend.get_albums_by_artistID(artist.artistID)
clutter.threads_enter()