Lista rápida do Spotify para Unity

10

Como posso adicionar uma "lista rápida" do Unity para o Spotify (instalada no site), para que, quando clico com o botão direito do mouse no ícone no meu dock, obtenho: "Next, Previous, Stop, Play" e assim por diante?

MarkovCh1
fonte

Respostas:

5

spotify (cliente nativo do linux)

Como o spotify inclui um indicador para controlar algumas de suas funções, isso nos permite usar dbuspara enviar eventos.

Existe um ótimo script no ubuntuforums que aborda isso.

Primeiro instale um pré-requisito:

sudo apt-get install libnet-dbus-perl

Agora copie e cole o script em um arquivo de texto chamado spcmde salve-o na sua pasta pessoal.

Conceda direitos de execução:

chmod +x ~/spcmd

Vamos mover isso para uma pasta mais útil:

mv ~/spcmd /usr/local/bin

Agora, vamos criar uma lista rápida.

Primeiro copie o arquivo da área de trabalho spotify para sua pasta pessoal:

mkdir -p ~/.local/share/applications
cp /usr/share/applications/spotify.desktop ~/.local/share/applications

Abra o arquivo, copie e cole a lista rápida no final do arquivo. Salve isso.

gedit ~/.local/share/applications/spotify.desktop

resultado final

insira a descrição da imagem aqui

lista rápida

X-Ayatana-Desktop-Shortcuts=PlayPause;Next;Previous;Stop;

[PlayPause Shortcut Group]
Name=PlayPause
Exec=spcmd playpause
TargetEnvironment=Unity

[Next Shortcut Group]
Name=Next
Exec=spcmd next
TargetEnvironment=Unity

[Previous Shortcut Group]
Name=Previous
Exec=spcmd previous
TargetEnvironment=Unity

[Stop Shortcut Group]
Name=Stop
Exec=spcmd stop
TargetEnvironment=Unity

spcmd

#!/usr/bin/perl

use 5.010;
use strict;
use warnings;
use File::Basename;
use Net::DBus;

# Figure out some dbus stuff
unless ( defined $ENV{'DBUS_SESSION_BUS_ADDRESS'} ) {
&set_DBUS_SESSION_BUS_ADDRESS;
#die "Don't know which dbus to attach to.\nMake sure environment variable DBUS_SESSION_BUS_ADDRESS is set.";
}
#my $bus = Net::DBus->find;
my $bus = Net::DBus->session;
my $spotify = $bus->get_service("org.mpris.MediaPlayer2.spotify");
my $player = $spotify->get_object("/org/mpris/MediaPlayer2", "org.mpris.MediaPlayer2.Player");
my $application = $spotify->get_object("/org/mpris/MediaPlayer2", "org.mpris.MediaPlayer2");
my $getorset = $spotify->get_object("/org/mpris/MediaPlayer2", "org.freedesktop.DBus.Properties");

# Handle command line argument
if (scalar @ARGV == 0) { &print_help; }
given ($ARGV[0]) {
# when ('play') { $player->Play(); } #Does not work for some reason.
when ('pause') { $player->Pause(); }
when ('playpause') { $player->PlayPause(); }
when ('next') { $player->Next(); }
when ('previous') { $player->Previous(); }
when ('stop') { $player->Stop(); }
when ('playstatus') { print $getorset->Get("org.mpris.MediaPlayer2.Player", "PlaybackStatus") . "\n"; }
when (m/\bspotify:(artist|album|track):[0-9a-zA-z]{22}\b/) { $player->OpenUri($_); }
when ('metadata-debug') { &print_debug_metadata; }
default { &print_help; }
}


# Print the help text
sub print_help {
print "USAGE: " . basename($0) . " {pause|playpause|next|previous|stop|playstatus|met adata-debug|<spotify URI>}\n\n";
print "\t" . "pause" . "\t\t" . "Causes spotify to pause current playback." . "\n";
print "\t" . "playpause" . "\t" . "Causes spotify to pause or play current playback." . "\n";
print "\t" . "next" . "\t\t" . "Goes to next song." . "\n";
print "\t" . "previous" . "\t" . "Goes to previous song." . "\n";
print "\t" . "stop" . "\t\t" . "Stops playback." . "\n";
print "\t" . "playstatus" . "\t" . "Prints current playstatus (Playing/Paused)." . "\n";
print "\t" . "<spotify URI>" . "\t" . "Starts playing supplied URI." . "\n";
print "\t" . "metadata-debug" . "\t" . "Shows available data on currently playing song." . "\n";
print "\t" . "\t\t" . "Fairly unformatted, thus \"debug\" data." . "\n";
print "\n";
print "EXAMPLES:\t" . basename($0) . " playpause" . "\n";
print "\t\t" . basename($0) . " spotify:track:5XXAq1r5r73ZyBS0XAiGw0" . "\n";

exit;
}

