FFmpeg
Macros | Functions
transform.c File Reference
#include "libavutil/common.h"
#include "libavutil/avassert.h"
#include "transform.h"

Go to the source code of this file.

Macros

#define INTERPOLATE_METHOD(name)
 
#define PIXEL(img, x, y, w, h, stride, def)
 

Functions

 INTERPOLATE_METHOD (interpolate_nearest)
 Nearest neighbor interpolation. More...
 
 INTERPOLATE_METHOD (interpolate_bilinear)
 Bilinear interpolation. More...
 
 INTERPOLATE_METHOD (interpolate_biquadratic)
 Biquadratic interpolation. More...
 
void ff_get_matrix (float x_shift, float y_shift, float angle, float scale_x, float scale_y, float *matrix)
 Get an affine transformation matrix from given translation, rotation, and zoom factors. More...
 
int ff_affine_transform (const uint8_t *src, uint8_t *dst, int src_stride, int dst_stride, int width, int height, const float *matrix, enum InterpolateMethod interpolate, enum FillMethod fill)
 Do an affine transformation with the given interpolation method. More...
 

Detailed Description

transform input video

Definition in file transform.c.

Macro Definition Documentation

◆ INTERPOLATE_METHOD

#define INTERPOLATE_METHOD (   name)
Value:
static uint8_t name(float x, float y, const uint8_t *src, \
int width, int height, int stride, uint8_t def)

Definition at line 32 of file transform.c.

◆ PIXEL

#define PIXEL (   img,
  x,
  y,
  w,
  h,
  stride,
  def 
)
Value:
((x) < 0 || (y) < 0) ? (def) : \
(((x) >= (w) || (y) >= (h)) ? (def) : \
img[(x) + (y) * (stride)])

Definition at line 36 of file transform.c.

Function Documentation

◆ INTERPOLATE_METHOD() [1/3]

INTERPOLATE_METHOD ( interpolate_nearest  )

Nearest neighbor interpolation.

Definition at line 44 of file transform.c.

◆ INTERPOLATE_METHOD() [2/3]

INTERPOLATE_METHOD ( interpolate_bilinear  )

Bilinear interpolation.

Definition at line 52 of file transform.c.

◆ INTERPOLATE_METHOD() [3/3]

INTERPOLATE_METHOD ( interpolate_biquadratic  )

Biquadratic interpolation.

Definition at line 79 of file transform.c.

◆ ff_get_matrix()

void ff_get_matrix ( float  x_shift,
float  y_shift,
float  angle,
float  scale_x,
float  scale_y,
float *  matrix 
)

Get an affine transformation matrix from given translation, rotation, and zoom factors.

The matrix will look like:

[ scale_x * cos(angle), -sin(angle), x_shift, sin(angle), scale_y * cos(angle), y_shift, 0, 0, 1 ]

Parameters
x_shifthorizontal translation
y_shiftvertical translation
anglerotation in radians
scale_xx scale percent (1.0 = 100%)
scale_yy scale percent (1.0 = 100%)
matrix9-item affine transformation matrix

Definition at line 106 of file transform.c.

Referenced by filter_frame(), and transform_center_scale().

◆ ff_affine_transform()

int ff_affine_transform ( const uint8_t *  src,
uint8_t *  dst,
int  src_stride,
int  dst_stride,
int  width,
int  height,
const float *  matrix,
enum InterpolateMethod  interpolate,
enum FillMethod  fill 
)

Do an affine transformation with the given interpolation method.

This multiplies each vector [x,y,1] by the matrix and then interpolates to get the final value.

Parameters
srcsource image
dstdestination image
src_stridesource image line size in bytes
dst_stridedestination image line size in bytes
widthimage width in pixels
heightimage height in pixels
matrix9-item affine transformation matrix
interpolatepixel interpolation method
filledge fill method
Returns
negative on error

Definition at line 125 of file transform.c.

Referenced by deshake_transform_c().

stride
int stride
Definition: mace.c:144
name
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf default minimum maximum flags name is the option name
Definition: writing_filters.txt:88
w
uint8_t w
Definition: llviddspenc.c:38
width
#define width
src
#define src
Definition: vp8dsp.c:255
height
#define height
h
h
Definition: vp9dsp_template.c:2038