- Load time improvement on music module

This commit is contained in:
noisymime 2008-06-22 11:31:12 +00:00
parent eb32e8c8ff
commit 63cf4aec58
3 changed files with 60 additions and 79 deletions

View File

@ -22,8 +22,8 @@ class MusicObjectRow(ImageRow):
self.sleep = False self.sleep = False
self.objectLibrary = [] self.objectLibrary = []
self.loaded_objects = 0
self.timeline = None self.timeline = None
self.loaded_max = 0
def add_object(self, object): def add_object(self, object):
self.objectLibrary.append(object) self.objectLibrary.append(object)
@ -34,47 +34,46 @@ class MusicObjectRow(ImageRow):
def load_image_range(self, start, end, as_thread = False, thread_data = None): def load_image_range(self, start, end, as_thread = False, thread_data = None):
#External timeline can be set by other objects as a form of 'lock'. If external timeline is running, thread will be paused #External timeline can be set by other objects as a form of 'lock'. If external timeline is running, thread will be paused
self.external_timeline = None self.external_timeline = None
self.buffer = 5
self.emit("load-begin") self.emit("load-begin")
#Do a check so we don't reload anything that's already been done #Do a check so we don't reload anything that's already been done
if start < self.loaded_objects: if start < self.loaded_max:
start = self.loaded_objects start = self.loaded_objects
for i in range(start, end): for i in range(start, end):
object = self.objectLibrary[i] object = self.objectLibrary[i]
print "loading: " + object.name print "loading: " + object.name
if i > (self.num_columns + self.buffer):
pixbuf = object.get_default_image()
else:
pixbuf = object.get_image(size = self.image_size) pixbuf = object.get_image(size = self.image_size)
#If there is currently motion, we need to pause this work
#if self.should_sleep():
# time.sleep(0.1)
#if self.sleep:
#self.timeline.connect('completed', self.restart_cb)
#time.sleep(self.music_player.sleep_time)
self.process_pixbuf(pixbuf, object)
self.loaded_max = (self.num_columns + self.buffer)
self.emit("load-complete")
return False
def process_pixbuf(self, pixbuf, object):
if pixbuf == object.PENDING_DOWNLOAD: if pixbuf == object.PENDING_DOWNLOAD:
#Get the temporary image #Get the temporary image
if as_thread: clutter.threads_enter() #if as_thread: clutter.threads_enter()
pixbuf = object.get_default_image() pixbuf = object.get_default_image()
tmpImage = ImageFrame(pixbuf, self.image_size, use_reflection = True, quality = ImageFrame.QUALITY_FAST) #clutter.Texture() tmpImage = ImageFrame(pixbuf, self.image_size, use_reflection = True, quality = ImageFrame.QUALITY_FAST) #clutter.Texture()
object.connect("image-found", self.set_image_cb, object, tmpImage) object.connect("image-found", self.set_image_cb, object, tmpImage)
if as_thread: clutter.threads_leave() #if as_thread: clutter.threads_leave()
elif not pixbuf is None: elif not pixbuf is None:
#If we're performing this loading as a seperate thread, we need to lock the Clutter threads #If we're performing this loading as a seperate thread, we need to lock the Clutter threads
if as_thread: clutter.threads_enter() #if as_thread: clutter.threads_enter()
tmpImage = ImageFrame(pixbuf, self.image_size, use_reflection=True, quality = ImageFrame.QUALITY_FAST) tmpImage = ImageFrame(pixbuf, self.image_size, use_reflection=True, quality = ImageFrame.QUALITY_FAST)
if as_thread: clutter.threads_leave() #if as_thread: clutter.threads_leave()
else: else:
if as_thread: clutter.threads_enter() #if as_thread: clutter.threads_enter()
pixbuf = object.get_default_image() pixbuf = object.get_default_image()
tmpImage = ImageFrame(pixbuf, self.image_size, use_reflection = True, quality = ImageFrame.QUALITY_FAST) #clutter.Texture() tmpImage = ImageFrame(pixbuf, self.image_size, use_reflection = True, quality = ImageFrame.QUALITY_FAST) #clutter.Texture()
if as_thread: clutter.threads_leave() #if as_thread: clutter.threads_leave()
self.add_texture_group(tmpImage) self.add_texture_group(tmpImage)
self.loaded_objects += 1
self.emit("load-complete")
return False
#print "Finished threads"
#A simple callback funtion to set the image of an artist/album after it has completed a download #A simple callback funtion to set the image of an artist/album after it has completed a download
def set_image_cb(self, data, music_object, tmpImage): def set_image_cb(self, data, music_object, tmpImage):
@ -86,23 +85,25 @@ class MusicObjectRow(ImageRow):
tmpImage.set_pixbuf(pixbuf) tmpImage.set_pixbuf(pixbuf)
clutter.threads_leave() clutter.threads_leave()
def restart_cb(self, data):
self.sleep = True
def should_sleep(self):
ret_val = False
#if self.sleep:
# return True
if not self.external_timeline is None:
if self.external_timeline.is_playing():
ret_val = True
if not self.timeline is None:
if self.timeline.is_playing():
ret_val = True
return ret_val
def get_current_object(self): def get_current_object(self):
return self.objectLibrary[self.currentSelection] return self.objectLibrary[self.currentSelection]
def move_common(self, newItem):
if (newItem + self.buffer) > self.loaded_max:
max_load = newItem + int(self.num_columns / 2 + 1)
for i in range(self.loaded_max, max_load):
object = self.objectLibrary[i]
img_frame = self.textureLibrary[i]
print "loading: " + object.name
pixbuf = object.get_image(size = self.image_size)
if pixbuf == object.PENDING_DOWNLOAD:
#Get the temporary image
pixbuf = object.get_default_image()
object.connect("image-found", self.set_image_cb, object, img_frame)
img_frame.set_pixbuf(pixbuf)
self.loaded_max = max_load
ImageRow.move_common(self, newItem)

