38 const AVFrame *pic,
int *got_packet)
43 int pad = (aligned_width - avctx->
width) * 4;
52 src_line = pic->
data[0];
55 for (i = 0; i < avctx->
height; i++) {
56 uint16_t *
src = (uint16_t *)src_line;
57 for (j = 0; j < avctx->
width; j++) {
59 uint16_t
r = *src++ >> 6;
60 uint16_t
g = *src++ >> 6;
61 uint16_t
b = *src++ >> 6;
63 pixel = (r << 20) | (g << 10) |
b;
65 pixel = (r << 22) | (g << 12) | (b << 2);
67 bytestream_put_le32(&dst, pixel);
69 bytestream_put_be32(&dst, pixel);
88 #if CONFIG_R210_ENCODER
100 #if CONFIG_R10K_ENCODER
112 #if CONFIG_AVRP_ENCODER
int ff_alloc_packet2(AVCodecContext *avctx, AVPacket *avpkt, int64_t size)
Check AVPacket size and/or allocate data.
This structure describes decoded (raw) audio or video data.
AVFrame * coded_frame
the picture in the bitstream
static av_cold int encode_init(AVCodecContext *avctx)
AVFrame * av_frame_alloc(void)
Allocate an AVFrame and set its fields to default values.
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
const char * name
Name of the codec implementation.
Libavcodec external API header.
int flags
A combination of AV_PKT_FLAG values.
enum AVPictureType pict_type
Picture type of the frame.
int width
picture width / height.
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line.
main external API structure.
static av_cold int encode_close(AVCodecContext *avctx)
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
common internal api header.
static int encode_frame(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *pic, int *got_packet)
int key_frame
1 -> keyframe, 0-> not
AVPixelFormat
Pixel format.
This structure stores compressed data.