diff --git a/libheif/plugins/encoder_aom.cc b/libheif/plugins/encoder_aom.cc index f66752a6e6..d1bed0bb23 100644 --- a/libheif/plugins/encoder_aom.cc +++ b/libheif/plugins/encoder_aom.cc @@ -73,6 +73,7 @@ struct encoder_struct_aom bool lossless; bool lossless_alpha; bool auto_tiles; + bool intra_block_copy; #if defined(HAVE_AOM_CODEC_SET_OPTION) std::vector custom_options; @@ -162,6 +163,7 @@ static const char* kParam_alpha_min_q = "alpha-min-q"; static const char* kParam_alpha_max_q = "alpha-max-q"; static const char* kParam_lossless_alpha = "lossless-alpha"; static const char* kParam_auto_tiles = "auto-tiles"; +static const char* kParam_intra_block_copy = "intra-block-copy"; static const char* kParam_threads = "threads"; static const char* kParam_realtime = "realtime"; static const char* kParam_speed = "speed"; @@ -200,7 +202,7 @@ static const char* aom_plugin_name() } -#define MAX_NPARAMETERS 15 +#define MAX_NPARAMETERS 16 static struct heif_encoder_parameter aom_encoder_params[MAX_NPARAMETERS]; static const struct heif_encoder_parameter* aom_encoder_parameter_ptrs[MAX_NPARAMETERS + 1]; @@ -373,6 +375,14 @@ static void aom_init_parameters() p->has_default = true; d[i++] = p++; + assert(i < MAX_NPARAMETERS); + p->version = 2; + p->name = kParam_intra_block_copy; + p->type = heif_encoder_parameter_type_boolean; + p->boolean.default_value = true; + p->has_default = true; + d[i++] = p++; + assert(i < MAX_NPARAMETERS + 1); d[i++] = nullptr; } @@ -585,6 +595,9 @@ struct heif_error aom_set_parameter_boolean(void* encoder_raw, const char* name, } else if (strcmp(name, kParam_auto_tiles) == 0) { encoder->auto_tiles = value; return heif_error_ok; + } else if (strcmp(name, kParam_intra_block_copy) == 0) { + encoder->intra_block_copy = value; + return heif_error_ok; } set_value(kParam_realtime, realtime_mode); @@ -1037,6 +1050,10 @@ struct heif_error aom_encode_image(void* encoder_raw, const struct heif_image* i } #endif +#if defined(AOM_CTRL_AV1E_SET_ENABLE_INTRABC) + aom_codec_control(&codec, AV1E_SET_ENABLE_INTRABC, encoder->intra_block_copy); +#endif + #if defined(HAVE_AOM_CODEC_SET_OPTION) // Apply the custom AOM encoder options. // These should always be applied last as they can override the values that were set above.