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