summaryrefslogtreecommitdiff
path: root/libavfilter/vf_v360.c
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2020-03-26 13:53:22 +0100
committerPaul B Mahol <onemda@gmail.com>2020-03-26 13:53:22 +0100
commit840e92da17b12ea34df5757e57eb1d33231bc6b7 (patch)
tree018a0717c14e37ddc22092d92d29929e3d8e998d /libavfilter/vf_v360.c
parent7931e766ade210b3960aba987497d5bd2eeadcf4 (diff)
avfilter/vf_v360: improve sg input format
Specifically unbreak yaw functionality.
Diffstat (limited to 'libavfilter/vf_v360.c')
-rw-r--r--libavfilter/vf_v360.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/libavfilter/vf_v360.c b/libavfilter/vf_v360.c
index a16fd17574..b3443f2001 100644
--- a/libavfilter/vf_v360.c
+++ b/libavfilter/vf_v360.c
@@ -1742,8 +1742,11 @@ static int xyz_to_stereographic(const V360Context *s,
const float *vec, int width, int height,
int16_t us[4][4], int16_t vs[4][4], float *du, float *dv)
{
- const float x = vec[0] / (1.f - vec[1]) / s->iflat_range[0] * s->input_mirror_modifier[0];
- const float y = vec[2] / (1.f - vec[1]) / s->iflat_range[1] * s->input_mirror_modifier[1];
+ const float theta = acosf(-vec[2]);
+ const float r = tanf(theta * 0.5f);
+ const float c = r / hypotf(vec[0], vec[1]);
+ const float x = vec[0] * c / s->iflat_range[0] * s->input_mirror_modifier[0];
+ const float y = -vec[1] * c / s->iflat_range[1] * s->input_mirror_modifier[1];
const float uf = (x + 1.f) * width / 2.f;
const float vf = (y + 1.f) * height / 2.f;