- Load time improvement on music module
This commit is contained in:
parent
eb32e8c8ff
commit
63cf4aec58
|
@ -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)
|
|
@ -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)
|
|
||||||
"""
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue