diff options
author | Timothy Gu <timothygu99@gmail.com> | 2016-02-01 17:26:10 -0800 |
---|---|---|
committer | Timothy Gu <timothygu99@gmail.com> | 2016-02-02 18:06:13 -0800 |
commit | 13b8ba8c9d1fe3cec854a98b13b025578aa7ac6a (patch) | |
tree | 3a321d9b5d7ad3bc15c961ae1cab514d75dfde11 /libavdevice | |
parent | 228eb6708bd708bd778181ae91a7349eb803fed6 (diff) | |
download | ffmpeg-13b8ba8c9d1fe3cec854a98b13b025578aa7ac6a.tar.gz |
xv: Remove AVPicture usage
Diffstat (limited to 'libavdevice')
-rw-r--r-- | libavdevice/xv.c | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/libavdevice/xv.c b/libavdevice/xv.c index c19c15c234..64cddeb068 100644 --- a/libavdevice/xv.c +++ b/libavdevice/xv.c @@ -291,7 +291,8 @@ static int xv_repaint(AVFormatContext *s) return 0; } -static int write_picture(AVFormatContext *s, AVPicture *pict) +static int write_picture(AVFormatContext *s, uint8_t *input_data[4], + int linesize[4]) { XVContext *xv = s->priv_data; XvImage *img = xv->yuv_image; @@ -313,18 +314,20 @@ static int write_picture(AVFormatContext *s, AVPicture *pict) } } - av_image_copy(data, img->pitches, (const uint8_t **)pict->data, pict->linesize, + av_image_copy(data, img->pitches, (const uint8_t **)input_data, linesize, xv->image_format, img->width, img->height); return xv_repaint(s); } static int xv_write_packet(AVFormatContext *s, AVPacket *pkt) { - AVPicture pict; AVCodecContext *ctx = s->streams[0]->codec; + uint8_t *data[4]; + int linesize[4]; - avpicture_fill(&pict, pkt->data, ctx->pix_fmt, ctx->width, ctx->height); - return write_picture(s, &pict); + av_image_fill_arrays(data, linesize, pkt->data, ctx->pix_fmt, + ctx->width, ctx->height, 1); + return write_picture(s, data, linesize); } static int xv_write_frame(AVFormatContext *s, int stream_index, AVFrame **frame, @@ -333,7 +336,7 @@ static int xv_write_frame(AVFormatContext *s, int stream_index, AVFrame **frame, /* xv_write_header() should have accepted only supported formats */ if ((flags & AV_WRITE_UNCODED_FRAME_QUERY)) return 0; - return write_picture(s, (AVPicture *)*frame); + return write_picture(s, (*frame)->data, (*frame)->linesize); } static int xv_control_message(AVFormatContext *s, int type, void *data, size_t data_size) |