FFmpeg
[フレーム]
Modules | Files | Data Structures | Enumerations | Functions
AVFrame
Data Structures

AVFrame is an abstraction for reference-counted raw multimedia data. More...

Modules

  Flags describing additional frame properties.
 

Files

file   frame.h
  reference-counted frame API
 

Data Structures

struct   AVFrameSideData
  Structure to hold side data for an AVFrame. More...
 
struct   AVFrame
  This structure describes decoded (raw) audio or video data. More...
 

Enumerations

 
 
enum   { AV_FRAME_CROP_UNALIGNED = 1 << 0 }
  Flags for frame cropping. More...
 

Functions

  Accessors for some AVFrame fields. More...
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
const char *  av_get_colorspace_name (enum AVColorSpace val)
  Get the name of a colorspace. More...
 
  Allocate an AVFrame and set its fields to default values. More...
 
  Free the frame and any dynamically allocated objects in it, e.g. More...
 
int  av_frame_ref (AVFrame *dst, const AVFrame *src)
  Set up a new reference to the data described by the source frame. More...
 
  Create a new frame that references the same data as src. More...
 
  Unreference all the buffers referenced by frame and reset the frame fields. More...
 
  Move everything contained in src to dst and reset src. More...
 
  Allocate new buffer(s) for audio or video data. More...
 
  Check if the frame data is writable. More...
 
  Ensure that the frame data is writable, avoiding data copy if possible. More...
 
int  av_frame_copy (AVFrame *dst, const AVFrame *src)
  Copy the frame data from src to dst. More...
 
  Copy only "metadata" fields from src to dst. More...
 
  Get the buffer reference a given data plane is stored in. More...
 
  Add a new side data to a frame. More...
 
  Add a new side data to a frame from an existing AVBufferRef. More...
 
 
  If side data of the supplied type exists in the frame, free it and remove it from the frame. More...
 
  Crop the given video AVFrame according to its crop_left/crop_top/crop_right/ crop_bottom fields. More...
 
 

Detailed Description

AVFrame is an abstraction for reference-counted raw multimedia data.

Enumeration Type Documentation

Enumerator
AV_FRAME_DATA_PANSCAN 

The data is the AVPanScan struct defined in libavcodec.

AV_FRAME_DATA_A53_CC 

ATSC A53 Part 4 Closed Captions.

A53 CC bitstream is stored as uint8_t in AVFrameSideData.data. The number of bytes of CC data is AVFrameSideData.size.

AV_FRAME_DATA_STEREO3D 

Stereoscopic 3d metadata.

The data is the AVStereo3D struct defined in libavutil/stereo3d.h.

AV_FRAME_DATA_MATRIXENCODING 

The data is the AVMatrixEncoding enum defined in libavutil/channel_layout.h.

AV_FRAME_DATA_DOWNMIX_INFO 

Metadata relevant to a downmix procedure.

The data is the AVDownmixInfo struct defined in libavutil/downmix_info.h.

AV_FRAME_DATA_REPLAYGAIN 

ReplayGain information in the form of the AVReplayGain struct.

AV_FRAME_DATA_DISPLAYMATRIX 

This side data contains a 3x3 transformation matrix describing an affine transformation that needs to be applied to the frame for correct presentation.

See libavutil/display.h for a detailed description of the data.

AV_FRAME_DATA_AFD 

Active Format Description data consisting of a single byte as specified in ETSI TS 101 154 using AVActiveFormatDescription enum.

AV_FRAME_DATA_MOTION_VECTORS 

Motion vectors exported by some codecs (on demand through the export_mvs flag set in the libavcodec AVCodecContext flags2 option).

The data is the AVMotionVector struct defined in libavutil/motion_vector.h.

AV_FRAME_DATA_SKIP_SAMPLES 

Recommmends skipping the specified number of samples.

This is exported only if the "skip_manual" AVOption is set in libavcodec. This has the same format as AV_PKT_DATA_SKIP_SAMPLES.

u32le number of samples to skip from start of this packet
u32le number of samples to skip from end of this packet
u8 reason for start skip
u8 reason for end skip (0=padding silence, 1=convergence)
AV_FRAME_DATA_AUDIO_SERVICE_TYPE 

This side data must be associated with an audio frame and corresponds to enum AVAudioServiceType defined in avcodec.h.

AV_FRAME_DATA_MASTERING_DISPLAY_METADATA 

Mastering display metadata associated with a video frame.

The payload is an AVMasteringDisplayMetadata type and contains information about the mastering display color volume.

AV_FRAME_DATA_GOP_TIMECODE 

The GOP timecode in 25 bit timecode format.

Data format is 64-bit integer. This is set on the first frame of a GOP that has a temporal reference of 0.

AV_FRAME_DATA_SPHERICAL 

The data represents the AVSphericalMapping structure defined in libavutil/spherical.h.

AV_FRAME_DATA_CONTENT_LIGHT_LEVEL 

Content light level (based on CTA-861.3).

This payload contains data in the form of the AVContentLightMetadata struct.

AV_FRAME_DATA_ICC_PROFILE 

The data contains an ICC profile as an opaque octet buffer following the format described by ISO 15076-1 with an optional name defined in the metadata key entry "name".

AV_FRAME_DATA_QP_TABLE_PROPERTIES 

Implementation-specific description of the format of AV_FRAME_QP_TABLE_DATA.

The contents of this side data are undocumented and internal; use av_frame_set_qp_table() and av_frame_get_qp_table() to access this in a meaningful way instead.

AV_FRAME_DATA_QP_TABLE_DATA 

Raw QP table data.

Its format is described by AV_FRAME_DATA_QP_TABLE_PROPERTIES. Use av_frame_set_qp_table() and av_frame_get_qp_table() to access this instead.

Definition at line 48 of file frame.h.

Enumerator
AV_AFD_SAME 
AV_AFD_4_3 
AV_AFD_16_9 
AV_AFD_14_9 
AV_AFD_4_3_SP_14_9 
AV_AFD_16_9_SP_14_9 
AV_AFD_SP_4_3 

Definition at line 163 of file frame.h.

anonymous enum

Flags for frame cropping.

Enumerator
AV_FRAME_CROP_UNALIGNED 

Apply the maximum possible cropping, even if it requires setting the AVFrame.data[] entries to unaligned pointers.

Passing unaligned data to FFmpeg API is generally not allowed, and causes undefined behavior (such as crashes). You can pass unaligned data only to FFmpeg APIs that are explicitly documented to accept it. Use this flag only if you absolutely know what you are doing.

Definition at line 854 of file frame.h.

Function Documentation

attribute_deprecated int64_t av_frame_get_best_effort_timestamp ( const AVFrameframe )

Accessors for some AVFrame fields.

These used to be provided for ABI compatibility, and do not need to be used anymore.

attribute_deprecated void av_frame_set_best_effort_timestamp ( AVFrameframe,
int64_t  val 
)
attribute_deprecated int64_t av_frame_get_pkt_duration ( const AVFrameframe )
attribute_deprecated void av_frame_set_pkt_duration ( AVFrameframe,
int64_t  val 
)
attribute_deprecated int64_t av_frame_get_pkt_pos ( const AVFrameframe )
attribute_deprecated void av_frame_set_pkt_pos ( AVFrameframe,
int64_t  val 
)
attribute_deprecated int64_t av_frame_get_channel_layout ( const AVFrameframe )
attribute_deprecated void av_frame_set_channel_layout ( AVFrameframe,
int64_t  val 
)
attribute_deprecated int av_frame_get_channels ( const AVFrameframe )
attribute_deprecated void av_frame_set_channels ( AVFrameframe,
int  val 
)
attribute_deprecated int av_frame_get_sample_rate ( const AVFrameframe )
attribute_deprecated void av_frame_set_sample_rate ( AVFrameframe,
int  val 
)
attribute_deprecated AVDictionary* av_frame_get_metadata ( const AVFrameframe )
attribute_deprecated void av_frame_set_metadata ( AVFrameframe,
AVDictionaryval 
)
attribute_deprecated int av_frame_get_decode_error_flags ( const AVFrameframe )
attribute_deprecated void av_frame_set_decode_error_flags ( AVFrameframe,
int  val 
)
attribute_deprecated int av_frame_get_pkt_size ( const AVFrameframe )
attribute_deprecated void av_frame_set_pkt_size ( AVFrameframe,
int  val 
)
attribute_deprecated int8_t* av_frame_get_qp_table ( AVFramef,
intstride,
inttype 
)

Definition at line 90 of file frame.c.

Referenced by filter_frame(), and pp_filter_frame().

attribute_deprecated int av_frame_set_qp_table ( AVFramef,
AVBufferRefbuf,
int  stride,
int  type 
)

Definition at line 54 of file frame.c.

Referenced by ff_mjpeg_decode_frame(), ff_mpv_export_qp_table(), and filter_frame().

attribute_deprecated enum AVColorSpace av_frame_get_colorspace ( const AVFrameframe )
attribute_deprecated void av_frame_set_colorspace ( AVFrameframe,
enum AVColorSpace  val 
)
attribute_deprecated enum AVColorRange av_frame_get_color_range ( const AVFrameframe )
attribute_deprecated void av_frame_set_color_range ( AVFrameframe,
enum AVColorRange  val 
)
const char* av_get_colorspace_name ( enum AVColorSpace  val )

Get the name of a colorspace.

Returns
a static string identifying the colorspace; can be NULL.

Definition at line 122 of file frame.c.

Referenced by avcodec_string().

AVFrame* av_frame_alloc ( void  )

Allocate an AVFrame and set its fields to default values.

The resulting struct must be freed using av_frame_free().

Returns
An AVFrame filled with default values or NULL on failure.
Note
this only allocates the AVFrame itself, not the data buffers. Those must be allocated through other means, e.g. with av_frame_get_buffer() or manually.

Definition at line 189 of file frame.c.

Referenced by aasc_decode_init(), alloc_audio_frame(), alloc_frame(), alloc_frame_empty(), alloc_picture(), amf_load_library(), apng_encode_frame(), audio_thread(), av_buffersrc_add_frame_flags(), av_buffersrc_add_frame_internal(), av_frame_clone(), av_hwframe_get_buffer(), avcodec_encode_audio2(), avcodec_open2(), avs_decode_init(), bethsoftvid_decode_init(), cdg_decode_init(), cinepak_decode_init(), cinepak_encode_init(), cinvideo_decode_init(), clv_decode_init(), cmv_decode_init(), config_input(), config_output(), cpia_decode_init(), create_cv_pixel_buffer(), cudascale_filter_frame(), cudascale_init(), cuvid_output_frame(), dec_enc(), decode_audio(), decode_entropy_coded_image(), decode_init(), decode_video(), decode_write(), dirac_decode_init(), do_video_out(), downscale(), drm_transfer_data_from(), drm_transfer_data_to(), dxva2_transfer_data_from(), dxva2_transfer_data_to(), encode_apng(), encode_frame(), encode_init(), escape124_decode_init(), ff_cavs_init(), ff_default_get_video_buffer(), ff_ffv1_common_init(), ff_frame_pool_get(), ff_frame_thread_init(), ff_hwframe_map_create(), ff_libwebp_get_frame(), ff_load_image(), ff_mjpeg_decode_init(), ff_mpv_common_init(), ff_mpv_encode_init(), ff_thread_video_encode_frame(), ff_vaapi_encode2(), ff_vp56_init_context(), ffat_init_encoder(), fic_decode_init(), filter_encode_write_frame(), flashsv_decode_init(), flic_decode_init(), frame_queue_init(), get_free_frame(), get_surface(), gif_decode_init(), gif_encode_frame(), h264_init_context(), hevc_init_context(), hwaccel_retrieve_data(), hwframe_pool_prealloc(), hwmap_filter_frame(), hwmap_get_buffer(), init(), init_axis_from_file(), init_axis_from_font(), init_frames(), init_input_frame(), init_output_frame(), ipvideo_decode_init(), ir2_decode_init(), kmsgrab_read_packet(), lavfi_read_header(), LLVMFuzzerTestOneInput(), main(), mca(), mimic_decode_init(), mm_decode_init(), movie_push_frame(), mp_decode_init(), msrle_decode_init(), mss1_decode_init(), mss2_decode_init(), mss3_decode_init(), mss4_decode_init(), msvideo1_decode_init(), mxpeg_decode_init(), nppscale_filter_frame(), nppscale_init(), nvenc_alloc_surface(), pad_last_frame(), paf_video_init(), png_dec_init(), qsv_frame_lock(), qsv_map_from(), qsv_transfer_data_child(), qtrle_decode_init(), qtrle_encode_init(), query_frame(), read_interval_packets(), reap_filters(), reget_buffer_internal(), roq_decode_init(), roq_encode_init(), rpza_decode_init(), rscc_init(), run_test(), screenpresso_init(), seek_test(), sender_thread(), seqvideo_decode_init(), smc_decode_init(), smvjpeg_decode_init(), spawn_empty_frame(), sub2video_prepare(), svq1_decode_init(), svq1_encode_init(), svq3_decode_init(), tdsc_init(), tgv_decode_init(), transfer_data_alloc(), truemotion1_decode_init(), try_decode_frame(), try_decode_video_frame(), try_push_frame(), tscc2_decode_init(), ulti_decode_init(), vaapi_encode_issue(), vaapi_transfer_data_from(), vaapi_transfer_data_to(), vc1_decode_init(), video_decode(), video_decode_example(), video_thread(), videotoolbox_init(), vmdvideo_decode_init(), vp8_init_frames(), vp8_lossy_decode_alpha(), vt_transfer_data_from(), vt_transfer_data_to(), vtenc_populate_extradata(), xan_decode_init(), xma_decode_init(), xvid_encode_init(), yop_decode_init(), and zerocodec_decode_init().

void av_frame_free ( AVFrame **  frame )

Free the frame and any dynamically allocated objects in it, e.g.

extended_data. If the frame is reference counted, it will be unreferenced first.

Parameters
frame frame to be freed. The pointer will be set to NULL.

Definition at line 202 of file frame.c.

