>From d7819943529f5162f984c8f0aef439f9854bc4dd Mon Sep 17 00:00:00 2001 From: greg Date: Sat, 21 Feb 2009 05:48:03 +0100 Subject: [PATCH] When using pan-and-scan, use correct positions. Use correct positions for positioned events (even if they'll be off-screen), but restrict normal subtitle events to the visible area. --- libass/ass_render.c | 6 +++++- 1 files changed, 5 insertions(+), 1 deletions(-) diff --git a/libass/ass_render.c b/libass/ass_render.c index d8eb60e..ec51d8a 100644 --- a/libass/ass_render.c +++ b/libass/ass_render.c @@ -577,6 +577,10 @@ static int x2scr(double x) { return x*frame_context.orig_width_nocrop / frame_context.track->PlayResX + FFMAX(global_settings->left_margin, 0); } +static int x2scr_pos(double x) { + return x*frame_context.orig_width / frame_context.track->PlayResX + + global_settings->left_margin; +} /** * \brief Mapping between script and screen coordinates */ @@ -2124,7 +2128,7 @@ static int ass_render_event(ass_event_t* event, event_images_t* event_images) int base_y = 0; mp_msg(MSGT_ASS, MSGL_DBG2, "positioned event at %f, %f\n", render_context.pos_x, render_context.pos_y); get_base_point(bbox, alignment, &base_x, &base_y); - device_x = x2scr(render_context.pos_x) - base_x; + device_x = x2scr_pos(render_context.pos_x) - base_x; device_y = y2scr(render_context.pos_y) - base_y; } -- 1.5.6.3