diff options
author | Paul B Mahol <onemda@gmail.com> | 2019-09-11 16:21:25 +0200 |
---|---|---|
committer | Paul B Mahol <onemda@gmail.com> | 2019-09-11 16:25:21 +0200 |
commit | 7ce7002664fba80a0e36d221ceea1d3c6fd2ce08 (patch) | |
tree | ad7fa1c5b43de23076f3ef5b5dabedda959b2587 /libavfilter/vf_v360.c | |
parent | 78b86c30d3860135042505dd4a9cbd95c4e6257d (diff) | |
download | ffmpeg-7ce7002664fba80a0e36d221ceea1d3c6fd2ce08.tar.gz |
avfilter/vf_v360: refactor FoV calculation for stereographic
Move in out of loop.
Diffstat (limited to 'libavfilter/vf_v360.c')
-rw-r--r-- | libavfilter/vf_v360.c | 29 |
1 files changed, 23 insertions, 6 deletions
diff --git a/libavfilter/vf_v360.c b/libavfilter/vf_v360.c index 3f723fe574..ef4e303109 100644 --- a/libavfilter/vf_v360.c +++ b/libavfilter/vf_v360.c @@ -1397,6 +1397,26 @@ static void equirect_to_xyz(const V360Context *s, } /** + * Prepare data for processing stereographic output format. + * + * @param ctx filter context + * + * @return error code + */ +static int prepare_stereographic_out(AVFilterContext *ctx) +{ + V360Context *s = ctx->priv; + + const float h_angle = tan(FFMIN(s->h_fov, 359.f) * M_PI / 720.f); + const float v_angle = tan(FFMIN(s->v_fov, 359.f) * M_PI / 720.f); + + s->flat_range[0] = h_angle; + s->flat_range[1] = v_angle; + + return 0; +} + +/** * Calculate 3D coordinates on sphere for corresponding frame position in stereographic format. * * @param s filter context @@ -1410,11 +1430,8 @@ static void stereographic_to_xyz(const V360Context *s, int i, int j, int width, int height, float *vec) { - const float h_angle = tan(FFMIN(s->h_fov, 359.f) * M_PI / 720.f); - const float v_angle = tan(FFMIN(s->v_fov, 359.f) * M_PI / 720.f); - - const float x = ((2.f * i) / width - 1.f) * h_angle; - const float y = ((2.f * j) / height - 1.f) * v_angle; + const float x = ((2.f * i) / width - 1.f) * s->flat_range[0]; + const float y = ((2.f * j) / height - 1.f) * s->flat_range[1]; const float xy = x * x + y * y; vec[0] = 2.f * x / (1.f + xy); @@ -2282,7 +2299,7 @@ static int config_output(AVFilterLink *outlink) break; case STEREOGRAPHIC: out_transform = stereographic_to_xyz; - err = 0; + err = prepare_stereographic_out(ctx); w = FFMAX(roundf(wf), roundf(hf)); h = w; break; |