Referenced by aasc_decode_end(), activate(), add_to_queue(), alloc_frame(), alloc_frame_empty(), amf_release_buffer_with_frame_ref(), apng_encode_frame(), apply_lut(), apply_palette(), audio_thread(), av_buffersrc_add_frame_flags(), av_buffersrc_add_frame_internal(), av_frame_clone(), av_hwframe_get_buffer(), avcodec_close(), avcodec_encode_audio2(), avfilter_link_free(), avgblur_opencl_filter_frame(), avs_decode_end(), bethsoftvid_decode_end(), blend_frame(), cdg_decode_end(), celt_frame_setup_input(), channelmap_filter_frame(), cinepak_decode_end(), cinepak_encode_end(), cinepak_encode_init(), cinvideo_decode_end(), clear_frame_list(), clear_unused_frames(), close_stream(), clv_decode_end(), cmv_decode_end(), cmv_decode_init(), common_uninit(), compand_delay(), compand_nodelay(), config_output(), config_video(), config_video_output(), configure_filtergraph(), convert_coeffs(), convolution_opencl_filter_frame(), copy_context_reset(), cpia_decode_end(), create_cv_pixel_buffer(), cudascale_filter_frame(), cudascale_uninit(), cudaupload_filter_frame(), cuvid_output_frame(), dec_enc(), decimate_uninit(), decklink_write_video_packet(), decode_close(), decode_end(), decode_init(), decode_write(), deint_vaapi_filter_frame(), deint_vaapi_pipeline_uninit(), dirac_decode_end(), dirac_decode_init(), do_video_out(), downscale(), drm_transfer_data_from(), drm_transfer_data_to(), dxva2_transfer_data_from(), dxva2_transfer_data_to(), empty_buffer_done(), encode_apng(), encode_end(), encode_frame(), encode_write_frame(), end_last_frame(), escape124_decode_close(), ff_amf_encode_close(), ff_bufqueue_add(), ff_bufqueue_discard_all(), ff_cavs_end(), ff_default_get_video_buffer(), ff_ffv1_close(), ff_filter_frame(), ff_filter_frame_framed(), ff_frame_pool_get(), ff_frame_thread_free(), ff_framequeue_free(), ff_framesync_dualinput_get(), ff_framesync_dualinput_get_writable(), ff_framesync_get_frame(), ff_framesync_uninit(), ff_hwframe_map_create(), ff_hwframe_unmap(), ff_inlink_make_frame_writable(), ff_inlink_set_status(), ff_ivi_decode_close(), ff_load_image(), ff_mjpeg_decode_end(), ff_mpv_common_end(), ff_mpv_encode_end(), ff_nvenc_encode_close(), ff_qsv_decode_close(), ff_qsv_enc_close(), ff_qsvvpp_filter_frame(), ff_snow_common_end(), ff_thread_video_encode_frame(), ff_vc1_decode_end(), ff_vp56_free_context(), ff_vp8_decode_free(), ffat_close_encoder(), ffmpeg_cleanup(), fic_decode_close(), fic_decode_frame(), fieldmatch_uninit(), filter_encode_write_frame(), filter_frame(), filter_frame16(), filter_frame8(), fir_frame(), fixstride(), flashsv_decode_end(), flic_decode_end(), flush_frame(), frame_queue_destory(), framepack_uninit(), framesync_advance(), free_avframe(), free_frame(), geq_filter_frame(), get_best_frame(), get_scene_score(), gif_decode_close(), gif_encode_close(), h264_decode_end(), hevc_decode_free(), hwaccel_retrieve_data(), hwdownload_filter_frame(), hwframe_pool_prealloc(), hwmap_filter_frame(), hwmap_get_buffer(), hwupload_filter_frame(), if(), ifilter_send_frame(), image_ctx_free(), init_axis_from_file(), init_axis_from_font(), init_frames(), init_output_frame(), inject_frame(), ipvideo_decode_end(), ipvideo_decode_init(), ir2_decode_end(), join_uninit(), kmsgrab_free_frame(), lavfi_read_close(), libopenjpeg_encode_frame(), libwebp_anim_encode_close(), libwebp_anim_encode_frame(), libwebp_encode_close(), libwebp_encode_frame(), LLVMFuzzerTestOneInput(), load_apply_palette(), load_encode_and_write(), magy_encode_frame(), main(), mimic_decode_end(), misc_vaapi_filter_frame(), mm_decode_end(), move_audio(), movie_push_frame(), mp_decode_end(), msrle_decode_end(), mss1_decode_end(), mss1_decode_init(), mss2_decode_end(), mss3_decode_end(), mss3_decode_init(), mss4_decode_end(), msvideo1_decode_end(), mxpeg_decode_end(), ndi_write_trailer(), ndi_write_video_packet(), nppscale_filter_frame(), nppscale_uninit(), null_filter_frame(), nvenc_alloc_surface(), output_frame(), output_single_frame(), overlay_opencl_blend(), pad_last_frame(), paf_video_close(), pixscope_filter_frame(), plot_freqs(), png_dec_end(), png_dec_init(), png_enc_close(), pp_filter_frame(), procamp_vaapi_filter_frame(), process_frame(), program_opencl_run(), qsv_frame_lock(), qsv_frame_unlock(), qsv_map_from(), qsv_transfer_data_child(), qsvdeint_filter_frame(), qsvdeint_uninit(), qsvscale_filter_frame(), qtrle_decode_end(), qtrle_encode_end(), read_decode_convert_and_store(), read_interval_packets(), read_ir(), receiver_thread(), reget_buffer_internal(), decklink_frame::Release(), request_frame(), return_audio_frame(), return_or_keep_frame(), roq_decode_end(), roq_decode_init(), roq_encode_end(), rpza_decode_end(), rscc_close(), run_test(), scale_vaapi_filter_frame(), screenpresso_close(), seek_test(), sender_thread(), seqvideo_decode_end(), shuffleplanes_filter_frame(), smc_decode_end(), smvjpeg_decode_end(), smvjpeg_decode_init(), spawn_empty_frame(), submit_frame(), svq1_decode_end(), svq1_encode_end(), svq3_decode_end(), take_samples(), tdsc_close(), tgv_decode_end(), transfer_data_alloc(), truemotion1_decode_end(), truemotion1_decode_init(), try_decode_frame(), try_decode_video_frame(), try_push_frame(), try_push_frames(), tscc2_decode_end(), ulti_decode_end(), uninit(), unsharp_opencl_filter_frame(), vaapi_encode_free(), vaapi_encode_issue(), vaapi_encode_wait(), vaapi_transfer_data_from(), vaapi_transfer_data_to(), video_decode(), video_decode_example(), video_thread(), videotoolbox_uninit(), vmdvideo_decode_end(), vp3_decode_end(), vp8_lossy_decode_alpha(), vp9_decode_free(), vt_transfer_data_from(), vt_transfer_data_to(), vtenc_populate_extradata(), worker(), wrapped_avframe_encode(), wrapped_avframe_release_buffer(), write_frame(), write_packet(), xan_decode_end(), xma_decode_end(), xvid_encode_init(), yae_clear(), yop_decode_close(), and zerocodec_decode_close().