# Print some raw metadata
sub print_debug_metadata {
# Dereference the metadata hashref by copying it to a local hash
my %metadata = %{ $getorset->Get("org.mpris.MediaPlayer2.Player", "Metadata") };

# Print all metadata
print "Now Playing:\n";
for (keys %metadata) {
print $_ . ":\t" . $metadata{$_} . "\n" unless ($_ eq 'xesam:artist');
}

# Dereference the artist arrayref by copying it to local array
my @artistarray = @{ $metadata{'xesam:artist'} };

# Print all artists.
foreach my $artist (@artistarray) {
print "artist: \t" . $artist . "\n";
}
}

sub set_DBUS_SESSION_BUS_ADDRESS {
my $curruser = `whoami`; chomp $curruser;
my $procname = 'spotify';
my $pid = `pgrep -o -u $curruser $procname`; chomp $pid;
my $environ = '/proc/' . $pid . '/environ';
my $dbussession = `grep -z DBUS_SESSION_BUS_ADDRESS $environ`; $dbussession =~ s/^DBUS_SESSION_BUS_ADDRESS=//;

$ENV{'DBUS_SESSION_BUS_ADDRESS'} = $dbussession;
}
liberdade de expressão
fonte
5

Eu acho que as respostas dadas até agora são coisas um pouco complicadas. Não é necessário um script separado, os comandos DBus relevantes podem ser enviados diretamente via dbus-send. Apenas verifique se o dbuspacote está instalado e na linha de comando emita os seguintes comandos:

mkdir -p ~/.local/share/applications
cp /usr/share/applications/spotify.desktop ~/.local/share/applications/

Edite o arquivo ~/.local/share/applications/spotify.desktoppara ler:

[Desktop Entry]
Name=Spotify
GenericName=Music Player
Comment=Listen to music using Spotify
Icon=spotify-client
Exec=spotify %U
TryExec=spotify
Terminal=false
Type=Application
Categories=Qt;Audio;Music;Player;AudioVideo
MimeType=x-scheme-handler/spotify
# ====> MODIFICATIONS START HERE <=====
Actions=PlayPause;Next;Previous

[Desktop Action PlayPause]
Name=Play/Pause
Exec=dbus-send --print-reply=literal --dest=org.mpris.MediaPlayer2.spotify /org/mpris/MediaPlayer2 org.mpris.MediaPlayer2.Player.PlayPause
OnlyShowIn=Messaging Menu;Unity;

[Desktop Action Next]
Name=Next
Exec=dbus-send --print-reply=literal --dest=org.mpris.MediaPlayer2.spotify /org/mpris/MediaPlayer2 org.mpris.MediaPlayer2.Player.Next
OnlyShowIn=Messaging Menu;Unity;

[Desktop Action Previous]
Name=Previous
Exec=dbus-send --print-reply=literal --dest=org.mpris.MediaPlayer2.spotify /org/mpris/MediaPlayer2 org.mpris.MediaPlayer2.Player.Previous
OnlyShowIn=Messaging Menu;Unity;

E você terminou.

Michael Wild
fonte
Esta é a melhor resposta. No entanto, quando tentei fazê-lo manualmente, perdi --print-reply=literale não funcionou. Você tem uma explicação? Não sei quase nada do DBus.
Tamás Barta
Resposta excelente :) Pergunta adicional, é possível adicionar o botão "thumbs-up" e "thumbs-down" também (os que estão no rádio spotify :))?
Linus
2

O spotify_cmd é uma ferramenta para controlar uma instância em execução do Spotify no wine , que também deve funcionar no Windows, mas não foi testado.

Faça o download do spotifycmd . Copie para a área de trabalho. então

cd ~/Desktop/
tar -xvjf spotifycmd-0.5.tar.bz2 
sudo cp -r spotifycmd /usr/bin/

agora use Exec=/usr/bin/spotifycmd/spotify_cmd.exe XXXXao criar a lista rápida.

Aqui XXXXé playpause, next, prev, stop, voldown, volup, etc.

para obter um guia para criar uma lista rápida, veja minha resposta

Rahul Virpara
fonte
Esta resposta é excelente !!!! Estou tendo problemas com o spotify_cmd.exe funcionando. Retorna Can not find spotify, is it running?no terminal. Este é o caminho certo!
Ryan McClure
Oof, existe uma maneira nativa?
precisa saber é o seguinte
@ Syzygy eu não encontrei um. :(
Rahul Virpara
hmmm - dado o erro - talvez você precise executar a versão windows do spotify no wine para que este spotify_cmd baseado em vinho funcione.
fossfreedom
@fossfreedom você está certo. apenas fonte verificada. inclui windows.huma biblioteca que fornece a API Win32.
Rahul Virpara
-1

O Spotify terá um ícone no painel. Basta clicar nele e você começa a jogar, parar, pausar, próximo etc (não se lembra de tudo). Não tenho certeza se isso responde à sua pergunta.

user66987
fonte
2
Esta pergunta está perguntando como colocar essa funcionalidade no ícone do Spotify no lançador Unity também.
Eliah Kagan
Ok, só eu que entendi mal a pergunta dele.
precisa saber é o seguinte