[FFmpeg-devel] [PATCH 3/3] libx265: Add crf private option
Gerion Entrup
gerion.entrup at t-online.de
Wed Feb 18 03:48:20 CET 2015
I guess, this is based on the irc talk. Thank you again!
Cheers,
Gerion
Am Dienstag 17 Februar 2015, 17:02:31 schrieb Derek Buitenhuis:
> Signed-off-by: Derek Buitenhuis <derek.buitenhuis at gmail.com>
> ---
> libavcodec/libx265.c | 13 ++++++++++++-
> 1 file changed, 12 insertions(+), 1 deletion(-)
>
> diff --git a/libavcodec/libx265.c b/libavcodec/libx265.c
> index c35f6c2..0d546d8 100644
> --- a/libavcodec/libx265.c
> +++ b/libavcodec/libx265.c
> @@ -25,6 +25,7 @@
> #endif
>
> #include <x265.h>
> +#include <float.h>
>
> #include "libavutil/internal.h"
> #include "libavutil/common.h"
> @@ -39,6 +40,7 @@ typedef struct libx265Context {
> x265_encoder *encoder;
> x265_param *params;
>
> + float crf;
> char *preset;
> char *tune;
> char *x265_opts;
> @@ -138,7 +140,15 @@ static av_cold int libx265_encode_init(AVCodecContext
> *avctx) break;
> }
>
> - if (avctx->bit_rate > 0) {
> + if (ctx->crf >= 0) {
> + char crf[6];
> +
> + snprintf(crf, sizeof(crf), "%2.2f", ctx->crf);
> + if (x265_param_parse(ctx->params, "crf", crf) ==
> X265_PARAM_BAD_VALUE) { + av_log(avctx, AV_LOG_ERROR, "Invalid
> crf: %2.2f.\n", ctx->crf); + return AVERROR_INVALIDDATA;
> + }
> + } else if (avctx->bit_rate > 0) {
> ctx->params->rc.bitrate = avctx->bit_rate / 1000;
> ctx->params->rc.rateControlMode = X265_RC_ABR;
> }
> @@ -294,6 +304,7 @@ static av_cold void libx265_encode_init_csp(AVCodec
> *codec) #define OFFSET(x) offsetof(libx265Context, x)
> #define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
> static const AVOption options[] = {
> + { "crf", "set the x265 crf",
> OFFSET(crf), AV_OPT_TYPE_FLOAT, { .dbl = -1
> }, -1, FLT_MAX, VE }, { "preset", "set the x265 preset",
> OFFSET(preset),
> AV_OPT_TYPE_STRING, { 0 }, 0, 0, VE }, { "tune", "set the x265 tune
> parameter", OFFSET(tune),
> AV_OPT_TYPE_STRING, { 0 }, 0, 0, VE }, { "x265-params", "set the x265
> configuration using a :-separated list of key=value parameters",
> OFFSET(x265_opts), AV_OPT_TYPE_STRING, { 0 }, 0, 0, VE },
More information about the ffmpeg-devel
mailing list