int av_frame_ref ( AVFramedst,
const AVFramesrc 
)

Set up a new reference to the data described by the source frame.

Copy frame properties from src to dst and create a new reference for each AVBufferRef from src.

If src is not reference counted, new buffers are allocated and the data is copied.

Warning
: dst MUST have been either unreferenced with av_frame_unref(dst), or newly allocated with av_frame_alloc() before calling this function, or undefined behavior will occur.
Returns
0 on success, a negative AVERROR on error

Definition at line 441 of file frame.c.

Referenced by aasc_decode_frame(), av_buffersrc_add_frame_flags(), av_buffersrc_add_frame_internal(), av_frame_clone(), av_hwframe_map(), avs_decode_frame(), bethsoftvid_decode_frame(), cavs_decode_frame(), cdg_decode_frame(), cinepak_decode_frame(), cinvideo_decode_frame(), clv_decode_frame(), cmv_decode_frame(), cpia_decode_frame(), create_cv_pixel_buffer(), decode_frame(), dirac_decode_frame(), do_video_out(), do_vmaf(), encode_apng(), encode_frame(), escape124_decode_frame(), ff_amf_send_frame(), ff_h263_decode_frame(), ff_hevc_output_frame(), ff_hwframe_map_create(), ff_mjpeg_decode_frame(), ff_rv34_decode_frame(), ff_thread_ref_frame(), ff_thread_video_encode_frame(), ff_vaapi_encode2(), ff_vp56_decode_frame(), ff_vp56_decode_mbs(), ffat_encode_callback(), fic_decode_frame(), finish_frame(), flashsv_decode_frame(), flic_decode_frame_15_16BPP(), flic_decode_frame_24BPP(), flic_decode_frame_8BPP(), get_delayed_pic(), gif_decode_frame(), gif_encode_frame(), h261_decode_frame(), ipvideo_decode_frame(), ir2_decode_frame(), load_input_picture(), mimic_decode_frame(), mjpegb_decode_frame(), mm_decode_frame(), mp_decode_frame(), mpeg_decode_frame(), msrle_decode_frame(), mss1_decode_frame(), mss2_decode_frame(), mss3_decode_frame(), mss4_decode_frame(), msvideo1_decode_frame(), mxpeg_decode_frame(), nvenc_upload_frame(), output_frame(), paf_video_decode(), qsv_decode(), qtrle_decode_frame(), qtrle_encode_frame(), return_or_keep_frame(), roq_decode_frame(), rpza_decode_frame(), rscc_decode_frame(), rv10_decode_frame(), screenpresso_decode_frame(), send_frame_to_filters(), seqvideo_decode_frame(), slice_end(), smc_decode_frame(), smvjpeg_decode_frame(), submit_frame(), svq1_decode_frame(), svq3_decode_frame(), tgv_decode_frame(), truemotion1_decode_frame(), tscc2_decode_frame(), ulti_decode_frame(), vc1_decode_frame(), vmdvideo_decode_frame(), vp78_decode_frame(), vp9_decode_frame(), xan_decode_frame(), yop_decode_frame(), and zerocodec_decode_frame().

