Commit a604289b authored by Niklesh's avatar Niklesh Committed by Philip Langdale

movtextdec: Add support for automatic text wrapping

The value of wrap_flag in the Text Wrap Box specifies if the text is to
be wrapped or not. Uses 'end of line wrap' amongst the wrap styles
supported by ASS if the text is to be wrapped, i.e; fill as much text
in a line as possible, then break to next line.

The 3GPP spec has no provision for smart wrapping.
Signed-off-by: 's avatarNiklesh <niklesh.lalwani@iitb.ac.in>
parent c84d208c
...@@ -36,6 +36,7 @@ ...@@ -36,6 +36,7 @@
#define STYL_BOX (1<<0) #define STYL_BOX (1<<0)
#define HLIT_BOX (1<<1) #define HLIT_BOX (1<<1)
#define HCLR_BOX (1<<2) #define HCLR_BOX (1<<2)
#define TWRP_BOX (1<<3)
#define BOTTOM_LEFT 1 #define BOTTOM_LEFT 1
#define BOTTOM_CENTER 2 #define BOTTOM_CENTER 2
...@@ -80,6 +81,10 @@ typedef struct { ...@@ -80,6 +81,10 @@ typedef struct {
uint8_t hlit_color[4]; uint8_t hlit_color[4];
} HilightcolorBox; } HilightcolorBox;
typedef struct {
uint8_t wrap_flag;
} TextWrapBox;
typedef struct { typedef struct {
StyleBox **s; StyleBox **s;
StyleBox *s_temp; StyleBox *s_temp;
...@@ -87,6 +92,7 @@ typedef struct { ...@@ -87,6 +92,7 @@ typedef struct {
HilightcolorBox c; HilightcolorBox c;
FontRecord **ftab; FontRecord **ftab;
FontRecord *ftab_temp; FontRecord *ftab_temp;
TextWrapBox w;
MovTextDefault d; MovTextDefault d;
uint8_t box_flags; uint8_t box_flags;
uint16_t style_entries, ftab_entries; uint16_t style_entries, ftab_entries;
...@@ -240,6 +246,13 @@ static int mov_text_tx3g(AVCodecContext *avctx, MovTextContext *m) ...@@ -240,6 +246,13 @@ static int mov_text_tx3g(AVCodecContext *avctx, MovTextContext *m)
return 0; return 0;
} }
static int decode_twrp(const uint8_t *tsmb, MovTextContext *m, AVPacket *avpkt)
{
m->box_flags |= TWRP_BOX;
m->w.wrap_flag = *tsmb++;
return 0;
}
static int decode_hlit(const uint8_t *tsmb, MovTextContext *m, AVPacket *avpkt) static int decode_hlit(const uint8_t *tsmb, MovTextContext *m, AVPacket *avpkt)
{ {
m->box_flags |= HLIT_BOX; m->box_flags |= HLIT_BOX;
...@@ -298,7 +311,8 @@ static int decode_styl(const uint8_t *tsmb, MovTextContext *m, AVPacket *avpkt) ...@@ -298,7 +311,8 @@ static int decode_styl(const uint8_t *tsmb, MovTextContext *m, AVPacket *avpkt)
static const Box box_types[] = { static const Box box_types[] = {
{ MKBETAG('s','t','y','l'), 2, decode_styl }, { MKBETAG('s','t','y','l'), 2, decode_styl },
{ MKBETAG('h','l','i','t'), 4, decode_hlit }, { MKBETAG('h','l','i','t'), 4, decode_hlit },
{ MKBETAG('h','c','l','r'), 4, decode_hclr } { MKBETAG('h','c','l','r'), 4, decode_hclr },
{ MKBETAG('t','w','r','p'), 1, decode_twrp }
}; };
const static size_t box_count = FF_ARRAY_ELEMS(box_types); const static size_t box_count = FF_ARRAY_ELEMS(box_types);
...@@ -309,6 +323,15 @@ static int text_to_ass(AVBPrint *buf, const char *text, const char *text_end, ...@@ -309,6 +323,15 @@ static int text_to_ass(AVBPrint *buf, const char *text, const char *text_end,
int i = 0; int i = 0;
int j = 0; int j = 0;
int text_pos = 0; int text_pos = 0;
if (text < text_end && m->box_flags & TWRP_BOX) {
if (m->w.wrap_flag == 1) {
av_bprintf(buf, "{\\q1}"); /* End of line wrap */
} else {
av_bprintf(buf, "{\\q2}"); /* No wrap */
}
}
while (text < text_end) { while (text < text_end) {
if (m->box_flags & STYL_BOX) { if (m->box_flags & STYL_BOX) {
for (i = 0; i < m->style_entries; i++) { for (i = 0; i < m->style_entries; i++) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment