|
@@ -33,27 +33,27 @@
|
|
|
#include "libavutil/imgutils.h"
|
|
|
#include "libavutil/samplefmt.h"
|
|
|
|
|
|
-enum PixelFormat choose_pixel_fmt(AVStream *st, AVCodec *codec, enum PixelFormat target)
|
|
|
+enum AVPixelFormat choose_pixel_fmt(AVStream *st, AVCodec *codec, enum AVPixelFormat target)
|
|
|
{
|
|
|
if (codec && codec->pix_fmts) {
|
|
|
- const enum PixelFormat *p = codec->pix_fmts;
|
|
|
+ const enum AVPixelFormat *p = codec->pix_fmts;
|
|
|
int has_alpha= av_pix_fmt_descriptors[target].nb_components % 2 == 0;
|
|
|
- enum PixelFormat best= PIX_FMT_NONE;
|
|
|
+ enum AVPixelFormat best= AV_PIX_FMT_NONE;
|
|
|
if (st->codec->strict_std_compliance <= FF_COMPLIANCE_UNOFFICIAL) {
|
|
|
if (st->codec->codec_id == AV_CODEC_ID_MJPEG) {
|
|
|
- p = (const enum PixelFormat[]) { PIX_FMT_YUVJ420P, PIX_FMT_YUVJ422P, PIX_FMT_YUV420P, PIX_FMT_YUV422P, PIX_FMT_NONE };
|
|
|
+ p = (const enum AVPixelFormat[]) { AV_PIX_FMT_YUVJ420P, AV_PIX_FMT_YUVJ422P, AV_PIX_FMT_YUV420P, AV_PIX_FMT_YUV422P, AV_PIX_FMT_NONE };
|
|
|
} else if (st->codec->codec_id == AV_CODEC_ID_LJPEG) {
|
|
|
- p = (const enum PixelFormat[]) { PIX_FMT_YUVJ420P, PIX_FMT_YUVJ422P, PIX_FMT_YUVJ444P, PIX_FMT_YUV420P,
|
|
|
- PIX_FMT_YUV422P, PIX_FMT_YUV444P, PIX_FMT_BGRA, PIX_FMT_NONE };
|
|
|
+ p = (const enum AVPixelFormat[]) { AV_PIX_FMT_YUVJ420P, AV_PIX_FMT_YUVJ422P, AV_PIX_FMT_YUVJ444P, AV_PIX_FMT_YUV420P,
|
|
|
+ AV_PIX_FMT_YUV422P, AV_PIX_FMT_YUV444P, AV_PIX_FMT_BGRA, AV_PIX_FMT_NONE };
|
|
|
}
|
|
|
}
|
|
|
- for (; *p != PIX_FMT_NONE; p++) {
|
|
|
+ for (; *p != AV_PIX_FMT_NONE; p++) {
|
|
|
best= avcodec_find_best_pix_fmt_of_2(best, *p, target, has_alpha, NULL);
|
|
|
if (*p == target)
|
|
|
break;
|
|
|
}
|
|
|
- if (*p == PIX_FMT_NONE) {
|
|
|
- if (target != PIX_FMT_NONE)
|
|
|
+ if (*p == AV_PIX_FMT_NONE) {
|
|
|
+ if (target != AV_PIX_FMT_NONE)
|
|
|
av_log(NULL, AV_LOG_WARNING,
|
|
|
"Incompatible pixel format '%s' for codec '%s', auto-selecting format '%s'\n",
|
|
|
av_pix_fmt_descriptors[target].name,
|
|
@@ -93,14 +93,14 @@ static char *choose_pix_fmts(OutputStream *ost)
|
|
|
if (ost->filter)
|
|
|
avfilter_graph_set_auto_convert(ost->filter->graph->graph,
|
|
|
AVFILTER_AUTO_CONVERT_NONE);
|
|
|
- if (ost->st->codec->pix_fmt == PIX_FMT_NONE)
|
|
|
+ if (ost->st->codec->pix_fmt == AV_PIX_FMT_NONE)
|
|
|
return NULL;
|
|
|
return av_strdup(av_get_pix_fmt_name(ost->st->codec->pix_fmt));
|
|
|
}
|
|
|
- if (ost->st->codec->pix_fmt != PIX_FMT_NONE) {
|
|
|
+ if (ost->st->codec->pix_fmt != AV_PIX_FMT_NONE) {
|
|
|
return av_strdup(av_get_pix_fmt_name(choose_pixel_fmt(ost->st, ost->enc, ost->st->codec->pix_fmt)));
|
|
|
} else if (ost->enc && ost->enc->pix_fmts) {
|
|
|
- const enum PixelFormat *p;
|
|
|
+ const enum AVPixelFormat *p;
|
|
|
AVIOContext *s = NULL;
|
|
|
uint8_t *ret;
|
|
|
int len;
|
|
@@ -111,14 +111,14 @@ static char *choose_pix_fmts(OutputStream *ost)
|
|
|
p = ost->enc->pix_fmts;
|
|
|
if (ost->st->codec->strict_std_compliance <= FF_COMPLIANCE_UNOFFICIAL) {
|
|
|
if (ost->st->codec->codec_id == AV_CODEC_ID_MJPEG) {
|
|
|
- p = (const enum PixelFormat[]) { PIX_FMT_YUVJ420P, PIX_FMT_YUVJ422P, PIX_FMT_YUV420P, PIX_FMT_YUV422P, PIX_FMT_NONE };
|
|
|
+ p = (const enum AVPixelFormat[]) { AV_PIX_FMT_YUVJ420P, AV_PIX_FMT_YUVJ422P, AV_PIX_FMT_YUV420P, AV_PIX_FMT_YUV422P, AV_PIX_FMT_NONE };
|
|
|
} else if (ost->st->codec->codec_id == AV_CODEC_ID_LJPEG) {
|
|
|
- p = (const enum PixelFormat[]) { PIX_FMT_YUVJ420P, PIX_FMT_YUVJ422P, PIX_FMT_YUVJ444P, PIX_FMT_YUV420P,
|
|
|
- PIX_FMT_YUV422P, PIX_FMT_YUV444P, PIX_FMT_BGRA, PIX_FMT_NONE };
|
|
|
+ p = (const enum AVPixelFormat[]) { AV_PIX_FMT_YUVJ420P, AV_PIX_FMT_YUVJ422P, AV_PIX_FMT_YUVJ444P, AV_PIX_FMT_YUV420P,
|
|
|
+ AV_PIX_FMT_YUV422P, AV_PIX_FMT_YUV444P, AV_PIX_FMT_BGRA, AV_PIX_FMT_NONE };
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- for (; *p != PIX_FMT_NONE; p++) {
|
|
|
+ for (; *p != AV_PIX_FMT_NONE; p++) {
|
|
|
const char *name = av_get_pix_fmt_name(*p);
|
|
|
avio_printf(s, "%s:", name);
|
|
|
}
|
|
@@ -159,7 +159,7 @@ static char *choose_ ## var ## s(OutputStream *ost) \
|
|
|
return NULL; \
|
|
|
}
|
|
|
|
|
|
-// DEF_CHOOSE_FORMAT(enum PixelFormat, pix_fmt, pix_fmts, PIX_FMT_NONE,
|
|
|
+// DEF_CHOOSE_FORMAT(enum AVPixelFormat, pix_fmt, pix_fmts, AV_PIX_FMT_NONE,
|
|
|
// GET_PIX_FMT_NAME, ":")
|
|
|
|
|
|
DEF_CHOOSE_FORMAT(enum AVSampleFormat, sample_fmt, sample_fmts,
|
|
@@ -526,17 +526,17 @@ static int sub2video_prepare(InputStream *ist)
|
|
|
ist->sub2video.w = ist->st->codec->width = w;
|
|
|
ist->sub2video.h = ist->st->codec->height = h;
|
|
|
|
|
|
- /* rectangles are PIX_FMT_PAL8, but we have no guarantee that the
|
|
|
+ /* rectangles are AV_PIX_FMT_PAL8, but we have no guarantee that the
|
|
|
palettes for all rectangles are identical or compatible */
|
|
|
- ist->st->codec->pix_fmt = PIX_FMT_RGB32;
|
|
|
+ ist->st->codec->pix_fmt = AV_PIX_FMT_RGB32;
|
|
|
|
|
|
- ret = av_image_alloc(image, linesize, w, h, PIX_FMT_RGB32, 32);
|
|
|
+ ret = av_image_alloc(image, linesize, w, h, AV_PIX_FMT_RGB32, 32);
|
|
|
if (ret < 0)
|
|
|
return ret;
|
|
|
memset(image[0], 0, h * linesize[0]);
|
|
|
ist->sub2video.ref = avfilter_get_video_buffer_ref_from_arrays(
|
|
|
image, linesize, AV_PERM_READ | AV_PERM_PRESERVE,
|
|
|
- w, h, PIX_FMT_RGB32);
|
|
|
+ w, h, AV_PIX_FMT_RGB32);
|
|
|
if (!ist->sub2video.ref) {
|
|
|
av_free(image[0]);
|
|
|
return AVERROR(ENOMEM);
|