media-gstreamer: Port to GdkGLTextureBuilder
authorBenjamin Otte <otte@redhat.com>
Mon, 24 Apr 2023 20:22:07 +0000 (22:22 +0200)
committerBenjamin Otte <otte@redhat.com>
Thu, 27 Apr 2023 04:40:47 +0000 (06:40 +0200)
This is a rudimentary port that does not take advantage of all the cool
new formats that we could support now.

modules/media/gtkgstsink.c

index 552c23c23d75d0d6b84b23c62f39e1bd3c0e261a..f0a15390f74c45bf8d30675c0c4fbb3f94328b07 100644 (file)
@@ -287,6 +287,7 @@ gtk_gst_sink_texture_from_buffer (GtkGstSink *self,
       gst_video_frame_map (frame, &self->v_info, buffer, GST_MAP_READ | GST_MAP_GL))
     {
       GstGLSyncMeta *sync_meta;
+      GdkGLTextureBuilder *builder;
 
       sync_meta = gst_buffer_get_gl_sync_meta (buffer);
       if (sync_meta) {
@@ -296,12 +297,17 @@ gtk_gst_sink_texture_from_buffer (GtkGstSink *self,
         gst_gl_context_activate (self->gst_gdk_context, FALSE);
       }
 
-      texture = gdk_gl_texture_new (self->gdk_context,
-                                    *(guint *) frame->data[0],
-                                    frame->info.width,
-                                    frame->info.height,
-                                    (GDestroyNotify) video_frame_free,
-                                    frame);
+      builder = gdk_gl_texture_builder_new ();
+      gdk_gl_texture_builder_set_context (builder, self->gdk_context);
+      gdk_gl_texture_builder_set_id (builder, *(guint *) frame->data[0]);
+      gdk_gl_texture_builder_set_width (builder, frame->info.width);
+      gdk_gl_texture_builder_set_height (builder, frame->info.height);
+
+      texture = gdk_gl_texture_builder_build (builder,
+                                              (GDestroyNotify) video_frame_free,
+                                              frame);
+
+      g_object_unref (builder);
 
       *pixel_aspect_ratio = ((double) frame->info.par_n) / ((double) frame->info.par_d);
     }