eglglessink: Fix aspect-ratio issues caused by scaling on RPi
authorSebastian Dröge <sebastian.droege@collabora.co.uk>
Thu, 28 Feb 2013 10:27:44 +0000 (11:27 +0100)
committerSebastian Dröge <sebastian.droege@collabora.co.uk>
Thu, 21 Mar 2013 09:11:27 +0000 (10:11 +0100)
Conflicts:
ext/eglgles/video_platform_wrapper.c

ext/eglgles/video_platform_wrapper.c

index e863de830e067628b2a9e259d9b2c158af51ea5c..9b0dc37b5f3bdd285416b89363d883e16d151216 100644 (file)
@@ -165,6 +165,7 @@ platform_destroy_native_window (EGLNativeDisplayType display,
 
 #ifdef USE_EGL_RPI
 #include <bcm_host.h>
+#include <gst/video/gstvideosink.h>
 
 typedef struct
 {
@@ -181,6 +182,7 @@ platform_create_native_window (gint width, gint height, gpointer * window_data)
   RPIWindowData *data;
   VC_RECT_T dst_rect;
   VC_RECT_T src_rect;
+  GstVideoRectangle src, dst, res;
 
   uint32_t dp_height;
   uint32_t dp_width;
@@ -195,10 +197,19 @@ platform_create_native_window (gint width, gint height, gpointer * window_data)
   GST_DEBUG ("Got display size: %dx%d\n", dp_width, dp_height);
   GST_DEBUG ("Source size: %dx%d\n", width, height);
 
-  dst_rect.x = 0;
-  dst_rect.y = 0;
-  dst_rect.width = dp_width;
-  dst_rect.height = dp_height;
+  /* Center width*height frame inside dp_width*dp_height */
+  src.w = width;
+  src.h = height;
+  src.x = src.y = 0;
+  dst.w = dp_width;
+  dst.h = dp_height;
+  dst.x = dst.y = 0;
+  gst_video_sink_center_rect (&src, &dst, &res, TRUE);
+
+  dst_rect.x = res.x;
+  dst_rect.y = res.y;
+  dst_rect.width = res.w;
+  dst_rect.height = res.h;
 
   src_rect.x = 0;
   src_rect.y = 0;