diff options
author | wm4 <wm4@nowhere> | 2015-02-02 16:09:14 +0100 |
---|---|---|
committer | wm4 <wm4@nowhere> | 2015-02-02 18:07:37 +0100 |
commit | c45f2fe0ee147cadb85e8f166cca83012977c545 (patch) | |
tree | ea4bf480adc060ed16c7f138da9f8d518a24262c /video | |
parent | 568a0157ff92dac051ed5cd76b957ec851c14350 (diff) |
vo_opengl: fix breakage with rotated video on initial display
Resizing was happening before reconfig, so src_rect_rot was outdated and
didn't include the rotation. This resulted in corrupted rendering on
initial display, which fixed itself after the first time the window was
somehow resized.
Diffstat (limited to 'video')
-rw-r--r-- | video/out/gl_video.c | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/video/out/gl_video.c b/video/out/gl_video.c index 2f0eaf23ea..cef901d1b6 100644 --- a/video/out/gl_video.c +++ b/video/out/gl_video.c @@ -182,7 +182,6 @@ struct gl_video { struct mp_csp_primaries csp_src, csp_dest; struct mp_rect src_rect; // displayed part of the source video - struct mp_rect src_rect_rot;// compensated for optional rotation struct mp_rect dst_rect; // video rectangle on output window struct mp_osd_res osd_rect; // OSD size/margins int vp_x, vp_y, vp_w, vp_h; // GL viewport @@ -1750,6 +1749,13 @@ void gl_video_render_frame(struct gl_video *p, int fbo, struct frame_timing *t) GL *gl = p->gl; struct video_image *vimg = &p->image; + // compensated for optional rotation + struct mp_rect src_rect_rot = p->src_rect; + if ((p->image_params.rotate % 180) == 90) { + MPSWAP(int, src_rect_rot.x0, src_rect_rot.y0); + MPSWAP(int, src_rect_rot.x1, src_rect_rot.y1); + } + gl->BindFramebuffer(GL_FRAMEBUFFER, fbo); gl->Viewport(p->vp_x, p->vp_y, p->vp_w, p->vp_h); @@ -1800,8 +1806,8 @@ void gl_video_render_frame(struct gl_video *p, int fbo, struct frame_timing *t) // Clip to visible height so that separate scaling scales the visible part // only (and the target FBO texture can have a bounded size). // Don't clamp width; too hard to get correct final scaling on l/r borders. - chain.f.vp_y = p->src_rect_rot.y0; - chain.f.vp_h = p->src_rect_rot.y1 - p->src_rect_rot.y0; + chain.f.vp_y = src_rect_rot.y0; + chain.f.vp_h = src_rect_rot.y1 - src_rect_rot.y0; handle_pass(p, &chain, &p->scale_sep_fbo, p->scale_sep_program); @@ -1817,8 +1823,8 @@ void gl_video_render_frame(struct gl_video *p, int fbo, struct frame_timing *t) // correct origin/height before. // For X direction, assume the texture wasn't scaled yet, so we can // select the correct portion, which will be scaled to screen. - chain.f.vp_x = p->src_rect_rot.x0; - chain.f.vp_w = p->src_rect_rot.x1 - p->src_rect_rot.x0; + chain.f.vp_x = src_rect_rot.x0; + chain.f.vp_w = src_rect_rot.x1 - src_rect_rot.x0; chain.use_dst = true; chain.dst = p->dst_rect; @@ -1906,15 +1912,9 @@ void gl_video_resize(struct gl_video *p, struct mp_rect *window, struct mp_osd_res *osd, bool vflip) { p->src_rect = *src; - p->src_rect_rot = *src; p->dst_rect = *dst; p->osd_rect = *osd; - if ((p->image_params.rotate % 180) == 90) { - MPSWAP(int, p->src_rect_rot.x0, p->src_rect_rot.y0); - MPSWAP(int, p->src_rect_rot.x1, p->src_rect_rot.y1); - } - p->vp_x = window->x0; p->vp_y = window->y0; p->vp_w = window->x1 - window->x0; |