Spotify Quicklist for Unity


10

Jak mogę dodać „szybką listę” Unity dla Spotify (zainstalowaną z ich strony internetowej), aby po kliknięciu prawym przyciskiem myszy ikony na stacji dokującej otrzymałem: „Dalej, Wstecz, Zatrzymaj, Graj” i tak dalej?

Odpowiedzi:


5

spotify (natywny klient linux)

Ponieważ spotify zawiera wskaźnik kontrolujący niektóre z jego funkcji, pozwala nam to używać dbusdo wysyłania zdarzeń.

Na Ubuntuforums jest świetny skrypt, który to opisuje.

Najpierw zainstaluj warunek:

sudo apt-get install libnet-dbus-perl

Teraz skopiuj i wklej skrypt do pliku tekstowego o nazwie spcmdi zapisz go w folderze domowym.

Nadaj mu uprawnienia do wykonywania:

chmod +x ~/spcmd

Przenieśmy to do bardziej użytecznego folderu:

mv ~/spcmd /usr/local/bin

Teraz stwórzmy szybką listę.

Najpierw skopiuj plik pulpitu spotify do folderu domowego:

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

Otwórz plik, skopiuj i wklej szybką listę na końcu pliku. Zapisz to.

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

wynik końcowy

wprowadź opis zdjęcia tutaj

szybka lista

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;
}

5

Myślę, że dotychczasowe odpowiedzi są nieco zbyt skomplikowane. Nie jest wymagany osobny skrypt, odpowiednie polecenia DBus można wysyłać bezpośrednio przez dbus-send. Upewnij się tylko, że dbuspakiet jest zainstalowany, aw wierszu polecenia wydaj następujące polecenia:

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

Edytuj plik ~/.local/share/applications/spotify.desktopdo odczytu:

[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;

I jesteś skończony.


To najlepsza odpowiedź. Jednak kiedy próbowałem to zrobić ręcznie, brakowało mi --print-reply=literali nie działało. Czy masz wyjaśnienie? Prawie nic nie wiem o DBusie.
Tamás Barta

Znakomita odpowiedź :) Dodatkowe pytanie, czy można również dodać przycisk „kciuk w górę” i „kciuk w dół” (te, które są w radiu spotify :))?
Linus,

2

spotify_cmd to narzędzie do kontrolowania działającej instancji Spotify pod Wine , powinno również działać w systemie Windows, ale nie zostało przetestowane.

Pobierz spotifycmd . Skopiuj na pulpit. następnie

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

użyj teraz Exec=/usr/bin/spotifycmd/spotify_cmd.exe XXXXpodczas tworzenia szybkiej listy.

Tutaj XXXXjest playpause, next, prev, stop, voldown, volup, itd.

przewodnik po tworzeniu szybkiej listy można znaleźć w mojej odpowiedzi


Ta odpowiedź jest doskonała !!!! Mam jednak problemy z działaniem spotify_cmd.exe. Zwraca Can not find spotify, is it running?w terminalu. To jednak właściwy utwór!
Ryan McClure,

Oof, czy istnieje sposób natywny?
MarkovCh1

@Syzygy nie znalazłem. :(
Rahul Virpara

hmmm - biorąc pod uwagę błąd - być może musisz uruchomić wersję Spotify pod Wine dla Windows, aby ten oparty na winie spotify_cmd działał.
fossfreedom

@fossfreedom masz rację. właśnie sprawdziłem źródło. zawiera windows.hbibliotekę udostępniającą Win32 API.
Rahul Virpara,

-1

Spotify będzie mieć ikonę na panelu. Po prostu kliknij na to, a otrzymasz grę, stop, pauzę, następne itd. (Nie pamiętam wszystkiego). Nie jestem pewien, czy to odpowiada na twoje pytanie.


2
To pytanie dotyczy również sposobu umieszczenia tej funkcji w ikonie Spotify w programie uruchamiającym Unity.
Eliah Kagan

Ok, tylko ja źle zrozumiałem jego pytanie.
user66987
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.