From ada06703fbc78d2218b045e0e72156a9d9ee240a Mon Sep 17 00:00:00 2001 From: wm4 Date: Sat, 29 Jun 2013 19:39:41 +0200 Subject: sd_ass: convert pts to integer for get_text() Gives more consistent rounding, which makes sub_step behave better. --- sub/sd_ass.c | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) (limited to 'sub/sd_ass.c') diff --git a/sub/sd_ass.c b/sub/sd_ass.c index c82e1e80bb..0200dd4e68 100644 --- a/sub/sd_ass.c +++ b/sub/sd_ass.c @@ -264,14 +264,13 @@ static char *get_text(struct sd *sd, double pts) if (pts == MP_NOPTS_VALUE) return NULL; + long long ipts = pts * 1000 + 0.5; struct buf b = {ctx->last_text, sizeof(ctx->last_text) - 1}; for (int i = 0; i < track->n_events; ++i) { ASS_Event *event = track->events + i; - double start = event->Start / 1000.0; - double end = (event->Start + event->Duration) / 1000.0; - if (pts >= start && pts < end) { + if (ipts >= event->Start && ipts < event->Start + event->Duration) { if (event->Text) { int start = b.len; ass_to_plaintext(&b, event->Text); -- cgit v1.2.3