diff mbox series

[FFmpeg-devel,09/23] lavc/movtextdec: restore active style color after hilite

Message ID 20200406175218.1299994-10-jstebbins@jetheaddev.com
State Accepted
Commit f406dc9ceb92e1a37b7cbfd27c1f38290fe857ec
Headers show
Series [FFmpeg-devel,01/23] lavc/movtextdec: fix ass header colors | expand

Checks

Context Check Description
andriy/ffmpeg-patchwork warning Failed to apply patch

Commit Message

John Stebbins April 6, 2020, 5:52 p.m. UTC
---
 libavcodec/movtextdec.c | 14 +++++++++-----
 1 file changed, 9 insertions(+), 5 deletions(-)

Comments

Philip Langdale April 7, 2020, 12:01 a.m. UTC | #1
On Mon, 6 Apr 2020 11:52:04 -0600
John Stebbins <jstebbins@jetheaddev.com> wrote:

> ---
>  libavcodec/movtextdec.c | 14 +++++++++-----
>  1 file changed, 9 insertions(+), 5 deletions(-)
> 
> diff --git a/libavcodec/movtextdec.c b/libavcodec/movtextdec.c
> index 4d5dcdf5e7..f3a504b47b 100644
> --- a/libavcodec/movtextdec.c
> +++ b/libavcodec/movtextdec.c
> @@ -376,6 +376,7 @@ static int text_to_ass(AVBPrint *buf, const char
> *text, const char *text_end, int text_pos = 0;
>      int style_active = 0;
>      int entry = 0;
> +    int color = m->d.color;
>  
>      if (text < text_end && m->box_flags & TWRP_BOX) {
>          if (m->w.wrap_flag == 1) {
> @@ -404,9 +405,10 @@ static int text_to_ass(AVBPrint *buf, const char
> *text, const char *text_end, if (m->s[entry]->style_fontID ==
> m->ftab[i]->fontID) av_bprintf(buf, "{\\fn%s}", m->ftab[i]->font);
>                      }
> -                if (m->d.color != m->s[entry]->color)
> -                    av_bprintf(buf, "{\\1c&H%X&}",
> -                               RGB_TO_BGR(m->s[entry]->color));
> +                if (m->d.color != m->s[entry]->color) {
> +                    color = m->s[entry]->color;
> +                    av_bprintf(buf, "{\\1c&H%X&}",
> RGB_TO_BGR(color));
> +                }
>                  if (m->d.alpha != m->s[entry]->alpha)
>                      av_bprintf(buf, "{\\1a&H%02X&}", 255 -
> m->s[entry]->alpha); }
> @@ -414,6 +416,7 @@ static int text_to_ass(AVBPrint *buf, const char
> *text, const char *text_end, if (style_active) {
>                      av_bprintf(buf, "{\\r}");
>                      style_active = 0;
> +                    color = m->d.color;
>                  }
>                  entry++;
>              }
> @@ -435,9 +438,10 @@ static int text_to_ass(AVBPrint *buf, const char
> *text, const char *text_end, }
>              if (text_pos == m->h.hlit_end) {
>                  if (m->box_flags & HCLR_BOX) {
> -                    av_bprintf(buf, "{\\2c&H000000&}");
> +                    av_bprintf(buf, "{\\2c&H%X&}",
> RGB_TO_BGR(m->d.color)); } else {
> -                    av_bprintf(buf,
> "{\\1c&HFFFFFF&}{\\2c&H000000&}");
> +                    av_bprintf(buf, "{\\1c&H%X&}{\\2c&H%X&}",
> +                               RGB_TO_BGR(color),
> RGB_TO_BGR(m->d.color)); }
>              }
>          }

LGTM.


--phil
diff mbox series

Patch

diff --git a/libavcodec/movtextdec.c b/libavcodec/movtextdec.c
index 4d5dcdf5e7..f3a504b47b 100644
--- a/libavcodec/movtextdec.c
+++ b/libavcodec/movtextdec.c
@@ -376,6 +376,7 @@  static int text_to_ass(AVBPrint *buf, const char *text, const char *text_end,
     int text_pos = 0;
     int style_active = 0;
     int entry = 0;
+    int color = m->d.color;
 
     if (text < text_end && m->box_flags & TWRP_BOX) {
         if (m->w.wrap_flag == 1) {
@@ -404,9 +405,10 @@  static int text_to_ass(AVBPrint *buf, const char *text, const char *text_end,
                         if (m->s[entry]->style_fontID == m->ftab[i]->fontID)
                             av_bprintf(buf, "{\\fn%s}", m->ftab[i]->font);
                     }
-                if (m->d.color != m->s[entry]->color)
-                    av_bprintf(buf, "{\\1c&H%X&}",
-                               RGB_TO_BGR(m->s[entry]->color));
+                if (m->d.color != m->s[entry]->color) {
+                    color = m->s[entry]->color;
+                    av_bprintf(buf, "{\\1c&H%X&}", RGB_TO_BGR(color));
+                }
                 if (m->d.alpha != m->s[entry]->alpha)
                     av_bprintf(buf, "{\\1a&H%02X&}", 255 - m->s[entry]->alpha);
             }
@@ -414,6 +416,7 @@  static int text_to_ass(AVBPrint *buf, const char *text, const char *text_end,
                 if (style_active) {
                     av_bprintf(buf, "{\\r}");
                     style_active = 0;
+                    color = m->d.color;
                 }
                 entry++;
             }
@@ -435,9 +438,10 @@  static int text_to_ass(AVBPrint *buf, const char *text, const char *text_end,
             }
             if (text_pos == m->h.hlit_end) {
                 if (m->box_flags & HCLR_BOX) {
-                    av_bprintf(buf, "{\\2c&H000000&}");
+                    av_bprintf(buf, "{\\2c&H%X&}", RGB_TO_BGR(m->d.color));
                 } else {
-                    av_bprintf(buf, "{\\1c&HFFFFFF&}{\\2c&H000000&}");
+                    av_bprintf(buf, "{\\1c&H%X&}{\\2c&H%X&}",
+                               RGB_TO_BGR(color), RGB_TO_BGR(m->d.color));
                 }
             }
         }