You've already forked FFmpeg
mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-08-10 06:10:52 +02:00
avcodec/libx265: apply some global AVCodecContext settings to the encoder context
There's no reason to ignore them if set. Signed-off-by: James Almer <jamrial@gmail.com>
This commit is contained in:
@@ -2415,6 +2415,20 @@ during configuration. You need to explicitly configure the build with
|
|||||||
@subsection Options
|
@subsection Options
|
||||||
|
|
||||||
@table @option
|
@table @option
|
||||||
|
@item b
|
||||||
|
Sets target video bitrate.
|
||||||
|
|
||||||
|
@item bf
|
||||||
|
|
||||||
|
@item g
|
||||||
|
Set the GOP size.
|
||||||
|
|
||||||
|
@item keyint_min
|
||||||
|
Minimum GOP size.
|
||||||
|
|
||||||
|
@item refs
|
||||||
|
Number of reference frames each P-frame can use. The range is from @var{1-16}.
|
||||||
|
|
||||||
@item preset
|
@item preset
|
||||||
Set the x265 preset.
|
Set the x265 preset.
|
||||||
|
|
||||||
|
@@ -82,10 +82,26 @@ static av_cold int libx265_encode_close(AVCodecContext *avctx)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static av_cold int libx265_param_parse_int(AVCodecContext *avctx,
|
||||||
|
const char *key, int value)
|
||||||
|
{
|
||||||
|
libx265Context *ctx = avctx->priv_data;
|
||||||
|
char buf[256];
|
||||||
|
|
||||||
|
snprintf(buf, sizeof(buf), "%d", value);
|
||||||
|
if (ctx->api->param_parse(ctx->params, key, buf) == X265_PARAM_BAD_VALUE) {
|
||||||
|
av_log(avctx, AV_LOG_ERROR, "Invalid value %d for param \"%s\".\n", value, key);
|
||||||
|
return AVERROR(EINVAL);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static av_cold int libx265_encode_init(AVCodecContext *avctx)
|
static av_cold int libx265_encode_init(AVCodecContext *avctx)
|
||||||
{
|
{
|
||||||
libx265Context *ctx = avctx->priv_data;
|
libx265Context *ctx = avctx->priv_data;
|
||||||
AVCPBProperties *cpb_props = NULL;
|
AVCPBProperties *cpb_props = NULL;
|
||||||
|
int ret;
|
||||||
|
|
||||||
ctx->api = x265_api_get(av_pix_fmt_desc_get(avctx->pix_fmt)->comp[0].depth);
|
ctx->api = x265_api_get(av_pix_fmt_desc_get(avctx->pix_fmt)->comp[0].depth);
|
||||||
if (!ctx->api)
|
if (!ctx->api)
|
||||||
@@ -241,6 +257,27 @@ static av_cold int libx265_encode_init(AVCodecContext *avctx)
|
|||||||
if (!(avctx->flags & AV_CODEC_FLAG_GLOBAL_HEADER))
|
if (!(avctx->flags & AV_CODEC_FLAG_GLOBAL_HEADER))
|
||||||
ctx->params->bRepeatHeaders = 1;
|
ctx->params->bRepeatHeaders = 1;
|
||||||
|
|
||||||
|
if (avctx->gop_size >= 0) {
|
||||||
|
ret = libx265_param_parse_int(avctx, "keyint", avctx->gop_size);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
if (avctx->keyint_min > 0) {
|
||||||
|
ret = libx265_param_parse_int(avctx, "min-keyint", avctx->keyint_min);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
if (avctx->max_b_frames >= 0) {
|
||||||
|
ret = libx265_param_parse_int(avctx, "bframes", avctx->max_b_frames);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
if (avctx->refs >= 0) {
|
||||||
|
ret = libx265_param_parse_int(avctx, "ref", avctx->refs);
|
||||||
|
if (ret < 0)
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
if (ctx->x265_opts) {
|
if (ctx->x265_opts) {
|
||||||
AVDictionary *dict = NULL;
|
AVDictionary *dict = NULL;
|
||||||
AVDictionaryEntry *en = NULL;
|
AVDictionaryEntry *en = NULL;
|
||||||
@@ -556,6 +593,10 @@ static const AVClass class = {
|
|||||||
|
|
||||||
static const AVCodecDefault x265_defaults[] = {
|
static const AVCodecDefault x265_defaults[] = {
|
||||||
{ "b", "0" },
|
{ "b", "0" },
|
||||||
|
{ "bf", "-1" },
|
||||||
|
{ "g", "-1" },
|
||||||
|
{ "keyint_min", "-1" },
|
||||||
|
{ "refs", "-1" },
|
||||||
{ NULL },
|
{ NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user