mirror of
https://github.com/Febbweiss/mopidy-touchscreen.git
synced 2026-03-05 06:35:43 +00:00
Downloading album cover art
This commit is contained in:
@@ -1,40 +1,77 @@
|
|||||||
import pygame
|
import pygame
|
||||||
import logging
|
import logging
|
||||||
|
import hashlib
|
||||||
|
import os
|
||||||
|
import urllib
|
||||||
|
import urllib2
|
||||||
|
import json
|
||||||
from mopidy.audio import PlaybackState
|
from mopidy.audio import PlaybackState
|
||||||
|
from .touch_text_manager import TouchTextManager
|
||||||
from .dynamic_background import DynamicBackground
|
from .dynamic_background import DynamicBackground
|
||||||
import musicbrainzngs as musicb
|
|
||||||
|
|
||||||
|
|
||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
|
margin = 10
|
||||||
|
|
||||||
|
|
||||||
class MainScreen():
|
class MainScreen():
|
||||||
|
|
||||||
|
def __init__(self,size,manager,cache):
|
||||||
|
self.size = size
|
||||||
|
self.manager = manager
|
||||||
|
self.background = DynamicBackground()
|
||||||
|
self.track = None
|
||||||
|
self.cache = cache
|
||||||
|
self.image = None
|
||||||
|
self.touch_text_manager = TouchTextManager(size)
|
||||||
|
|
||||||
|
def update(self,core):
|
||||||
|
screen = pygame.Surface(self.size)
|
||||||
|
self.background.drawBackground(screen)
|
||||||
|
if self.track!=None:
|
||||||
|
if self.image is not None:
|
||||||
|
screen.blit(self.image, (0, 0))
|
||||||
|
self.touch_text_manager.render(screen)
|
||||||
|
|
||||||
def __init__(self,size,manager):
|
return screen
|
||||||
self.size=size
|
|
||||||
self.manager=manager
|
|
||||||
self.background=DynamicBackground()
|
|
||||||
self.track = None
|
|
||||||
|
|
||||||
def update(self,core):
|
def track_started(self, track):
|
||||||
screen = pygame.Surface(self.size)
|
self.track = track
|
||||||
self.background.drawBackground(screen)
|
logger.error("hemen nago")
|
||||||
text = pygame.font.SysFont("arial",20)
|
self.touch_text_manager.add_text_object(self.track.name,(0,0), self.size, (255.255,255))
|
||||||
if(self.track!=None):
|
if not self.is_image_in_cache():
|
||||||
text_surface=text.render(self.track.album.musicbrainz_id,False,(255,255,255))
|
self.downloadImage()
|
||||||
screen.blit(text_surface,(0,0))
|
else:
|
||||||
#logger.error(self.track.album.musicbrainz_id)
|
self.loadImage()
|
||||||
return screen
|
|
||||||
|
|
||||||
def track_started(self,track):
|
def getImageFileName(self):
|
||||||
self.track=track
|
name = self.track.album.name
|
||||||
self.downloadImage()
|
md5name = hashlib.md5(name).hexdigest()+".png"
|
||||||
|
return md5name
|
||||||
|
|
||||||
def downloadImage(self):
|
def getCoverFolder(self):
|
||||||
logger.error("hemen nago")
|
if(not os.path.isdir(self.cache+"/covers")):
|
||||||
logger.error(musicb.search_releases(artist=self.track.artist.name, limit=1))
|
os.makedirs(self.cache+"/covers")
|
||||||
|
return self.cache+"/covers/"
|
||||||
|
|
||||||
|
def is_image_in_cache(self):
|
||||||
|
self.getCoverFolder()
|
||||||
|
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_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)
|
||||||
|
urllib.urlretrieve(image, self.getCoverFolder()+self.getImageFileName())
|
||||||
|
self.loadImage()
|
||||||
|
|
||||||
|
def loadImage(self):
|
||||||
|
size = self.size[0]/2 - margin
|
||||||
|
self.image = pygame.transform.scale(pygame.image.load(self.getCoverFolder()+self.getImageFileName()),(size,size))
|
||||||
|
|
||||||
|
|||||||
@@ -1,11 +1,16 @@
|
|||||||
from .main_screen import MainScreen
|
from .main_screen import MainScreen
|
||||||
import pygame
|
import pygame
|
||||||
|
import logging
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
class ScreenManager():
|
class ScreenManager():
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def __init__(self,size):
|
def __init__(self,size):
|
||||||
self.screen_size=size
|
self.screen_size=size
|
||||||
self.screens=[MainScreen(size,self)]
|
self.screens=[MainScreen(size,self,"/home/ander")]
|
||||||
self.track=None
|
self.track=None
|
||||||
|
|
||||||
def update(self,core):
|
def update(self,core):
|
||||||
@@ -13,4 +18,5 @@ class ScreenManager():
|
|||||||
|
|
||||||
def track_started(self,track):
|
def track_started(self,track):
|
||||||
self.track=track
|
self.track=track
|
||||||
|
self.screens[0].track_started(track.track)
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import pykka
|
import pykka
|
||||||
|
|
||||||
|
import traceback
|
||||||
import logging
|
import logging
|
||||||
from threading import Thread
|
from threading import Thread
|
||||||
import pygame
|
import pygame
|
||||||
@@ -12,33 +13,32 @@ logger = logging.getLogger(__name__)
|
|||||||
|
|
||||||
class TouchScreen(pykka.ThreadingActor, core.CoreListener):
|
class TouchScreen(pykka.ThreadingActor, core.CoreListener):
|
||||||
def __init__(self, config, core):
|
def __init__(self, config, core):
|
||||||
super(TouchScreen, self).__init__()
|
super(TouchScreen, self).__init__()
|
||||||
self.core = core
|
self.core = core
|
||||||
self.screen_size=(320, 240)
|
self.screen_size=(320, 240)
|
||||||
|
self.screen_manager = ScreenManager(self.screen_size)
|
||||||
|
|
||||||
|
|
||||||
def start_thread(self):
|
def start_thread(self):
|
||||||
self.screen_manager = ScreenManager(self.screen_size)
|
pygame.init()
|
||||||
pygame.init()
|
clock = pygame.time.Clock()
|
||||||
clock = pygame.time.Clock()
|
screen = pygame.display.set_mode(self.screen_size)
|
||||||
screen = pygame.display.set_mode(self.screen_size)
|
while self.running:
|
||||||
while self.running:
|
clock.tick(30)
|
||||||
clock.tick(60)
|
screen.blit(self.screen_manager.update(self.core),(0,0))
|
||||||
screen.blit(self.screen_manager.update(self.core),(0,0))
|
pygame.display.flip()
|
||||||
pygame.display.flip()
|
|
||||||
pygame.quit()
|
|
||||||
|
|
||||||
|
|
||||||
|
pygame.quit()
|
||||||
|
|
||||||
def on_start(self):
|
def on_start(self):
|
||||||
self.running=True
|
logger.error("hemen nago")
|
||||||
thread = Thread(target=self.start_thread)
|
self.running=True
|
||||||
thread.start()
|
thread = Thread(target=self.start_thread)
|
||||||
pass
|
thread.start()
|
||||||
|
|
||||||
def on_stop(self):
|
def on_stop(self):
|
||||||
self.running = False
|
self.running = False
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def track_playback_started(self, tl_track):
|
def track_playback_started(self, tl_track):
|
||||||
self.screen_manager.track_started(tl_track)
|
self.screen_manager.track_started(tl_track)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user