mirror of
https://github.com/Febbweiss/mopidy-touchscreen.git
synced 2026-03-04 22:25:39 +00:00
Code cleanup
This commit is contained in:
@@ -3,11 +3,12 @@ from __future__ import unicode_literals
|
||||
import logging
|
||||
import os
|
||||
|
||||
|
||||
from mopidy import config, ext
|
||||
|
||||
from .touch_screen import TouchScreen
|
||||
from .touch_screen_backend import TouchScreenBackend
|
||||
|
||||
|
||||
__version__ = '0.1.0'
|
||||
|
||||
# TODO: If you need to log, use loggers named after the current Python module
|
||||
@@ -15,7 +16,6 @@ logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class Extension(ext.Extension):
|
||||
|
||||
dist_name = 'Mopidy-Touchscreen'
|
||||
ext_name = 'touchscreen'
|
||||
version = __version__
|
||||
@@ -35,4 +35,6 @@ class Extension(ext.Extension):
|
||||
|
||||
def setup(self, registry):
|
||||
registry.add('frontend', TouchScreen)
|
||||
|
||||
#Backend used for controling volume
|
||||
registry.add('backend', TouchScreenBackend)
|
||||
@@ -5,7 +5,6 @@ logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class DynamicBackground():
|
||||
|
||||
def __init__(self):
|
||||
self.current = get_valid_color()
|
||||
self.target = get_valid_color()
|
||||
@@ -23,6 +22,7 @@ class DynamicBackground():
|
||||
self.target = get_valid_color()
|
||||
surface.fill(self.current)
|
||||
|
||||
|
||||
# Returns an array with 3 integers in range of 0-255
|
||||
#The sum of the three integers will be lower than 255*2 (510) to avoid very bright colors
|
||||
#White text should be seen ok with this background color
|
||||
|
||||
@@ -6,13 +6,17 @@
|
||||
<meta name="description" content="An Icon Font Generated By IcoMoon.io">
|
||||
<meta name="viewport" content="width=device-width">
|
||||
<link rel="stylesheet" href="demo-files/demo.css">
|
||||
<link rel="stylesheet" href="style.css"></head>
|
||||
<link rel="stylesheet" href="style.css">
|
||||
</head>
|
||||
<body>
|
||||
<div class="bgc1 clearfix">
|
||||
<h1 class="mhmm mvm"><span class="fgc1">Font Name:</span> icomoon <small class="fgc1">(Glyphs: 42)</small></h1>
|
||||
<h1 class="mhmm mvm"><span class="fgc1">Font Name:</span> icomoon
|
||||
<small class="fgc1">(Glyphs: 42)</small>
|
||||
</h1>
|
||||
</div>
|
||||
<div class="clearfix mhl ptl">
|
||||
<h1 class="mvm mtn bshadow fgc1">Grid Size: 16</h1>
|
||||
|
||||
<div class="glyph fs1">
|
||||
<div class="clearfix bshadow0 pbs">
|
||||
<span class="icon-music"></span><span class="mls"> icon-music</span>
|
||||
|
||||
@@ -1,18 +1,21 @@
|
||||
import logging
|
||||
|
||||
import mopidy.models
|
||||
|
||||
from .list_view import ListView
|
||||
from .touch_manager import TouchManager
|
||||
import logging
|
||||
import mopidy.models
|
||||
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class LibraryScreen():
|
||||
|
||||
def __init__(self, size, base_size, manager):
|
||||
self.size = size
|
||||
self.base_size = base_size
|
||||
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.list_view = ListView((0, self.base_size), (self.size[0], self.size[1] - 2 * self.base_size),
|
||||
self.base_size, manager.fonts['base'])
|
||||
self.directory_list = []
|
||||
self.current_directory = None
|
||||
self.library = None
|
||||
@@ -72,7 +75,8 @@ class LibraryScreen():
|
||||
self.manager.core.tracklist.clear()
|
||||
if track:
|
||||
self.manager.core.tracklist.add(uri=uri)
|
||||
else:
|
||||
logger.error(uri)
|
||||
self.manager.core.tracklist.add(tracks=self.manager.core.library.search(query={'any':'*'}, uris=[uri]).get()[0].tracks)
|
||||
self.manager.core.playback.play()
|
||||
else:
|
||||
#TODO: add folder to tracks to play
|
||||
pass
|
||||
|
||||
|
||||
@@ -1,40 +1,38 @@
|
||||
from .screen_objects import ScreenObjectsManager
|
||||
import logging
|
||||
import pygame
|
||||
from .touch_manager import TouchManager
|
||||
from .touch_manager import TouchEvent
|
||||
from .screen_objects import *
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class ListView():
|
||||
|
||||
def __init__(self, pos, size, base_size, fonts):
|
||||
def __init__(self, pos, size, base_size, font):
|
||||
self.size = size
|
||||
self.pos = pos
|
||||
self.base_size = base_size
|
||||
self.screen_objects = ScreenObjectsManager()
|
||||
self.max_rows = self.size[1] / self.base_size
|
||||
self.current_item = 0
|
||||
self.fonts = fonts
|
||||
self.font = font
|
||||
self.list_size = 0
|
||||
self.list = []
|
||||
self.scrollbar = False
|
||||
self.set_list([])
|
||||
self.selected = []
|
||||
|
||||
#Sets the list for the lisview. It should be an iterable of strings
|
||||
def set_list(self, item_list):
|
||||
self.list = item_list
|
||||
self.list_size = len(item_list)
|
||||
if self.max_rows < self.list_size:
|
||||
self.scrollbar = True
|
||||
scroll_bar = ScrollBar((self.pos[0]+self.size[0]-self.base_size,self.pos[1]), (self.base_size, self.size[1]),self.list_size,self.max_rows)
|
||||
scroll_bar = ScrollBar((self.pos[0] + self.size[0] - self.base_size, self.pos[1]),
|
||||
(self.base_size, self.size[1]), self.list_size, self.max_rows)
|
||||
self.screen_objects.set_touch_object("scrollbar", scroll_bar)
|
||||
else:
|
||||
self.scrollbar = False
|
||||
self.load_new_item_position(0)
|
||||
|
||||
#Will load items currently displaying in item_pos
|
||||
def load_new_item_position(self, item_pos):
|
||||
self.current_item = item_pos
|
||||
if self.scrollbar:
|
||||
@@ -48,7 +46,8 @@ class ListView():
|
||||
else:
|
||||
width = self.size[0]
|
||||
while i < self.list_size and z < self.max_rows:
|
||||
item = TouchAndTextItem(self.fonts['base'], self.list[i], (self.pos[0], self.pos[1]+self.base_size*z), (width, -1))
|
||||
item = TouchAndTextItem(self.font, self.list[i], (self.pos[0], self.pos[1] + self.base_size * z),
|
||||
(width, -1))
|
||||
self.screen_objects.set_touch_object(str(i), item)
|
||||
i += 1
|
||||
z += 1
|
||||
@@ -73,6 +72,9 @@ class ListView():
|
||||
elif touch_event.direction == TouchManager.down:
|
||||
self.move_to(1)
|
||||
|
||||
#Scroll to direction
|
||||
#direction == 1 will scroll down
|
||||
#direction == -1 will scroll up
|
||||
def move_to(self, direction):
|
||||
if self.scrollbar:
|
||||
if direction == 1:
|
||||
@@ -89,6 +91,7 @@ class ListView():
|
||||
self.screen_objects.get_touch_object("scrollbar").set_item(self.current_item)
|
||||
self.set_selected(self.selected)
|
||||
|
||||
#Set selected items
|
||||
def set_selected(self, selected):
|
||||
for number in self.selected:
|
||||
try:
|
||||
|
||||
@@ -5,6 +5,7 @@ from threading import Thread
|
||||
import urllib
|
||||
import urllib2
|
||||
import json
|
||||
|
||||
from .touch_manager import TouchManager
|
||||
from .screen_objects import *
|
||||
|
||||
@@ -34,8 +35,11 @@ class MainScreen():
|
||||
if self.track is not None:
|
||||
if self.image is not None:
|
||||
screen.blit(self.image, (self.base_size / 2, self.base_size + self.base_size / 2))
|
||||
self.touch_text_manager.get_touch_object("time_progress").set_value(self.core.playback.time_position.get() / 1000)
|
||||
self.touch_text_manager.get_touch_object("time_progress").set_text(time.strftime('%M:%S', time.gmtime(self.core.playback.time_position.get() / 1000)) + "/" + time.strftime('%M:%S', time.gmtime(self.track.length / 1000)))
|
||||
self.touch_text_manager.get_touch_object("time_progress").set_value(
|
||||
self.core.playback.time_position.get() / 1000)
|
||||
self.touch_text_manager.get_touch_object("time_progress").set_text(time.strftime('%M:%S', time.gmtime(
|
||||
self.core.playback.time_position.get() / 1000)) + "/" + time.strftime('%M:%S', time.gmtime(
|
||||
self.track.length / 1000)))
|
||||
self.touch_text_manager.render(screen)
|
||||
return screen
|
||||
|
||||
@@ -50,11 +54,13 @@ class MainScreen():
|
||||
self.artists.append(artist)
|
||||
|
||||
# Track name
|
||||
label = TextItem(self.fonts['base'], MainScreen.get_track_name(track), (x, self.base_size * 2), (width, self.size[1]))
|
||||
label = TextItem(self.fonts['base'], MainScreen.get_track_name(track), (x, self.base_size * 2),
|
||||
(width, self.size[1]))
|
||||
self.touch_text_manager.set_object("track_name", label)
|
||||
|
||||
#Album name
|
||||
label = TextItem(self.fonts['base'], MainScreen.get_track_album_name(track), (x, self.base_size * 3), (width, self.size[1]))
|
||||
label = TextItem(self.fonts['base'], MainScreen.get_track_album_name(track), (x, self.base_size * 3),
|
||||
(width, self.size[1]))
|
||||
self.touch_text_manager.set_object("album_name", label)
|
||||
|
||||
#Artist
|
||||
@@ -129,11 +135,13 @@ class MainScreen():
|
||||
# There is no cover so it will use all the screen size for the text
|
||||
width = self.size[0] - self.base_size
|
||||
|
||||
current = TextItem(self.fonts['base'], MainScreen.get_track_name(self.track), (self.base_size / 2, self.base_size * 2),
|
||||
current = TextItem(self.fonts['base'], MainScreen.get_track_name(self.track),
|
||||
(self.base_size / 2, self.base_size * 2),
|
||||
(width, -1))
|
||||
self.touch_text_manager.set_object("track_name", current)
|
||||
|
||||
current = TextItem(self.fonts['base'], MainScreen.get_track_album_name(self.track), (self.base_size / 2, self.base_size * 3),
|
||||
current = TextItem(self.fonts['base'], MainScreen.get_track_album_name(self.track),
|
||||
(self.base_size / 2, self.base_size * 3),
|
||||
(width, -1))
|
||||
self.touch_text_manager.set_object("album_name", current)
|
||||
|
||||
|
||||
@@ -1,12 +1,12 @@
|
||||
from .list_view import ListView
|
||||
from .screen_objects import *
|
||||
import mopidy
|
||||
import os
|
||||
import socket
|
||||
|
||||
import mopidy
|
||||
|
||||
from .screen_objects import *
|
||||
|
||||
|
||||
class MenuScreen():
|
||||
|
||||
def __init__(self, size, base_size, manager):
|
||||
self.size = size
|
||||
self.base_size = base_size
|
||||
@@ -17,19 +17,22 @@ class MenuScreen():
|
||||
# Exit mopidy button
|
||||
button = TouchAndTextItem(self.manager.fonts['icon'], u"\ue611", (0, self.base_size), None)
|
||||
self.screen_objects.set_touch_object("exit_icon", button)
|
||||
button = TouchAndTextItem(self.manager.fonts['base'], "Exit Mopidy", (button.get_right_pos(), self.base_size), None)
|
||||
button = TouchAndTextItem(self.manager.fonts['base'], "Exit Mopidy", (button.get_right_pos(), self.base_size),
|
||||
None)
|
||||
self.screen_objects.set_touch_object("exit", button)
|
||||
|
||||
#Shutdown button
|
||||
button = TouchAndTextItem(self.manager.fonts['icon'], u"\ue60b", (0, self.base_size * 2), None)
|
||||
self.screen_objects.set_touch_object("shutdown_icon", button)
|
||||
button = TouchAndTextItem(self.manager.fonts['base'], "Shutdown", (button.get_right_pos(), self.base_size * 2), None)
|
||||
button = TouchAndTextItem(self.manager.fonts['base'], "Shutdown", (button.get_right_pos(), self.base_size * 2),
|
||||
None)
|
||||
self.screen_objects.set_touch_object("shutdown", button)
|
||||
|
||||
#Restart button
|
||||
button = TouchAndTextItem(self.manager.fonts['icon'], u"\ue609", (0, self.base_size * 3), None)
|
||||
self.screen_objects.set_touch_object("restart_icon", button)
|
||||
button = TouchAndTextItem(self.manager.fonts['base'], "Restart", (button.get_right_pos(), self.base_size * 3), None)
|
||||
button = TouchAndTextItem(self.manager.fonts['base'], "Restart", (button.get_right_pos(), self.base_size * 3),
|
||||
None)
|
||||
self.screen_objects.set_touch_object("restart", button)
|
||||
|
||||
#IP addres
|
||||
@@ -40,7 +43,6 @@ class MenuScreen():
|
||||
#self.list_view.set_list(["Exit mopidy", "Shutdown", "Restart"])
|
||||
|
||||
|
||||
|
||||
def update(self, screen):
|
||||
self.screen_objects.render(screen)
|
||||
# self.list_view.render(screen)
|
||||
@@ -52,10 +54,15 @@ class MenuScreen():
|
||||
if key == "exit_icon" or key == "exit":
|
||||
mopidy.utils.process.exit_process()
|
||||
elif key == "shutdown_icon" or key == "shutdown":
|
||||
if os.system("gksu -- shutdown now -h") != 0:
|
||||
os.system("shutdown now -h")
|
||||
elif key == "restart_icon" or key == "restart":
|
||||
if os.system("gksu -- shutdown -r now") != 0:
|
||||
os.system("shutdown -r now")
|
||||
elif key == "ip":
|
||||
self.check_connection()
|
||||
|
||||
#Will check internet connection
|
||||
def check_connection(self):
|
||||
try:
|
||||
self.manager.set_connection(False, True)
|
||||
|
||||
@@ -2,12 +2,12 @@ from .list_view import ListView
|
||||
|
||||
|
||||
class PlaylistScreen():
|
||||
|
||||
def __init__(self, size, base_size, manager):
|
||||
self.size = size
|
||||
self.base_size = base_size
|
||||
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.list_view = ListView((0, self.base_size), (self.size[0], self.size[1] - 2 * self.base_size),
|
||||
self.base_size, manager.fonts['base'])
|
||||
self.playlists_strings = []
|
||||
self.playlists = []
|
||||
self.playlists_loaded()
|
||||
|
||||
@@ -1,3 +1,10 @@
|
||||
import logging
|
||||
import traceback
|
||||
import os
|
||||
import pygame
|
||||
|
||||
import mopidy
|
||||
|
||||
from .main_screen import MainScreen
|
||||
from .touch_manager import TouchManager
|
||||
from .screen_objects import *
|
||||
@@ -5,12 +12,8 @@ from .tracklist import Tracklist
|
||||
from .playlist_screen import PlaylistScreen
|
||||
from .dynamic_background import DynamicBackground
|
||||
from .library_screen import LibraryScreen
|
||||
import logging
|
||||
import mopidy
|
||||
import traceback
|
||||
import os
|
||||
from .menu_screen import MenuScreen
|
||||
import pygame
|
||||
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
@@ -6,7 +6,6 @@ logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class ScreenObjectsManager():
|
||||
|
||||
def __init__(self):
|
||||
self.touch_objects = {}
|
||||
self.text_objects = {}
|
||||
@@ -49,7 +48,6 @@ class ScreenObjectsManager():
|
||||
|
||||
|
||||
class BaseItem():
|
||||
|
||||
def __init__(self, pos, size):
|
||||
self.pos = pos
|
||||
self.size = size
|
||||
@@ -64,7 +62,6 @@ class BaseItem():
|
||||
|
||||
|
||||
class TextItem(BaseItem):
|
||||
|
||||
def __init__(self, font, text, pos, size):
|
||||
self.font = font
|
||||
self.text = text
|
||||
@@ -126,7 +123,6 @@ class TextItem(BaseItem):
|
||||
|
||||
|
||||
class TouchObject(BaseItem):
|
||||
|
||||
def __init__(self, pos, size):
|
||||
BaseItem.__init__(self, pos, size)
|
||||
self.active = False
|
||||
@@ -139,7 +135,6 @@ class TouchObject(BaseItem):
|
||||
|
||||
|
||||
class TouchAndTextItem(TouchObject, TextItem):
|
||||
|
||||
def __init__(self, font, text, pos, size):
|
||||
TextItem.__init__(self, font, text, pos, size)
|
||||
TouchObject.__init__(self, pos, self.size)
|
||||
@@ -169,7 +164,6 @@ class TouchAndTextItem(TouchObject, TextItem):
|
||||
|
||||
|
||||
class Progressbar(TouchObject):
|
||||
|
||||
def __init__(self, font, text, pos, size, max_value, value_text):
|
||||
BaseItem.__init__(self, pos, size)
|
||||
self.value = 0
|
||||
@@ -212,7 +206,6 @@ class Progressbar(TouchObject):
|
||||
|
||||
|
||||
class ScrollBar(TouchObject):
|
||||
|
||||
def __init__(self, pos, size, max_value, items_on_screen):
|
||||
BaseItem.__init__(self, pos, (pos[0] + size[0], pos[1] + size[1]))
|
||||
self.pos = pos
|
||||
|
||||
@@ -6,7 +6,6 @@ logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class TouchManager():
|
||||
|
||||
click = 1
|
||||
swipe = 2
|
||||
long_click = 3
|
||||
@@ -56,7 +55,6 @@ class TouchManager():
|
||||
self.down_time = time.time()
|
||||
|
||||
def mouse_up(self, event):
|
||||
logger.error(event.button)
|
||||
self.up_pos = event.pos
|
||||
if abs(self.down_pos[0] - self.up_pos[0]) < self.max_move_margin:
|
||||
if abs(self.down_pos[1] - self.up_pos[1]) < self.max_move_margin:
|
||||
@@ -72,7 +70,6 @@ class TouchManager():
|
||||
|
||||
|
||||
class TouchEvent():
|
||||
|
||||
def __init__(self, event_type, down_pos, current_pos, vertical):
|
||||
self.type = event_type
|
||||
self.down_pos = down_pos
|
||||
|
||||
@@ -3,20 +3,19 @@ import traceback
|
||||
import logging
|
||||
from threading import Thread
|
||||
import pygame
|
||||
from .screen_manager import ScreenManager
|
||||
|
||||
from mopidy import core
|
||||
|
||||
from .screen_manager import ScreenManager
|
||||
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class TouchScreen(pykka.ThreadingActor, core.CoreListener):
|
||||
|
||||
def __init__(self, config, core):
|
||||
super(TouchScreen, self).__init__()
|
||||
self.backend = pykka.ActorRegistry.get_by_class_name("TouchScreenBackend")[0]
|
||||
logger.error(self.backend)
|
||||
self.core = core
|
||||
self.running = False
|
||||
self.screen_size = (config['touchscreen']['screen_width'], config['touchscreen']['screen_height'])
|
||||
|
||||
@@ -1,15 +1,16 @@
|
||||
import pykka
|
||||
from mopidy import backend
|
||||
import logging
|
||||
|
||||
from mopidy import backend
|
||||
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
|
||||
class TouchScreenBackend(pykka.ThreadingActor, backend.Backend):
|
||||
|
||||
class TouchScreenBackend(pykka.ThreadingActor, backend.Backend):
|
||||
def __init__(self, config, audio):
|
||||
super(TouchScreenBackend, self).__init__()
|
||||
self.audio = audio
|
||||
logger.error("backend funciona")
|
||||
|
||||
def on_receive(self, message):
|
||||
action = message['action']
|
||||
|
||||
@@ -1,13 +1,14 @@
|
||||
from .list_view import ListView
|
||||
from .main_screen import MainScreen
|
||||
|
||||
class Tracklist():
|
||||
|
||||
class Tracklist():
|
||||
def __init__(self, size, base_size, manager):
|
||||
self.size = size
|
||||
self.base_size = base_size
|
||||
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.list_view = ListView((0, self.base_size), (self.size[0], self.size[1] - 2 * self.base_size),
|
||||
self.base_size, manager.fonts['base'])
|
||||
self.tracks = []
|
||||
self.tracks_strings = []
|
||||
self.update_list()
|
||||
|
||||
Reference in New Issue
Block a user