Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
7985430c
Commit
7985430c
authored
Sep 09, 2019
by
Paul B Mahol
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
avfilter/vf_v360: factor vector normalization out
parent
a0abcb4a
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
31 additions
and
26 deletions
+31
-26
vf_v360.c
libavfilter/vf_v360.c
+31
-26
No files found.
libavfilter/vf_v360.c
View file @
7985430c
...
@@ -689,6 +689,20 @@ static inline void rotate_cube_face_inverse(float *uf, float *vf, int rotation)
...
@@ -689,6 +689,20 @@ static inline void rotate_cube_face_inverse(float *uf, float *vf, int rotation)
}
}
}
}
/**
* Normalize vector.
*
* @param vec vector
*/
static
void
normalize_vector
(
float
*
vec
)
{
const
float
norm
=
sqrtf
(
vec
[
0
]
*
vec
[
0
]
+
vec
[
1
]
*
vec
[
1
]
+
vec
[
2
]
*
vec
[
2
]);
vec
[
0
]
/=
norm
;
vec
[
1
]
/=
norm
;
vec
[
2
]
/=
norm
;
}
/**
/**
* Calculate 3D coordinates on sphere for corresponding cubemap position.
* Calculate 3D coordinates on sphere for corresponding cubemap position.
* Common operation for every cubemap.
* Common operation for every cubemap.
...
@@ -704,7 +718,6 @@ static void cube_to_xyz(const V360Context *s,
...
@@ -704,7 +718,6 @@ static void cube_to_xyz(const V360Context *s,
float
*
vec
)
float
*
vec
)
{
{
const
int
direction
=
s
->
out_cubemap_direction_order
[
face
];
const
int
direction
=
s
->
out_cubemap_direction_order
[
face
];
float
norm
;
float
l_x
,
l_y
,
l_z
;
float
l_x
,
l_y
,
l_z
;
uf
/=
(
1
.
f
-
s
->
out_pad
);
uf
/=
(
1
.
f
-
s
->
out_pad
);
...
@@ -745,10 +758,11 @@ static void cube_to_xyz(const V360Context *s,
...
@@ -745,10 +758,11 @@ static void cube_to_xyz(const V360Context *s,
break
;
break
;
}
}
norm
=
sqrtf
(
l_x
*
l_x
+
l_y
*
l_y
+
l_z
*
l_z
);
vec
[
0
]
=
l_x
;
vec
[
0
]
=
l_x
/
norm
;
vec
[
1
]
=
l_y
;
vec
[
1
]
=
l_y
/
norm
;
vec
[
2
]
=
l_z
;
vec
[
2
]
=
l_z
/
norm
;
normalize_vector
(
vec
);
}
}
/**
/**
...
@@ -1396,16 +1410,12 @@ static void stereographic_to_xyz(const V360Context *s,
...
@@ -1396,16 +1410,12 @@ static void stereographic_to_xyz(const V360Context *s,
const
float
x
=
z
*
(
2
.
f
*
i
/
width
-
1
.
f
);
const
float
x
=
z
*
(
2
.
f
*
i
/
width
-
1
.
f
);
const
float
y
=
z
*
(
2
.
f
*
j
/
height
-
1
.
f
);
const
float
y
=
z
*
(
2
.
f
*
j
/
height
-
1
.
f
);
const
float
xy
=
x
*
x
+
y
*
y
;
const
float
xy
=
x
*
x
+
y
*
y
;
float
norm
;
vec
[
0
]
=
2
.
f
*
x
/
(
1
.
f
+
xy
);
vec
[
0
]
=
2
.
f
*
x
/
(
1
.
f
+
xy
);
vec
[
1
]
=
(
-
1
.
f
+
xy
)
/
(
1
.
f
+
xy
);
vec
[
1
]
=
(
-
1
.
f
+
xy
)
/
(
1
.
f
+
xy
);
vec
[
2
]
=
2
.
f
*
y
/
(
1
.
f
+
xy
);
vec
[
2
]
=
2
.
f
*
y
/
(
1
.
f
+
xy
);
norm
=
sqrtf
(
vec
[
0
]
*
vec
[
0
]
+
vec
[
1
]
*
vec
[
1
]
+
vec
[
2
]
*
vec
[
2
]);
normalize_vector
(
vec
);
vec
[
0
]
/=
norm
;
vec
[
1
]
/=
norm
;
vec
[
2
]
/=
norm
;
}
}
/**
/**
...
@@ -1555,7 +1565,6 @@ static void eac_to_xyz(const V360Context *s,
...
@@ -1555,7 +1565,6 @@ static void eac_to_xyz(const V360Context *s,
int
u_face
,
v_face
,
face
;
int
u_face
,
v_face
,
face
;
float
l_x
,
l_y
,
l_z
;
float
l_x
,
l_y
,
l_z
;
float
norm
;
float
uf
=
(
float
)
i
/
width
;
float
uf
=
(
float
)
i
/
width
;
float
vf
=
(
float
)
j
/
height
;
float
vf
=
(
float
)
j
/
height
;
...
@@ -1629,10 +1638,11 @@ static void eac_to_xyz(const V360Context *s,
...
@@ -1629,10 +1638,11 @@ static void eac_to_xyz(const V360Context *s,
av_assert0
(
0
);
av_assert0
(
0
);
}
}
norm
=
sqrtf
(
l_x
*
l_x
+
l_y
*
l_y
+
l_z
*
l_z
);
vec
[
0
]
=
l_x
;
vec
[
0
]
=
l_x
/
norm
;
vec
[
1
]
=
l_y
;
vec
[
1
]
=
l_y
/
norm
;
vec
[
2
]
=
l_z
;
vec
[
2
]
=
l_z
/
norm
;
normalize_vector
(
vec
);
}
}
/**
/**
...
@@ -1735,11 +1745,11 @@ static void flat_to_xyz(const V360Context *s,
...
@@ -1735,11 +1745,11 @@ static void flat_to_xyz(const V360Context *s,
const
float
l_y
=
-
s
->
flat_range
[
1
]
*
(
2
.
f
*
j
/
height
-
1
.
f
);
const
float
l_y
=
-
s
->
flat_range
[
1
]
*
(
2
.
f
*
j
/
height
-
1
.
f
);
const
float
l_z
=
s
->
flat_range
[
2
];
const
float
l_z
=
s
->
flat_range
[
2
];
const
float
norm
=
sqrtf
(
l_x
*
l_x
+
l_y
*
l_y
+
l_z
*
l_z
);
vec
[
0
]
=
l_x
;
vec
[
1
]
=
l_y
;
vec
[
2
]
=
l_z
;
vec
[
0
]
=
l_x
/
norm
;
normalize_vector
(
vec
);
vec
[
1
]
=
l_y
/
norm
;
vec
[
2
]
=
l_z
/
norm
;
}
}
/**
/**
...
@@ -1833,7 +1843,6 @@ static void barrel_to_xyz(const V360Context *s,
...
@@ -1833,7 +1843,6 @@ static void barrel_to_xyz(const V360Context *s,
const
int
eh
=
height
/
2
;
const
int
eh
=
height
/
2
;
float
uf
,
vf
;
float
uf
,
vf
;
float
norm
;
if
(
j
<
eh
)
{
// UP
if
(
j
<
eh
)
{
// UP
uf
=
2
.
f
*
(
i
-
4
*
ew
)
/
ew
-
1
.
f
;
uf
=
2
.
f
*
(
i
-
4
*
ew
)
/
ew
-
1
.
f
;
...
@@ -1856,17 +1865,13 @@ static void barrel_to_xyz(const V360Context *s,
...
@@ -1856,17 +1865,13 @@ static void barrel_to_xyz(const V360Context *s,
l_y
=
-
1
.
f
;
l_y
=
-
1
.
f
;
l_z
=
vf
;
l_z
=
vf
;
}
}
norm
=
sqrtf
(
l_x
*
l_x
+
l_y
*
l_y
+
l_z
*
l_z
);
l_x
/=
norm
;
l_y
/=
norm
;
l_z
/=
norm
;
}
}
vec
[
0
]
=
l_x
;
vec
[
0
]
=
l_x
;
vec
[
1
]
=
l_y
;
vec
[
1
]
=
l_y
;
vec
[
2
]
=
l_z
;
vec
[
2
]
=
l_z
;
normalize_vector
(
vec
);
}
}
/**
/**
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment