FFmpeg
xbmenc.c
Go to the documentation of this file.
1 /*
2  * XBM image format
3  *
4  * Copyright (c) 2012 Paul B Mahol
5  *
6  * This file is part of FFmpeg.
7  *
8  * FFmpeg is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Lesser General Public
10  * License as published by the Free Software Foundation; either
11  * version 2.1 of the License, or (at your option) any later version.
12  *
13  * FFmpeg is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16  * Lesser General Public License for more details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with FFmpeg; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21  */
22 
23 #include "libavutil/reverse.h"
24 #include "avcodec.h"
25 #include "codec_internal.h"
26 #include "encode.h"
27 #include "mathops.h"
28 
29 #define ANSI_MIN_READLINE 509
30 
32  const AVFrame *p, int *got_packet)
33 {
34  int i, j, l, commas, ret, size, linesize, lineout, rowsout;
35  const uint8_t *ptr;
36  uint8_t *buf;
37 
38  linesize = lineout = (avctx->width + 7) / 8;
39  commas = avctx->height * linesize;
40 
41  /* ANSI worst case minimum readline is 509 chars. */
42  rowsout = avctx->height;
43  if (lineout > (ANSI_MIN_READLINE / 6)) {
44  lineout = ANSI_MIN_READLINE / 6;
45  rowsout = (commas + lineout - 1) / lineout;
46  }
47 
48  size = rowsout * (lineout * 6 + 1) + 106;
49  if ((ret = ff_alloc_packet(avctx, pkt, size)) < 0)
50  return ret;
51 
52  buf = pkt->data;
53  ptr = p->data[0];
54 
55  buf += snprintf(buf, 32, "#define image_width %u\n", avctx->width);
56  buf += snprintf(buf, 33, "#define image_height %u\n", avctx->height);
57  buf += snprintf(buf, 39, "static unsigned char image_bits[] = {\n");
58  for (i = 0, l = lineout; i < avctx->height; i++) {
59  for (j = 0; j < linesize; j++) {
60  buf += snprintf(buf, 6, " 0x%02X", ff_reverse[*ptr++]);
61  if (--commas <= 0) {
62  buf += snprintf(buf, 2, "\n");
63  break;
64  }
65  buf += snprintf(buf, 2, ",");
66  if (--l <= 0) {
67  buf += snprintf(buf, 2, "\n");
68  l = lineout;
69  }
70  }
71  ptr += p->linesize[0] - linesize;
72  }
73  buf += snprintf(buf, 5, " };\n");
74 
75  pkt->size = buf - pkt->data;
76  *got_packet = 1;
77  return 0;
78 }
79 
81  .p.name = "xbm",
82  CODEC_LONG_NAME("XBM (X BitMap) image"),
83  .p.type = AVMEDIA_TYPE_VIDEO,
84  .p.id = AV_CODEC_ID_XBM,
87  .p.pix_fmts = (const enum AVPixelFormat[]) { AV_PIX_FMT_MONOWHITE,
89 };
AVPixelFormat
AVPixelFormat
Pixel format.
Definition: pixfmt.h:64
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:330
AVPacket::data
uint8_t * data
Definition: packet.h:374
ANSI_MIN_READLINE
#define ANSI_MIN_READLINE
Definition: xbmenc.c:29
encode.h
ff_reverse
const uint8_t ff_reverse[256]
Definition: reverse.c:23
AV_PIX_FMT_MONOWHITE
@ AV_PIX_FMT_MONOWHITE
Y , 1bpp, 0 is white, 1 is black, in each byte pixels are ordered from the msb to the lsb.
Definition: pixfmt.h:75
FFCodec
Definition: codec_internal.h:127
reverse.h
AVFrame::data
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
Definition: frame.h:351
FFCodec::p
AVCodec p
The public AVCodec.
Definition: codec_internal.h:131
FF_CODEC_ENCODE_CB
#define FF_CODEC_ENCODE_CB(func)
Definition: codec_internal.h:315
pkt
AVPacket * pkt
Definition: movenc.c:59
AV_CODEC_CAP_ENCODER_REORDERED_OPAQUE
#define AV_CODEC_CAP_ENCODER_REORDERED_OPAQUE
This encoder can reorder user opaque values from input AVFrames and return them with corresponding ou...
Definition: codec.h:156
CODEC_LONG_NAME
#define CODEC_LONG_NAME(str)
Definition: codec_internal.h:272
mathops.h
xbm_encode_frame
static int xbm_encode_frame(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *p, int *got_packet)
Definition: xbmenc.c:31
AV_CODEC_CAP_DR1
#define AV_CODEC_CAP_DR1
Codec uses get_buffer() or get_encode_buffer() for allocating buffers and supports custom allocators.
Definition: codec.h:52
AVPacket::size
int size
Definition: packet.h:375
codec_internal.h
size
int size
Definition: twinvq_data.h:10344
ff_xbm_encoder
const FFCodec ff_xbm_encoder
Definition: xbmenc.c:80
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:269
AVCodec::name
const char * name
Name of the codec implementation.
Definition: codec.h:191
AVCodecContext::height
int height
Definition: avcodec.h:598
AV_CODEC_ID_XBM
@ AV_CODEC_ID_XBM
Definition: codec_id.h:212
avcodec.h
ret
ret
Definition: filter_design.txt:187
AVCodecContext
main external API structure.
Definition: avcodec.h:426
AV_PIX_FMT_NONE
@ AV_PIX_FMT_NONE
Definition: pixfmt.h:65
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
AVPacket
This structure stores compressed data.
Definition: packet.h:351
AVCodecContext::width
int width
picture width / height.
Definition: avcodec.h:598
AVFrame::linesize
int linesize[AV_NUM_DATA_POINTERS]
For video, a positive or negative value, which is typically indicating the size in bytes of each pict...
Definition: frame.h:375
snprintf
#define snprintf
Definition: snprintf.h:34
ff_alloc_packet
int ff_alloc_packet(AVCodecContext *avctx, AVPacket *avpkt, int64_t size)
Check AVPacket size and allocate data.
Definition: encode.c:35