[FFmpeg-devel] [PATCH 1/2] avcodec/libzvbi-teletextdec: add support for selecting subtitle pages only
Aman Gupta
ffmpeg at tmm1.net
Mon May 7 22:28:28 EEST 2018
On Sun, May 6, 2018 at 2:05 PM, Marton Balint <cus at passwd.hu> wrote:
> Signed-off-by: Marton Balint <cus at passwd.hu>
> ---
> doc/decoders.texi | 5 +++--
> libavcodec/libzvbi-teletextdec.c | 31 ++++++++++++++++++++++---------
> 2 files changed, 25 insertions(+), 11 deletions(-)
>
> diff --git a/doc/decoders.texi b/doc/decoders.texi
> index a551d5d0fd..8f07bc1afb 100644
> --- a/doc/decoders.texi
> +++ b/doc/decoders.texi
> @@ -248,8 +248,9 @@ configuration. You need to explicitly configure the
> build with
>
> @table @option
> @item txt_page
> -List of teletext page numbers to decode. You may use the special * string
> to
> -match all pages. Pages that do not match the specified list are dropped.
> +List of teletext page numbers to decode. Pages that do not match the
> specified
> +list are dropped. You may use the special @code{*} string to match all
> pages,
> +or @code{subtitle} to match all subtitle pages.
>
Thanks for adding this. It works as expected for me.
Might be worth documenting in the AVOption.help text as well.
Aman
> Default value is *.
> @item txt_chop_top
> Discards the top teletext line. Default value is 1.
> diff --git a/libavcodec/libzvbi-teletextdec.c b/libavcodec/libzvbi-
> teletextdec.c
> index a800ad34ae..56a7182882 100644
> --- a/libavcodec/libzvbi-teletextdec.c
> +++ b/libavcodec/libzvbi-teletextdec.c
> @@ -73,6 +73,7 @@ typedef struct TeletextContext
> vbi_sliced sliced[MAX_SLICES];
>
> int readorder;
> + uint8_t subtitle_map[2048];
> } TeletextContext;
>
> static int chop_spaces_utf8(const unsigned char* t, int len)
> @@ -281,16 +282,14 @@ static void handler(vbi_event *ev, void *user_data)
> vbi_page page;
> int res;
> char pgno_str[12];
> - vbi_subno subno;
> - vbi_page_type vpt;
> int chop_top;
> - char *lang;
> + int is_subtitle_page = ctx->subtitle_map[ev->ev.ttx_page.pgno &
> 0x7ff];
>
> snprintf(pgno_str, sizeof pgno_str, "%03x", ev->ev.ttx_page.pgno);
> av_log(ctx, AV_LOG_DEBUG, "decoded page %s.%02x\n",
> pgno_str, ev->ev.ttx_page.subno & 0xFF);
>
> - if (strcmp(ctx->pgno, "*") && !strstr(ctx->pgno, pgno_str))
> + if (strcmp(ctx->pgno, "*") && (strcmp(ctx->pgno, "subtitle") ||
> !is_subtitle_page) && !strstr(ctx->pgno, pgno_str))
> return;
> if (ctx->handler_ret < 0)
> return;
> @@ -303,9 +302,7 @@ static void handler(vbi_event *ev, void *user_data)
> if (!res)
> return;
>
> - vpt = vbi_classify_page(ctx->vbi, ev->ev.ttx_page.pgno, &subno,
> &lang);
> - chop_top = ctx->chop_top ||
> - ((page.rows > 1) && (vpt == VBI_SUBTITLE_PAGE));
> + chop_top = ctx->chop_top || ((page.rows > 1) && is_subtitle_page);
>
> av_log(ctx, AV_LOG_DEBUG, "%d x %d page chop:%d\n",
> page.columns, page.rows, chop_top);
> @@ -357,11 +354,26 @@ static int slice_to_vbi_lines(TeletextContext *ctx,
> uint8_t* buf, int size)
> else {
> int line_offset = buf[2] & 0x1f;
> int field_parity = buf[2] & 0x20;
> - int i;
> + uint8_t *p = ctx->sliced[lines].data;
> + int i, pmag;
> ctx->sliced[lines].id = VBI_SLICED_TELETEXT_B;
> ctx->sliced[lines].line = (line_offset > 0 ? (line_offset
> + (field_parity ? 0 : 313)) : 0);
> for (i = 0; i < 42; i++)
> - ctx->sliced[lines].data[i] = vbi_rev8(buf[4 + i]);
> + p[i] = vbi_rev8(buf[4 + i]);
> + /* Unfortunately libzvbi does not expose page flags, and
> + * vbi_classify_page only checks MIP, so we have to
> manually
> + * decode the page flags and store the results. */
> + pmag = vbi_unham16p(p);
> + if (pmag >= 0 && pmag >> 3 == 0) { // We found a row 0
> header
> + int page = vbi_unham16p(p + 2);
> + int flags1 = vbi_unham16p(p + 6);
> + int flags2 = vbi_unham16p(p + 8);
> + if (page >= 0 && flags1 >= 0 && flags2 >= 0) {
> + int pgno = ((pmag & 7) << 8) + page;
> + // Check for disabled NEWSFLASH flag and enabled
> SUBTITLE and SUPRESS_HEADER flags
> + ctx->subtitle_map[pgno] = (!(flags1 & 0x40) &&
> flags1 & 0x80 && flags2 & 0x01);
> + }
> + }
> lines++;
> }
> }
> @@ -502,6 +514,7 @@ static int teletext_close_decoder(AVCodecContext
> *avctx)
> vbi_decoder_delete(ctx->vbi);
> ctx->vbi = NULL;
> ctx->pts = AV_NOPTS_VALUE;
> + memset(ctx->subtitle_map, 0, sizeof(ctx->subtitle_map));
> if (!(avctx->flags2 & AV_CODEC_FLAG2_RO_FLUSH_NOOP))
> ctx->readorder = 0;
> return 0;
> --
> 2.13.6
>
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel at ffmpeg.org
> http://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
More information about the ffmpeg-devel
mailing list