AVFrame* av_frame_clone ( const AVFramesrc )

Create a new frame that references the same data as src.

This is a shortcut for av_frame_alloc()+av_frame_ref().

Returns
newly created AVFrame on success, NULL on error.

Definition at line 538 of file frame.c.

Referenced by amf_create_buffer_with_frame_ref(), apply_palette(), create_weave_frame(), decklink_write_video_packet(), end_last_frame(), ff_framesync_get_frame(), ff_libwebp_get_frame(), ffat_encode(), fic_decode_frame(), filter_frame(), filter_frame16(), filter_frame8(), get_scene_score(), ifilter_send_frame(), init(), libopenjpeg_encode_frame(), magy_encode_frame(), ndi_write_video_packet(), omx_encode_frame(), opus_encode_frame(), plot_spectrum_column(), process_frame(), process_work_frame(), request_frame(), return_audio_frame(), submit_frame(), vorbis_encode_frame(), wrapped_avframe_encode(), and write_frame().

void av_frame_unref ( AVFrameframe )

Unreference all the buffers referenced by frame and reset the frame fields.

Definition at line 551 of file frame.c.

Referenced by aac_decode_frame_int(), audio_get_buffer(), av_frame_free(), av_frame_make_writable(), av_frame_ref(), av_hwframe_map(), avcodec_flush_buffers(), avcodec_receive_frame(), cavs_decode_frame(), cdg_decode_frame(), clear_unused_frames(), cmv_decode_frame(), cmv_process_header(), codec_reinit(), cuda_get_buffer(), decode_frame(), decode_packet(), decode_pic(), decode_receive_frame_internal(), decode_subframe(), decode_video(), dirac_decode_data_unit(), dirac_decode_frame(), do_video_out(), encode_apng(), encode_frame(), escape124_decode_frame(), execute_code(), ff_amf_receive_packet(), ff_mjpeg_decode_end(), ff_mjpeg_decode_sof(), ff_mpeg_unref_picture(), ff_snow_release_buffer(), ff_thread_flush(), ff_thread_release_buffer(), ff_v4l2_buffer_buf_to_avframe(), ff_vp56_decode_frame(), ff_vp56_decode_mbs(), ffat_encode_callback(), fixstride(), flashsv_decode_frame(), frame_configure_elements(), frame_end(), frame_queue_unref_item(), frame_worker_thread(), free_picture(), free_sequence_buffers(), get_audio_buffer(), get_buffer_internal(), get_video_buffer(), get_video_frame(), gif_decode_frame(), gif_encode_frame(), hevc_frame_start(), hwaccel_retrieve_data(), ifilter_send_frame(), init_stage(), ipvideo_decode_frame(), lavfi_read_packet(), LLVMFuzzerTestOneInput(), main(), mpeg_decode_frame(), mss2_decode_frame(), mxpeg_decode_frame(), nvenc_upload_frame(), process_output_surface(), qsv_clear_unused_frames(), qtrle_encode_frame(), reap_filters(), reget_buffer_internal(), release_delayed_buffers(), decklink_output_callback::ScheduledFrameCompleted(), select_input_picture(), smvjpeg_decode_frame(), sub2video_get_blank_frame(), submit_frame(), svq1_decode_frame(), svq1_flush(), svq3_decode_frame(), synth_superframe(), tdsc_decode_jpeg_tile(), tgv_decode_frame(), truemotion1_decode_header(), unrefcount_frame(), video_get_buffer(), video_thread(), videotoolbox_postproc_frame(), videotoolbox_retrieve_data(), videotoolbox_set_frame(), vmdvideo_decode_frame(), vorbis_decode_frame(), vtenc_populate_extradata(), worker(), wrapped_avframe_decode(), xan_decode_frame(), and zerocodec_decode_frame().

void av_frame_move_ref ( AVFramedst,
AVFramesrc 
)

Move everything contained in src to dst and reset src.

Warning
: dst is not unreferenced, but directly overwritten without reading or deallocating its contents. Call av_frame_unref(dst) manually before calling this function to ensure that no memory is leaked.

Definition at line 580 of file frame.c.

Referenced by audio_thread(), av_buffersrc_add_frame_internal(), avcodec_receive_frame(), cavs_decode_frame(), cmv_decode_frame(), cudascale_scale(), decode_frame(), decode_packet(), ff_ivi_decode_frame(), ff_thread_decode_frame(), ff_thread_release_buffer(), fixstride(), hevc_decode_frame(), hwaccel_retrieve_data(), nppscale_scale(), queue_picture(), reget_buffer_internal(), return_or_keep_frame(), transfer_data_alloc(), unrefcount_frame(), videotoolbox_retrieve_data(), wrapped_avframe_decode(), and wrapped_avframe_encode().

int av_frame_get_buffer ( AVFrameframe,
int  align 
)

Allocate new buffer(s) for audio or video data.

The following fields must be set on frame before calling this function:

  • format (pixel format for video, sample format for audio)
  • width and height for video
  • nb_samples and channel_layout for audio

This function will fill AVFrame.data and AVFrame.buf arrays and, if necessary, allocate and fill AVFrame.extended_data and AVFrame.extended_buf. For planar formats, one buffer will be allocated for each plane.

Warning
: if frame already has been allocated, calling this function will leak memory. In addition, undefined behavior can occur in certain cases.
Parameters
frame frame in which to store the new buffers.
align Required buffer size alignment. If equal to 0, alignment will be chosen automatically for the current CPU. It is highly recommended to pass 0 here unless you know what you are doing.
Returns
0 on success, a negative AVERROR on error.

Definition at line 322 of file frame.c.

Referenced by alloc_audio_frame(), alloc_frame(), alloc_frame_empty(), alloc_picture(), apng_encode_frame(), av_frame_make_writable(), av_frame_ref(), avresample_convert_frame(), config_input(), config_output(), decode_entropy_coded_image(), downscale(), encode_apng(), encode_frame(), ff_libwebp_get_frame(), ff_mpv_encode_init(), get_input(), init_output_frame(), main(), pad_last_frame(), run_test(), sender_thread(), spawn_empty_frame(), sub2video_get_blank_frame(), swr_convert_frame(), tdsc_parse_tdsf(), transfer_data_alloc(), and videotoolbox_retrieve_data().

int av_frame_is_writable ( AVFrameframe )

Check if the frame data is writable.

Returns
A positive value if the frame data is writable (which is true if and only if each of the underlying buffers has only one reference, namely the one stored in this frame). Return 0 otherwise.

If 1 is returned the answer is valid until av_buffer_ref() is called on any of the underlying AVBufferRefs (e.g. through av_frame_ref() or directly).

See Also
av_frame_make_writable(), av_buffer_is_writable()

Definition at line 592 of file frame.c.

Referenced by apply_lut(), av_frame_make_writable(), compand_nodelay(), ff_inlink_make_frame_writable(), filter_frame(), frame_needs_copy(), and reget_buffer_internal().

int av_frame_make_writable ( AVFrameframe )

Ensure that the frame data is writable, avoiding data copy if possible.

Do nothing if the frame is writable, allocate new buffers and copy the data if it is not.

Returns
0 on success, a negative AVERROR on error.
See Also
av_frame_is_writable(), av_buffer_is_writable(), av_buffer_make_writable()

Definition at line 609 of file frame.c.

Referenced by apply_palette(), ff_framesync_get_frame(), ff_h263_decode_frame(), ff_print_debug_info2(), filter_frame(), filter_frame16(), filter_frame8(), main(), plot_spectrum_column(), and write_audio_frame().

int av_frame_copy ( AVFramedst,
const AVFramesrc 
)

Copy the frame data from src to dst.

This function does not allocate anything, dst must be already initialized and allocated with the same parameters as src.

This function only copies the frame data (i.e. the contents of the data / extended data arrays), not any other properties.

Returns
>= 0 on success, a negative AVERROR on error.

Definition at line 790 of file frame.c.

Referenced by apng_encode_frame(), av_frame_make_writable(), av_frame_ref(), clv_decode_frame(), decode_frame(), drm_transfer_data_from(), drm_transfer_data_to(), encode_apng(), encode_frame(), ff_libwebp_get_frame(), filter_frame(), interpolate(), pixscope_filter_frame(), reget_buffer_internal(), roq_decode_frame(), shuffleplanes_filter_frame(), submit_frame(), tdsc_decode_frame(), vaapi_transfer_data_from(), vaapi_transfer_data_to(), vt_transfer_data_from(), and vt_transfer_data_to().

int av_frame_copy_props ( AVFramedst,
const AVFramesrc 
)

Copy only "metadata" fields from src to dst.

Metadata for the purpose of this function are those fields that do not affect the data layout in the buffers. E.g. pts, sample rate (for audio) or sample aspect ratio (for video), but not width/height or channel layout. Side data is also copied.

Definition at line 652 of file frame.c.

