/* * This file is part of FFmpeg. * * FFmpeg is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * FFmpeg is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with FFmpeg; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ #ifndef AVUTIL_FILM_GRAIN_PARAMS_H #define AVUTIL_FILM_GRAIN_PARAMS_H #include "frame.h" enum AVFilmGrainParamsType { … }; /** * This structure describes how to handle film grain synthesis for AOM codecs. * * @note The struct must be allocated as part of AVFilmGrainParams using * av_film_grain_params_alloc(). Its size is not a part of the public ABI. */ AVFilmGrainAOMParams; /** * This structure describes how to handle film grain synthesis for codecs using * the ITU-T H.274 Versatile suplemental enhancement information message. * * @note The struct must be allocated as part of AVFilmGrainParams using * av_film_grain_params_alloc(). Its size is not a part of the public ABI. */ AVFilmGrainH274Params; /** * This structure describes how to handle film grain synthesis in video * for specific codecs. Must be present on every frame where film grain is * meant to be synthesised for correct presentation. * * @note The struct must be allocated with av_film_grain_params_alloc() and * its size is not a part of the public ABI. */ AVFilmGrainParams; /** * Allocate an AVFilmGrainParams structure and set its fields to * default values. The resulting struct can be freed using av_freep(). * If size is not NULL it will be set to the number of bytes allocated. * * @return An AVFilmGrainParams filled with default values or NULL * on failure. */ AVFilmGrainParams *av_film_grain_params_alloc(size_t *size); /** * Allocate a complete AVFilmGrainParams and add it to the frame. * * @param frame The frame which side data is added to. * * @return The AVFilmGrainParams structure to be filled by caller. */ AVFilmGrainParams *av_film_grain_params_create_side_data(AVFrame *frame); /** * Select the most appropriate film grain parameters set for the frame, * taking into account the frame's format, resolution and video signal * characteristics. * * @note, for H.274, this may select a film grain parameter set with * greater chroma resolution than the frame. Users should take care to * correctly adjust the chroma grain frequency to the frame. */ const AVFilmGrainParams *av_film_grain_params_select(const AVFrame *frame); #endif /* AVUTIL_FILM_GRAIN_PARAMS_H */