Kaynağa Gözat

Track info: album and artist

9and3r 11 yıl önce
ebeveyn
işleme
1e2df3dba9

+ 19 - 12
mopidy_touchscreen/main_screen.py

@@ -2,6 +2,7 @@ import pygame
 import logging
 import hashlib
 import os
+from threading import Thread
 import urllib
 import urllib2
 import json
@@ -29,22 +30,31 @@ class MainScreen():
         self.background.drawBackground(screen)
         if self.track!=None:
             if self.image is not None:
-                screen.blit(self.image, (0, 0))
+                screen.blit(self.image, ((self.size[0]-self.image.get_rect().width)/2, 0))
             self.touch_text_manager.render(screen)
-
         return screen
 
     def track_started(self, track):
         self.track = track
-        logger.error("hemen nago")
-        self.touch_text_manager.add_text_object(self.track.name,(0,0), self.size, (255.255,255))
+        self.image = None
+        self.touch_text_manager.add_text_object("track_name",self.track.name,(0,0), self.size, (255, 255, 255))
+        self.touch_text_manager.add_text_object("album_name",self.track.album.name,(0,20), self.size, (255, 255, 255))
+        self.touch_text_manager.add_text_object("artist_name",self.getFirstArtist(),(0,40), self.size, (255, 255, 255))
         if not self.is_image_in_cache():
-            self.downloadImage()
+            thread = Thread(target=self.downloadImage())
+            thread.start()
         else:
             self.loadImage()
 
+    def getFirstArtist(self):
+        artist = next(iter(self.track.artists)).name
+        if "," in artist:
+            artist = artist.split(',')[0]
+        return artist
+
+
     def getImageFileName(self):
-        name = self.track.album.name
+        name = self.track.album.name + '-' + self.getFirstArtist()
         md5name = hashlib.md5(name).hexdigest()+".png"
         return md5name
 
@@ -58,20 +68,17 @@ class MainScreen():
         return os.path.isfile(self.cache+self.getCoverFolder()+self.getImageFileName())
 
     def downloadImage(self):
-        self.imageStatus = 0
-        #safe_artist=urllib.quote_plus(self.track.artists)
-        safe_artist='clean+bandit'
+        safe_artist=urllib.quote_plus(self.getFirstArtist())
         safe_album=urllib.quote_plus(self.track.album.name)
         url="http://ws.audioscrobbler.com/2.0/?"
         params="method=album.getinfo&api_key=59a04c6a73fb99d6e8996e01db306829&artist="+safe_artist+"&album="+safe_album+"&format=json"
         response = urllib2.urlopen(url+params)
         data = json.load(response)
-        image = data['album']['image'][2]['#text']
-        logger.error(image)
+        image = data['album']['image'][-1]['#text']
         urllib.urlretrieve(image, self.getCoverFolder()+self.getImageFileName())
         self.loadImage()
 
     def loadImage(self):
-        size = self.size[0]/2 - margin
+        size = self.size[1]
         self.image = pygame.transform.scale(pygame.image.load(self.getCoverFolder()+self.getImageFileName()),(size,size))
 

+ 5 - 2
mopidy_touchscreen/touch_screen.py

@@ -31,7 +31,6 @@ class TouchScreen(pykka.ThreadingActor, core.CoreListener):
     pygame.quit()
 
     def on_start(self):
-        logger.error("hemen nago")
         self.running=True
         thread = Thread(target=self.start_thread)
         thread.start()
@@ -40,5 +39,9 @@ class TouchScreen(pykka.ThreadingActor, core.CoreListener):
         self.running = False
 
     def track_playback_started(self, tl_track):
-        self.screen_manager.track_started(tl_track)
+        try:
+            self.screen_manager.track_started(tl_track)
+        except:
+            traceback.print_exc()
+