mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-13 19:05:37 +00:00
info: handle album-art
Decode and draw the album art into the video window.
This commit is contained in:
parent
328c9e7aab
commit
605e217942
2 changed files with 71 additions and 18 deletions
|
@ -15,7 +15,7 @@ files.
|
||||||
- offer several commands in addition (see below)
|
- offer several commands in addition (see below)
|
||||||
|
|
||||||
example output from commandline tool:
|
example output from commandline tool:
|
||||||
> gst-discoverer -v /home/ensonic/Musik/xotox-hypnocat.mp3
|
> gst-discoverer -v /home/ensonic/Musik/xotox-hypnocat.mp3
|
||||||
|
|
||||||
Topology:
|
Topology:
|
||||||
audio: audio/mpeg, mpegversion=(int)1, mpegaudioversion=(int)1, layer=(int)3, rate=(int)44100, channels=(int)2, parsed=(boolean)true
|
audio: audio/mpeg, mpegversion=(int)1, mpegaudioversion=(int)1, layer=(int)3, rate=(int)44100, channels=(int)2, parsed=(boolean)true
|
||||||
|
@ -74,7 +74,6 @@ Properties:
|
||||||
- if there is a "language-code" in the tags (or subtitles?) use flag icons
|
- if there is a "language-code" in the tags (or subtitles?) use flag icons
|
||||||
- deluge installs some under: /usr/share/pyshared/deluge/data/mediainfo/pixmaps/flags/
|
- deluge installs some under: /usr/share/pyshared/deluge/data/mediainfo/pixmaps/flags/
|
||||||
- famfamfam-flag-png: locale/usr/share/flags/countries/
|
- famfamfam-flag-png: locale/usr/share/flags/countries/
|
||||||
- handle album art in tag lists
|
|
||||||
- geo-tags: map-widget?, link to google-maps?
|
- geo-tags: map-widget?, link to google-maps?
|
||||||
- artist: links to {last.fm,wikipedia}
|
- artist: links to {last.fm,wikipedia}
|
||||||
- format dates nicely
|
- format dates nicely
|
||||||
|
@ -160,7 +159,7 @@ app disco
|
||||||
|<---------------------|
|
|<---------------------|
|
||||||
| ::finisheded |
|
| ::finisheded |
|
||||||
|<---------------------|
|
|<---------------------|
|
||||||
|
|
|
|
||||||
|
|
||||||
== sync deep-scan ==
|
== sync deep-scan ==
|
||||||
- same as "sync quick-scan", no intermediate result
|
- same as "sync quick-scan", no intermediate result
|
||||||
|
@ -189,5 +188,5 @@ app disco
|
||||||
|<---------------------|
|
|<---------------------|
|
||||||
| ::finisheded |
|
| ::finisheded |
|
||||||
|<---------------------|
|
|<---------------------|
|
||||||
|
|
|
|
||||||
|
|
||||||
|
|
|
@ -58,6 +58,8 @@ public class MediaInfo.Info : VPaned
|
||||||
private uint cur_video_stream;
|
private uint cur_video_stream;
|
||||||
private uint num_audio_streams;
|
private uint num_audio_streams;
|
||||||
private uint cur_audio_stream;
|
private uint cur_audio_stream;
|
||||||
|
// stream data
|
||||||
|
private Gdk.Pixbuf album_art = null;
|
||||||
|
|
||||||
private HashMap<string, string> resolutions;
|
private HashMap<string, string> resolutions;
|
||||||
private HashSet<string> tag_black_list;
|
private HashSet<string> tag_black_list;
|
||||||
|
@ -259,7 +261,9 @@ public class MediaInfo.Info : VPaned
|
||||||
bool res = true;
|
bool res = true;
|
||||||
|
|
||||||
// stop previous playback
|
// stop previous playback
|
||||||
pb.set_state (State.NULL);
|
pb.set_state (State.READY);
|
||||||
|
album_art = null;
|
||||||
|
drawing_area.queue_draw();
|
||||||
|
|
||||||
if (uri != null) {
|
if (uri != null) {
|
||||||
DiscovererInfo info;
|
DiscovererInfo info;
|
||||||
|
@ -595,14 +599,46 @@ public class MediaInfo.Info : VPaned
|
||||||
{
|
{
|
||||||
// redraw if not playing and if there is no video
|
// redraw if not playing and if there is no video
|
||||||
if (pb.current_state < State.PAUSED || !have_video) {
|
if (pb.current_state < State.PAUSED || !have_video) {
|
||||||
Gdk.Window w = widget.get_window();
|
|
||||||
Gtk.Allocation a;
|
Gtk.Allocation a;
|
||||||
widget.get_allocation(out a);
|
widget.get_allocation(out a);
|
||||||
Cairo.Context cr = Gdk.cairo_create (w);
|
Cairo.Context cr = Gdk.cairo_create (widget.get_window());
|
||||||
|
|
||||||
cr.set_source_rgb (0, 0, 0);
|
cr.set_source_rgb (0, 0, 0);
|
||||||
cr.rectangle (0, 0, a.width, a.height);
|
cr.rectangle (0, 0, a.width, a.height);
|
||||||
cr.fill ();
|
cr.fill ();
|
||||||
|
if (album_art != null) {
|
||||||
|
int sw=album_art.get_width();
|
||||||
|
int sh=album_art.get_height();
|
||||||
|
double sr = (double)sw / (double)sh;
|
||||||
|
double dr = (double)a.width / (double)a.height;
|
||||||
|
double wr = (double)sw / (double)a.width;
|
||||||
|
double hr = (double)sh / (double)a.height;
|
||||||
|
int x,y,w,h;
|
||||||
|
|
||||||
|
// stdout.printf("s: %d x %d : %f -> d: %d x %d : %f\n",sw,sh,sr,a.width,a.height,dr);
|
||||||
|
if (sr > dr) {
|
||||||
|
w = a.width;
|
||||||
|
h = (int)(w / sr);
|
||||||
|
x = 0;
|
||||||
|
y = (a.height - h) / 2;
|
||||||
|
} else if (sr < dr) {
|
||||||
|
h = a.height;
|
||||||
|
w = (int)(h * sr);
|
||||||
|
x = (a.width - w) / 2;
|
||||||
|
y = 0;
|
||||||
|
} else {
|
||||||
|
w = a.width;
|
||||||
|
h = a.height;
|
||||||
|
x = 0;
|
||||||
|
y = 0;
|
||||||
|
}
|
||||||
|
// stdout.printf("r: %d x %d\n",w,h);
|
||||||
|
|
||||||
|
Gdk.Pixbuf pb = album_art.scale_simple(w,h,Gdk.InterpType.BILINEAR);
|
||||||
|
Gdk.cairo_set_source_pixbuf(cr,pb,x,y);
|
||||||
|
cr.rectangle (x, y, w, h);
|
||||||
|
cr.fill ();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -680,20 +716,38 @@ public class MediaInfo.Info : VPaned
|
||||||
if (fn.has_prefix("private-"))
|
if (fn.has_prefix("private-"))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
// skip buffers (usualy images)
|
|
||||||
// TODO: decode images,
|
|
||||||
// - need to figure a way to return them
|
|
||||||
// - need to find a place where we show them
|
|
||||||
v = s.get_value (fn);
|
|
||||||
if (v.holds(typeof(Gst.Buffer)))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (str.length > 0)
|
if (str.length > 0)
|
||||||
str += "\n";
|
str += "\n";
|
||||||
|
|
||||||
vstr = v.serialize ().compress ();
|
// TODO: decode images:
|
||||||
if (vstr.has_prefix("http://") || vstr.has_prefix("https://")) {
|
/*
|
||||||
vstr = "<a href=\"" + vstr + "\">" + vstr + "</a>";
|
GInputStream is = g_memory_input_stream_new_from_data(GST_BUFFER_DATA(buf),GST_BUFFER_SIZE(buf,NULL);
|
||||||
|
GdkPixbuf pb = gdk_pixbuf_new_from_stream(is, NULL, NULL);
|
||||||
|
g_input_stream_close(is,NULL,NULL);
|
||||||
|
res = gdk_pixbuf_scale_simple(pb, w, h, GDK_INTERP_BILINEAR);
|
||||||
|
*/
|
||||||
|
// - need to figure a way to return them
|
||||||
|
// - where we show them -> in the drawing area
|
||||||
|
v = s.get_value (fn);
|
||||||
|
if (v.holds(typeof(Gst.Buffer))) {
|
||||||
|
Gst.Buffer buf = v.get_buffer();
|
||||||
|
Caps c = buf.get_caps();
|
||||||
|
|
||||||
|
try {
|
||||||
|
InputStream is = new MemoryInputStream.from_data (buf.data,buf.size,null);
|
||||||
|
album_art = new Gdk.Pixbuf.from_stream (is, null);
|
||||||
|
is.close();
|
||||||
|
} catch (Error e) {
|
||||||
|
debug ("Decoding album art failed: %s: %s", e.domain.to_string (), e.message);
|
||||||
|
}
|
||||||
|
|
||||||
|
// FIXME: having the actual resolution here would be nice
|
||||||
|
vstr = c.to_string();
|
||||||
|
} else {
|
||||||
|
vstr = v.serialize ().compress ();
|
||||||
|
if (vstr.has_prefix("http://") || vstr.has_prefix("https://")) {
|
||||||
|
vstr = "<a href=\"" + vstr + "\">" + vstr + "</a>";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
str += fn + " = " + vstr;
|
str += fn + " = " + vstr;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue