Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/FFmpeg/FFmpeg.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2019-09-16 18:53:58 +0300
committerPaul B Mahol <onemda@gmail.com>2019-09-16 18:53:58 +0300
commitc271d88257e74ec24a6815b66ef4d5cdbc3a05ba (patch)
tree089be8a8607d06d5eb4a50f708d7fe35231b05f0 /libavfilter
parentd87db83e1cad7b31639853f6da2aee28659a16d0 (diff)
avfilter/vf_v360: move some local variables to private filter context
Diffstat (limited to 'libavfilter')
-rw-r--r--libavfilter/v360.h3
-rw-r--r--libavfilter/vf_v360.c10
2 files changed, 7 insertions, 6 deletions
diff --git a/libavfilter/v360.h b/libavfilter/v360.h
index 8e8799a89e..24e4615c1c 100644
--- a/libavfilter/v360.h
+++ b/libavfilter/v360.h
@@ -115,7 +115,10 @@ typedef struct V360Context {
float h_fov, v_fov, d_fov;
float flat_range[3];
+ float rot_mat[3][3];
+
float input_mirror_modifier[2];
+ float output_mirror_modifier[3];
int pr_width[4], pr_height[4];
diff --git a/libavfilter/vf_v360.c b/libavfilter/vf_v360.c
index bdbd0baa81..c8258cecc6 100644
--- a/libavfilter/vf_v360.c
+++ b/libavfilter/vf_v360.c
@@ -2182,7 +2182,6 @@ static int config_output(AVFilterLink *outlink)
int in_offset_h, in_offset_w;
int out_offset_h, out_offset_w;
float hf, wf;
- float output_mirror_modifier[3];
void (*in_transform)(const V360Context *s,
const float *vec, int width, int height,
uint16_t us[4][4], uint16_t vs[4][4], float *du, float *dv);
@@ -2192,7 +2191,6 @@ static int config_output(AVFilterLink *outlink)
void (*calculate_kernel)(float du, float dv, const XYRemap *rmap,
uint16_t *u, uint16_t *v, int16_t *ker);
int (*prepare_out)(AVFilterContext *ctx);
- float rot_mat[3][3];
s->input_mirror_modifier[0] = s->ih_flip ? -1.f : 1.f;
s->input_mirror_modifier[1] = s->iv_flip ? -1.f : 1.f;
@@ -2466,8 +2464,8 @@ static int config_output(AVFilterLink *outlink)
allocate_plane(s, sizeof_uv, sizeof_ker, 1);
}
- calculate_rotation_matrix(s->yaw, s->pitch, s->roll, rot_mat, s->rotation_order);
- set_mirror_modifier(s->h_flip, s->v_flip, s->d_flip, output_mirror_modifier);
+ calculate_rotation_matrix(s->yaw, s->pitch, s->roll, s->rot_mat, s->rotation_order);
+ set_mirror_modifier(s->h_flip, s->v_flip, s->d_flip, s->output_mirror_modifier);
// Calculate remap data
for (int p = 0; p < s->nb_allocated; p++) {
@@ -2491,10 +2489,10 @@ static int config_output(AVFilterLink *outlink)
else
out_transform(s, i, j, width, height, vec);
av_assert1(!isnan(vec[0]) && !isnan(vec[1]) && !isnan(vec[2]));
- rotate(rot_mat, vec);
+ rotate(s->rot_mat, vec);
av_assert1(!isnan(vec[0]) && !isnan(vec[1]) && !isnan(vec[2]));
normalize_vector(vec);
- mirror(output_mirror_modifier, vec);
+ mirror(s->output_mirror_modifier, vec);
if (s->in_transpose)
in_transform(s, vec, in_height, in_width, rmap.v, rmap.u, &du, &dv);
else