Caratteristiche avanzate di Amarok
Scorciatoie da tastiera
&amarok; usa scorciatoie da tastiera come la maggior parte delle altre applicazioni. Sotto trovi un elenco di queste scorciatoie e le rispettive azioni. Le scorciatoie globali possono essere configurate facendo clic con il pulsante destro del mouse nella finestra del lettore e selezionando Configura scorciatoie globali.... Le scorciatoie di &amarok; possono essere configurate facendo clic con il pulsante destro del mouse nella finestra del lettore e selezionando Configura scorciatoie...
Puoi programmare i tasti multimediali affinché funzionino come scorciatoie per &amarok; facendo divenire la tua tastiera un centro di controllo di &amarok;.
Le scorciatoie globali sono:
Combinazione tasti
Azione
WinX
Riproduci
WinC
Pausa
WinV
Ferma
WinB
Prossima traccia
WinZ
Traccia precedente
Wintasto + in tast.num.
Aumenta volume
Wintasto - in tast.num.
Riduci volume
WinShifttasto + in tast.num
Cerca in avanti
WinShifttasto - in tast.num
Cerca indietro
WinA
Aggiungi file
WinP
Attiva/disattiva playlist
WinO
Mostra OSD
WinM
Volume muto
Le scorciatoie di &amarok; sono:
Combinazione tasti
Azione
CtrlC
Copia
Ctrltasto Invio in tast.num
Vai all'attuale
CtrlD
Accoda tracce selezionate
CtrlQ
Chiudi
CtrlShiftZ
Ripeti
CtrlS
Salva la playlist
CtrlA
Seleziona tutto
CtrlM
Mostra la barra dei menu
CtrlH
Mescola
CtrlZ
Annulla
Le scorciatoie per il navigatore della playlist sono:
Combinazione tasti
Azione
Barra spaziatrice
Carica playlist
F2
Rinomina playlist
Tasto di cancellazione a sinistra
Rimuove playlist
L'interfaccia DCOP
L'interfaccia DCOP di Amarok fornisce un modo semplice per controllare Amarok con script personalizzati.
L'interfaccia DCOP di Amarok ha molte funzioni generiche che possono essere trovate in altre applicazioni di KDE. Questa sezione è divisa in sei tabelle e descrive le funzioni DCOP della collezione, navigatore per contesti, lettore, playlist, navigatore della playlist e script. Un esempio della funzione dcop pausa
potrebbe essere il seguente:
%dcop amarok player pause
dcop amarok collection
Chiamata DCOP
Azione
int totalAlbums()
Restituisce il totale degli album nella collezione.
int totalArtists()
Restituisce il totale degli artisti nella collezione.
int totalCompilations()
Restituisce il totale di compilation nella collezione.
int totalGenres()
Restituisce il totale dei generi nella collezione.
int totalTracks()
Restituisce il totale delle tracce nella collezione.
QString query( QString sql )
Interroga il database attraverso SQL.
QStringList similarArtists( int artists )
Restituisce artisti simili alla traccia attuale, limitato a int artisti.
void migrateFile( QString oldURL, QString newURL )
Sposta un file nella collezione, mantenendo intatte le statistiche.
void scanCollection()
Scansione della collezione.
void scanCollectionChanges()
Scansione della collezione alla ricerca di modifiche.
dcop amarok contextbrowser
Chiamata DCOP
Azione
void showCurrentTrack()
Mostra la traccia attuale nel navigatore per contesti.
void showLyrics()
Mostra la scheda dei testi nel navigatore per contesti.
void showWiki()
Mostra la scheda di wikipedia nel navigatore per contesti.
dcop amarok player
Chiamata DCOP
Azione
bool dynamicModeStatus()
Restituisce lo stato della modalità dinamica.
bool equalizerEnabled()
Restituisce lo stato dell'equalizzatore.
bool isPlaying()
Restituisce vero se c'è qualcosa in riproduzione.
bool randomModeStatus()
Restituisce lo stato della modalità casuale.
bool repeatPlaylistStatus()
Restituisce lo stato di Ripeti playlist.
bool repeatTrackStatus()
Restituisce lo stato di Ripeti traccia.
int getVolume()
Restituisce il volume in un intervallo compreso tra 0 e 100%.
int sampleRate()
Restituisce il campionamento della traccia attuale.
int score()
Restituisce il punteggio della traccia in riproduzione.
int status()
Restituisce lo stato di riproduzione: 0 - fermato, 1 - in pausa, 2 - in riproduzione.
int trackCurrentTime()
Restituisce la posizione di riproduzione attuale in secondi.
int trackPlayCounter()
Restituisce il contatore di riproduzione per il brano attuale.
int trackTotalTime()
Restituisce la durata della traccia in secondi.
QString album()
Restituisce l'album della traccia in riproduzione.
QString artist()
Restituisce l'artista della traccia in riproduzione.
QString bitrate()
Restituisce il bitrate della traccia in riproduzione.
QString comment()
Restituisce il commento della traccia in riproduzione.
QString coverImage()
Restituisce l'URL codificato della copertina della traccia attuale.
QString currentTime()
Restituisce la posizione della traccia in riproduzione (formato [h:]mm:ss).
QString encodedURL()
Restituisce l'URL codificato della traccia in riproduzione.
QString engine()
Restituisce il motore sonoro attuale.
QString genre()
Restituisce il genere della traccia in riproduzione.
QString lyrics()
Restituisce il testo della traccia in riproduzione.
QString lyricsByPath( QString path )
Restituisce il testo di una traccia in base al percorso.
QString nowPlaying()
Il titolo dei media in fase di riproduzione.
QString path()
Restituisce il percorso non codificato della traccia in riproduzione.
QString setContextStyle( QString )
Imposta lo stile CSS del navigatore per contesti.
QString title()
Restituisce il titolo della traccia in riproduzione.
QString totalTime()
Restituisce la durata della traccia in riproduzione (formato [h:]mm:ss).
QString track()
Restituisce il numero di traccia.
QString type()
Restituisce il tipo di file.
QString year()
Restituisce l'anno della traccia in riproduzione.
void configEqualizer()
Commuta la finestra di configurazione dell'equalizzatore.
void enableDynamicMode(bool enable)
Attiva o disattiva Modalità dinamica.
void enableOSD(bool enable)
Attiva o disattiva visualizzazione OSD.
void enableRandomMode(bool enable)
Attiva o disattiva Modalità casuale.
void enableRepeatPlaylist(bool enable)
Attiva o disattiva Ripeti playlist.
void enableRepeatTrack(bool enable)
Attiva o disattiva Ripeti traccia.
void mediaDeviceMount()
Imposta il comando per montare il dispositivo multimediale.
void mediaDeviceUmount()
Imposta il comando per smontare i dispositivo multimediale.
void mute()
Commuta silenzio.
void next()
Equivale alla pressione del pulsante "Successivo".
void pause()
Equivale alla pressione del pulsante "Pausa".
void play()
Equivale alla pressione del pulsante "Riproduci".
void playPause()
Commuta lo stato riproduci/pausa (buono per utenti di tastiere mm)
void prev()
Equivale alla pressione del pulsante "Precedente".
void queueForTransfer( KURL url )
Accoda file per il trasferimeto al dispositivo multimediale.
void seek(int s)
Va al secondo dato nella traccia.
void seekRelative(int s)
Posizionamento relativo alla traccia attuale.
void setEqualizer(int, int, int, int, int, int, int, int, int, int, int)
Imposta le bande dell'equalizzatore
void setEqualizerEnabled( bool active )
Commuta l'equalizzatore.
void setEqualizerPreset( QString name )
Imposta la preimpostazione dell'equalizzatore.
void setLyricsByPath( QString url, QString lyrics )
Imposta il testo di una traccia in base al suo percorso.
void setScore( int score )
Imposta il punteggio della traccia in riproduzione.
void setScoreByPath( QString url, int score )
Imposta il punteggio di una traccia in base al suo percorso.
void setVolume(int volume)
Imposta il volume in un intervallo compreso tra 0 e !00%.
void showBrowser( QString browser )
Mostra i navigatori nella finestra della playlist.
void showOSD()
Mostra la visualizzazione OSD sullo schermo.
void stop()
Equivale alla pressione del pulsante "Ferma".
void transferDeviceFiles()
Trasferire file a un dispositivo multimediale.
void volumeDown()
Riduce il volume di una quantità ragionevole.
void volumeUp()
Aumenta il volume di una quantità ragionevole.
dcop amarok playlist
Chiamata DCOP
Azione
int getActiveIndex()
Restituisce l'indice della traccia attiva. -1 se nessuno.
int getTotalTrackCount()
Restituisce il numero di tracce nella playlist. 0 se nessuna
QString saveCurrentPlaylist()
Salva la playlist attuale come current.xml e ne restituisce il percorso.
void addMedia( KURL )
Aggiunge media audio specificati dall'URL.
void addMediaList( KURL::List )
Aggiunge alcuni media audio specificati dall'URL.
void clearPlaylist()
Svuota la playlist.
void playByIndex(int)
Avvia la riproduzione della traccia all'indice specificato.
void playMedia( KURL )
Aggiunge media audio specificati dall'URL.
void popupMessage( QString)
Mostra un messaggio a comparsa temporaneo.
void removeCurrentTrack()
Rimuove l'elemento della traccia attuale dalla playlist.
void repopulate()
Ripopola la playlist con tracce casuali.
void saveM3u( QString path, bool relativePaths)
Salva la playlist attuale come m3u.
void setStopAfterCurrent( bool )
Abilita/Disabilita la funzionalità "Ferma dopo la traccia attuale".
void shortStatusMessage( QString)
Mostra un messaggio temporaneo sulla barra di stato.
void shufflePlaylist()
Mescola la playlist
void togglePlaylist()
Commuta la finestra della playlist.
dcop amarok playlistbrowser
Chiamata DCOP
Azione
void addPodcast( QString )
Aggiunge una voce di podcast al navigatore della playlist.
void scanPodcasts()
Analisi di tutti i podcast alla ricerca di aggiornamenti.
void addPlaylist( QString )
Aggiunge una playlist al navigatore della playlist.
dcop amarok script
Chiamata DCOP
Azione
bool runScript( QString name)
Avvia lo script con il dato nome. Restituisce vero in caso di successo.
bool stopScript( QString name )
Ferma lo script con il dato nome. Restituisce vero in caso di successo.
QStringList listRunningScripts()
Restituisce un elenco di tutti gli script in esecuzione.
void addCustomMenuItem(QString submenu, QString itemTitle )
Abilita e imposta il titolo della voce di menu personalizzata.
void removeCustomMenuItem( QString submenu, QString itemTitle )
Rimuove l'elemento di menu personalizzato.
QString readConfig( QString key)
Restituisce il valore della voce di configurazione AmarokConfig data la chiave.
Opzioni linea di comando
Amarok supporta l'uso delle opzioni standard da riga di comando di Qt e kde. Amarok ha inoltre le proprie opzioni a livello applicazione specifiche.
Le opzioni Qt e kde:
Opzione
Azione
--help
Mostra l'aiuto sulle opzioni.
--help-qt
Mostra le opzioni specifiche di Qt.
--help-kde
Mostra le opzioni specifiche di KDE.
--help-all
Mostra tutte le opzioni.
--author
Mostra le informazioni dell'autore.
-v, --version
Mostra le informazioni della versione.
--license
Mostra le informazioni della licenza.
Le opzioni di Amarok:
Le opzioni di &amarok; sono pensate per essere usate mentre &amarok; è in funzione.
Opzione
Azione
-r, --previous
Salta alla traccia precedente nella playlist.
-p, --play
Inizia a riprodurre la playlist attuale.
-s, --stop
Ferma la riproduzione.
--pause
Mette in pausa la riproduzione.
-f, --next
Salta alla traccia successiva nella playlist.
-a, --append
Aggiungi file/URL alla playlist.
-e, --enqueue
Vedi append, disponibile per retro compatibilità.
--queue
Accoda file/URL dopo la traccia in riproduzione.
-m, --toggle-playlist-window
Attiva/disattiva la finestra della playlist.
--wizard
Lancia l'assistente del primo avvio.
--engine "name"
Avvia &amarok; con il motore "name".
Scrivere script
Scrivere script permette di estendere facilmente &amarok; senza cambiare il codice principale. Gli script sono simili ai plugin ma, invece di una API dedicata, usano l'interfaccia DCOP di &amarok; per comunicare. Ciò rende possibile scrivere script in quasi qualsiasi linguaggio di programmazione come Ruby, Python o PHP. Non solo si possono creare script nel classico linguaggio di programmazione, ma anche in linguaggi compilati come C++ o C. In aggiunta, &amarok; può notificare agli script eventi speciali e farli reagire di conseguenza. Questo sistema di notifiche verrà spiegato nel seguito di questa sezione.
Binding
È possibile scrivere semplici script che non necessitano dell'interazione dell'utente ed è anche possibile creare script con comode GUI che funzionino come piccole applicazioni singole. Per la programmazione delle GUI si può usare uno dei molti binding che KDE offre, per esempio RubyQT, una libreria Qt binding per Ruby. Tuttavia, vale la pena notare che non ogni utente ha tutti i binding disponibili installati. Se si decide di usarne uno, provare ad usarne uno di larga diffusione (p.e. RubyQt o PyQt).
Per fornire delle informazioni quando uno script non funziona per una dipendenza mancante, controllare che nel proprio script che il modulo che si vuole includere esista realmente. Se la dipendenza manca, si potrebbe intercettare l'errore e mostrare una finestra di informazione usando lo strumento da linea di comando "kdialog" in modo che l'utente capisca perché lo script fallisce.
Questo esempio mostra come intercettare una dipendenza mancante in Ruby:
begin
require 'Korundum'
rescue LoadError
error = 'Korundum (KDE bindings for ruby) from tdebindings v3.4 is required for this script.'
`kdialog --sorry '#{error}'`
exit
end
Per iniziare: i modelli
&amarok; fornisce modelli di script per numerose linguaggi nella cartella script/templates/. Si possono usare come base per propri script ed estenderli con le funzionalità di cui si necessita. Si noterà che lo scripting è attualmente abbastanza diretto. Se ad esempio si conosce un po' di programmazione in python, realizzare il proprio script non richiederà molto tempo.
Controllare &amarok; con DCOP
Gli script possono controllare Amarok richiamando alcune delle sue funzioni DCOP. Il modo più semplice per invocare una funzione DCOP è usare lo strumento da riga di comando "dcop", che fa parte di ogni distribuzione di KDE.
Questo è un esempio per aumentare il volume principale:
dcop amarok player volumeUp
La maggior parte dei linguaggi di scripting permette di eseguire programmi esterni con una funzione tipo exec(). In questa maniera lo strumento "dcop" può essere invocato facilmente. Questo è un semplice esempio in Python:
import os
os.system("dcop amarok player volumeDown")
Notifiche
&amarok; invia notifiche a tutti gli script attivi scrivendo stringhe sui loro canale stdin. Lo script dovrebbe quindi costantemente controllare stdin e reagire di conseguenza a ciascuno degli eventi possibili. Gli script possono anche scegliere ignorare tutti gli eventi che per cui non hanno funzioni.
Le seguenti notifiche vengono inviate a &amarok;:
configure
Dice allo script di mostrare la propria finestra di configurazione. Lo script
deve gestire archiviazione e caricamento delle opzioni di configurazione
in proprio. Quando uno script viene avviato, Amarok imposta la propria
cartella di lavoro in quella dove tutti i dati dovrebbero essere archiviati.
engineStateChange:empty|idle|paused|playing
Segnala una variazione nello stato del motore.
trackChange
Segnala l'inizio di una nuova traccia. Lo script può quindi usare le funzioni
DCOP per richiedere ulteriori informazioni sulla traccia, ad es. metadati
e durata.
volumeChangenewVolume
Segnala un cambiamento nel livello del volume principale. Il volume è un intero compreso
tra 0 e 100.
customMenuClicked:submenu itemTitle paths
Restituisce i percorsi dei file selezionati nella playlist quando si fa clic sulla voce del menu contestuale della playlist personalizzata. submenu e itemTitle
vengono inoltre restituiti per scopi di identificazione nel caso in cui uno
script rimanga in ascolto per notifiche multiple.
Per inserire una voce nel menu contestuale bisogna utilizzare la funzione DCOP
'dcop amarok script addCustomMenuItem( submenu itemTitle )'. Per rimuovere
una voce dal menu contestuale bisogna utilizzare la funzione DCOP
'dcop amarok script removeCustomMenuItem( submenu itemTitle )'.
Interruzione script
Prima che &amarok; si chiuda, o quando l'utente ferma uno script con il gestore degli script, &amarok; invia il segnale SIGTERM allo script. Il segnale può essere usato per fare pulizia, come salvataggio di dati o impostazioni di configurazione.
Pacchetti
Il gestore degli script di &amarok; è in grado di installare pacchetti di script scaricati dall'utente da un server web. I pacchetti sono normali tarball (.tar), opzionalmente compressi con bzip2 (.bz2). Si consiglia vivamente di usare un nome file del tipo myscript.amarokscript.tar.bz2, in modo che l'utente possa facilmente identificare il pacchetto come uno script per Amarok.
&amarok; 1.3 accetterà solamente pacchetti di script con l'estensione amarokscript, in modo da usarlo più facilmente fin da subito.
Il contenuto dei pacchetti tarball deve essere organizzato come segue:
myscript/
README
myscript.py (executable)
somemodule.py
foo.data
...
Permessi dei file
Lo script principale deve avere i permessi di esecuzione (+x) impostati, mentre moduli addizionali che vengono caricati dallo script possono non esserlo. Per preservare i permessi dei file nel tarball bisogna usare tar con l'opzione -p:
tar -cf myscript.amarokscript.tar -p myscript
&amarok; non sarà in grado di installare lo script se i permessi non sono correttamente impostati.
Distribuzione
Quando il pacchetto è terminato, si può inviarlo a www.kde-apps.org, ed aggiungere il collegamento nella Pagina Wiki degli script di &amarok;. Per la voce in kde-apps si dovrebbe usare la categoria &amarok; Scripts.