1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- package Plugins::SqueezeESP32::Plugin;
- use strict;
- use base qw(Slim::Plugin::Base);
- use Digest::MD5 qw(md5);
- use List::Util qw(min);
- use Slim::Utils::Prefs;
- use Slim::Utils::Log;
- use Slim::Web::ImageProxy;
- my $prefs = preferences('plugin.squeezeesp32');
- my $log = Slim::Utils::Log->addLogCategory({
- 'category' => 'plugin.squeezeesp32',
- 'defaultLevel' => 'INFO',
- 'description' => Slim::Utils::Strings::string('SqueezeESP32'),
- });
- sub initPlugin {
- my $class = shift;
-
- if ( main::WEBUI ) {
- require Plugins::SqueezeESP32::PlayerSettings;
- Plugins::SqueezeESP32::PlayerSettings->new;
-
- # require Plugins::SqueezeESP32::Settings;
- # Plugins::SqueezeESP32::Settings->new;
- }
-
- $class->SUPER::initPlugin(@_);
- Slim::Networking::Slimproto::addPlayerClass($class, 100, 'squeezeesp32', { client => 'Plugins::SqueezeESP32::Player', display => 'Plugins::SqueezeESP32::Graphics' });
- $log->info("Added class 100 for SqueezeESP32");
-
- Slim::Control::Request::subscribe(\&update_artwork, [ ['newmetadata'] ] );
- Slim::Control::Request::subscribe(\&update_artwork, [ ['playlist'], ['open', 'newsong'] ]);
- }
- sub update_artwork {
- my $request = shift;
- my $client = $request->client;
- my $cprefs = $prefs->client($client);
- my $artwork = $cprefs->get('artwork');
-
- return unless $client->model eq 'squeezeesp32' && $artwork->{'enable'};
- my $reqstr = $request->getRequestString();
- #my $path = $request->getParam('_path');
- my $s = $artwork->{'y'} >= 32 ? $cprefs->get('height') - $artwork->{'y'} : 32;
- $s = min($s, $cprefs->get('width') - $artwork->{'x'});
-
- my $path = 'music/current/cover_' . $s . 'x' . $s . '_o.jpg';
- my $body = Slim::Web::Graphics::artworkRequest($client, $path, undef, \&send_artwork, undef, HTTP::Response->new);
-
- send_artwork($client, undef, \$body) if $body;
-
- $log->info("artwork update notification $reqstr with $path");
- }
- sub send_artwork {
- my ($client, $params, $dataref) = @_;
-
- # I'm not sure why we are called so often, so only send when needed
- my $md5 = md5($$dataref);
- return if $client->pluginData('artwork_md5') eq $md5;
-
- $client->pluginData('artwork', $dataref);
- $client->pluginData('artwork_md5', $md5);
-
- my $artwork = $prefs->client($client)->get('artwork');
- my $length = length $$dataref;
- my $offset = 0;
-
- $log->info("got resized artwork (length: ", length $$dataref, ")");
-
- my $header = pack('Nnn', $length, $artwork->{'x'}, $artwork->{'y'});
-
- while ($length > 0) {
- $length = 1280 if $length > 1280;
- $log->info("sending grfa $length");
-
- my $data = $header . pack('N', $offset) . substr( $$dataref, 0, $length, '' );
-
- $client->sendFrame( grfa => \$data );
- $offset += $length;
- $length = length $$dataref;
- }
- }
- 1;
|