Added longpress (mouse right button)

This commit is contained in:
9and3r
2014-07-31 20:59:31 +02:00
parent 31b5862c63
commit 91d1e94a5e
4 changed files with 91 additions and 68 deletions

View File

@@ -1,8 +1,10 @@
from .list_view import ListView
import logging
import mopidy.models
logger = logging.getLogger(__name__)
class LibraryScreen():
def __init__(self, size, base_size, manager):
@@ -11,14 +13,19 @@ class LibraryScreen():
self.manager = manager
self.list_view = ListView((0,self.base_size),(self.size[0],self.size[1]-2*self.base_size), self.base_size, manager.fonts)
self.directory_list = []
self.current_directory = None
self.library = None
self.library_strings = None
self.lookup_uri(None)
def go_inside_directory(self, uri):
self.directory_list.append(self.current_directory)
self.current_directory = uri
self.lookup_uri(uri)
def lookup_uri(self, uri):
self.library_strings = []
if uri is not None:
self.directory_list.append(uri)
self.library_strings.append("..")
self.library = self.manager.core.library.browse(uri).get()
for lib in self.library:
@@ -26,10 +33,10 @@ class LibraryScreen():
self.list_view.set_list(self.library_strings)
def go_up_directory(self):
if len(self.directory_list) > 0:
self.lookup_uri(self.directory_list.pop())
else:
self.lookup_uri(None)
if len(self.directory_list):
directory = self.directory_list.pop()
self.current_directory = directory
self.lookup_uri(directory)
def update(self, screen):
self.list_view.render(screen)
@@ -37,10 +44,21 @@ class LibraryScreen():
def touch_event(self, touch_event):
clicked = self.list_view.touch_event(touch_event)
if clicked is not None:
if len(self.directory_list) > 0:
if self.current_directory is not None:
if clicked == 0:
self.go_up_directory()
else:
self.lookup_uri(self.library[clicked-1].uri)
if self.library[clicked-1].type == mopidy.models.Ref.TRACK:
self.play_uri(self.library[clicked-1].uri)
else:
self.go_inside_directory(self.library[clicked-1].uri)
else:
self.lookup_uri(self.library[clicked].uri)
if self.library[clicked].type == mopidy.models.Track:
self.play_uri(self.library[clicked].uri)
else:
self.go_inside_directory(self.library[clicked].uri)
def play_uri(self, uri):
self.manager.core.tracklist.clear()
self.manager.core.tracklist.add(uri=uri)
self.manager.core.playback.play()