From 3cbb4dd435f3cee4e706a01c07b509f7327fff80 Mon Sep 17 00:00:00 2001 From: Tadao Tanikawa Date: Tue, 13 Dec 2016 13:53:06 +0900 Subject: Adding backport patches of Qt5 to show cover art To show cover art in qtmultimedia, the backport patches(listed below) are needed. https://codereview.qt-project.org/179542 https://codereview.qt-project.org/165950 https://codereview.qt-project.org/165951 Change-Id: I638d824a3c8c4c632c4347538653830921c5e956 Signed-off-by: Tadao Tanikawa --- .../0001-GStreamer-support-cover-art.patch | 54 ++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 recipes-qt/qt5/qtmultimedia/0001-GStreamer-support-cover-art.patch (limited to 'recipes-qt/qt5/qtmultimedia/0001-GStreamer-support-cover-art.patch') diff --git a/recipes-qt/qt5/qtmultimedia/0001-GStreamer-support-cover-art.patch b/recipes-qt/qt5/qtmultimedia/0001-GStreamer-support-cover-art.patch new file mode 100644 index 00000000..8e644905 --- /dev/null +++ b/recipes-qt/qt5/qtmultimedia/0001-GStreamer-support-cover-art.patch @@ -0,0 +1,54 @@ +From 9bdc7c84eea0ff66c937d5f62ffed249321c3c35 Mon Sep 17 00:00:00 2001 +From: Tasuku Suzuki +Date: Sun, 24 Jul 2016 00:23:36 +0900 +Subject: [PATCH] GStreamer: support cover art + +Change-Id: I05987f578a40c23dc2eb6f3e6a7f76d11f704214 +Reviewed-by: Yoann Lopes +--- + src/gsttools/qgstutils.cpp | 16 ++++++++++++++++ + .../gstreamer/mediaplayer/qgstreamermetadataprovider.cpp | 1 + + 2 files changed, 17 insertions(+) + +diff --git a/src/gsttools/qgstutils.cpp b/src/gsttools/qgstutils.cpp +index 831ba96..a2b3507 100644 +--- a/src/gsttools/qgstutils.cpp ++++ b/src/gsttools/qgstutils.cpp +@@ -141,6 +141,22 @@ static void addTagToMap(const GstTagList *list, + } + if (!map->contains("year") && year > 0) + map->insert("year", year); ++ } else if (G_VALUE_TYPE(&val) == GST_TYPE_SAMPLE) { ++ GstSample *sample = (GstSample *)g_value_get_boxed(&val); ++ GstCaps* caps = gst_sample_get_caps(sample); ++ if (caps && !gst_caps_is_empty(caps)) { ++ GstStructure *structure = gst_caps_get_structure(caps, 0); ++ const gchar *name = gst_structure_get_name(structure); ++ if (QByteArray(name).startsWith("image/")) { ++ GstBuffer *buffer = gst_sample_get_buffer(sample); ++ if (buffer) { ++ GstMapInfo info; ++ gst_buffer_map(buffer, &info, GST_MAP_READ); ++ map->insert(QByteArray(tag), QImage::fromData(info.data, info.size, name)); ++ gst_buffer_unmap(buffer, &info); ++ } ++ } ++ } + #endif + } else if (G_VALUE_TYPE(&val) == GST_TYPE_FRACTION) { + int nom = gst_value_get_fraction_numerator(&val); +diff --git a/src/plugins/gstreamer/mediaplayer/qgstreamermetadataprovider.cpp b/src/plugins/gstreamer/mediaplayer/qgstreamermetadataprovider.cpp +index 074f8ad..01103d6 100644 +--- a/src/plugins/gstreamer/mediaplayer/qgstreamermetadataprovider.cpp ++++ b/src/plugins/gstreamer/mediaplayer/qgstreamermetadataprovider.cpp +@@ -93,6 +93,7 @@ static const QGstreamerMetaDataKeyLookup *qt_gstreamerMetaDataKeys() + + //metadataKeys->insert(0, QMediaMetaData::CoverArtUrlSmall); + //metadataKeys->insert(0, QMediaMetaData::CoverArtUrlLarge); ++ metadataKeys->insert(GST_TAG_PREVIEW_IMAGE, QMediaMetaData::CoverArtImage); + + // Image/Video + metadataKeys->insert("resolution", QMediaMetaData::Resolution); +-- +2.7.4 + -- cgit 1.2.3-korg