Referenced by apply_lut(), apply_palette(), av_frame_make_writable(), avgblur_opencl_filter_frame(), blend_frame(), blend_frames(), compand_delay(), compand_nodelay(), convolution_opencl_filter_frame(), create_weave_frame(), cudascale_scale(), cudaupload_filter_frame(), deint_vaapi_filter_frame(), drm_map_from(), dxva2_map_from(), ff_inlink_make_frame_writable(), filter(), filter_frame(), fixstride(), frame_end(), geq_filter_frame(), get_frame(), hwaccel_retrieve_data(), hwdownload_filter_frame(), hwmap_filter_frame(), hwupload_filter_frame(), load_input_picture(), misc_vaapi_filter_frame(), nppscale_scale(), overlay_opencl_blend(), pad_last_frame(), pixscope_filter_frame(), pp_filter_frame(), procamp_vaapi_filter_frame(), process_frame(), program_opencl_run(), qsvscale_filter_frame(), return_frame(), scale_vaapi_filter_frame(), select_input_picture(), shuffleplanes_filter_frame(), submit_frame(), take_samples(), try_push_frame(), unrefcount_frame(), unsharp_opencl_filter_frame(), vaapi_map_to_memory(), and videotoolbox_retrieve_data().

AVBufferRef* av_frame_get_plane_buffer ( AVFrameframe,
int  plane 
)

Get the buffer reference a given data plane is stored in.

Parameters
plane index of the data plane of interest in frame->extended_data.
Returns
the buffer reference that contains the plane or NULL if the input frame is not valid.

Definition at line 657 of file frame.c.

Referenced by buffer_needs_copy(), and try_push_frame().

AVFrameSideData* av_frame_new_side_data ( AVFrameframe,
enum AVFrameSideDataType  type,
int  size 
)

Add a new side data to a frame.

Parameters
frame a frame to which the side data should be added
type type of the added side data
size size of the side data
Returns
newly added side data on success, NULL on error

Definition at line 720 of file frame.c.

Referenced by av_content_light_metadata_create_side_data(), av_downmix_info_update_side_data(), av_frame_set_qp_table(), av_mastering_display_metadata_create_side_data(), av_stereo3d_create_side_data(), decode_frame(), decode_iccp_chunk(), ff_decode_frame_props(), ff_mjpeg_decode_frame(), ff_print_debug_info2(), ff_side_data_update_matrix_encoding(), filter_frame(), frame_copy_props(), h264_export_frame_props(), mpeg_decode_frame(), mpeg_field_start(), set_side_data(), and webp_decode_frame().

AVFrameSideData* av_frame_new_side_data_from_buf ( AVFrameframe,
enum AVFrameSideDataType  type,
AVBufferRefbuf 
)

Add a new side data to a frame from an existing AVBufferRef.

Parameters
frame a frame to which the side data should be added
type the type of the added side data
buf an AVBufferRef to add as side data. The ownership of the reference is transferred to the frame.
Returns
newly added side data on success, NULL on error. On failure the frame is unchanged and the AVBufferRef remains owned by the caller.

Definition at line 688 of file frame.c.

Referenced by av_frame_new_side_data(), av_frame_set_qp_table(), and frame_copy_props().

AVFrameSideData* av_frame_get_side_data ( const AVFrameframe,
enum AVFrameSideDataType  type 
)
Returns
a pointer to the side data of a given type on success, NULL if there is no side data with such type in this frame.

Definition at line 732 of file frame.c.

Referenced by av_downmix_info_update_side_data(), av_frame_get_qp_table(), avcodec_encode_audio2(), decode_packet(), determine_signal_peak(), encode_headers(), ff_alloc_a53_sei(), ff_mpeg1_encode_picture_header(), ff_side_data_update_matrix_encoding(), filter_frame(), mpeg1_encode_sequence_header(), reconfig_encoder(), and vtenc_send_frame().

void av_frame_remove_side_data ( AVFrameframe,
enum AVFrameSideDataType  type 
)

If side data of the supplied type exists in the frame, free it and remove it from the frame.

Definition at line 803 of file frame.c.

Referenced by av_frame_set_qp_table(), and filter_frame().

int av_frame_apply_cropping ( AVFrameframe,
int  flags 
)

Crop the given video AVFrame according to its crop_left/crop_top/crop_right/ crop_bottom fields.

If cropping is successful, the function will adjust the data pointers and the width/height fields, and set the crop fields to 0.

In all cases, the cropping boundaries will be rounded to the inherent alignment of the pixel format. In some cases, such as for opaque hwaccel formats, the left/top cropping is ignored. The crop fields are set to 0 even if the cropping was rounded or ignored.

Parameters
frame the frame which should be cropped
flags Some combination of AV_FRAME_CROP_* flags, or 0.
Returns
>= 0 on success, a negative AVERROR on error. If the cropping fields were invalid, AVERROR(ERANGE) is returned, and nothing is changed.

Definition at line 873 of file frame.c.

Referenced by apply_cropping().

const char* av_frame_side_data_name ( enum AVFrameSideDataType  type )
Returns
a string identifying the side data type

Definition at line 817 of file frame.c.

Referenced by show_frame().


Generated on Sun May 13 2018 02:04:27 for FFmpeg by   doxygen 1.8.6

AltStyle によって変換されたページ (->オリジナル) /