View File

@ -57,27 +57,3 @@ class Texture_Reflection (CairoTexture):
(x, y) = origTexture.get_position() (x, y) = origTexture.get_position()
self.set_position(x, y) self.set_position(x, y)
"""
self.set_pixbuf(origTexture.get_pixbuf())
#Rotate the reflection based on any rotations to the master
ang_y = origTexture.get_rotation(clutter.Y_AXIS) #ryang()
self.set_rotation(clutter.Y_AXIS, ang_y[0], (origTexture.get_width()), 0, 0)
ang_x = origTexture.get_rotation(clutter.X_AXIS)
self.set_rotation(clutter.X_AXIS, ang_x[0], 0, (origTexture.get_height()), 0)
#ang_z = origTexture.get_rotation(clutter.Z_AXIS)
#self.set_rotation(clutter.Z_AXIS, ang_z[0], 0, 0, 0)
(w, h) = origTexture.get_size()
self.set_width(w)
self.set_height(h)
#Flip it upside down
self.set_rotation(clutter.X_AXIS, 180, 0, origTexture.get_height(), 0)
self.set_opacity(50)
#Get/Set the location for it
(x, y) = origTexture.get_position()
self.set_position(x, y)
"""

View File

@ -92,12 +92,16 @@ class ImageFrame(clutter.Group):
return return
self.use_reflection = toggle self.use_reflection = toggle
if self.use_reflection:
if not self.reflection is None: if not self.reflection is None:
self.remove(self.reflection) self.remove(self.reflection)
self.reflection = None self.reflection = None
self.reflection = Texture_Reflection(self.main_pic) self.reflection = Texture_Reflection(self.main_pic)
self.add(self.reflection) self.add(self.reflection)
self.reflection.show() self.reflection.show()
else:
self.remove(self.reflection)
self.reflection = None
def get_texture(self): def get_texture(self):
return self.main_pic return self.main_pic