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
445204cd
Commit
445204cd
authored
Dec 06, 2016
by
James Almer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
avformat/matroskadec: add support for Spherical Video elements
Signed-off-by:
James Almer
<
jamrial@gmail.com
>
parent
e3694478
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
76 additions
and
0 deletions
+76
-0
matroska.h
libavformat/matroska.h
+14
-0
matroskadec.c
libavformat/matroskadec.c
+62
-0
No files found.
libavformat/matroska.h
View file @
445204cd
...
@@ -153,6 +153,13 @@
...
@@ -153,6 +153,13 @@
#define MATROSKA_ID_VIDEOCOLOR_LUMINANCEMAX 0x55D9
#define MATROSKA_ID_VIDEOCOLOR_LUMINANCEMAX 0x55D9
#define MATROSKA_ID_VIDEOCOLOR_LUMINANCEMIN 0x55DA
#define MATROSKA_ID_VIDEOCOLOR_LUMINANCEMIN 0x55DA
#define MATROSKA_ID_VIDEOPROJECTION 0x7670
#define MATROSKA_ID_VIDEOPROJECTIONTYPE 0x7671
#define MATROSKA_ID_VIDEOPROJECTIONPRIVATE 0x7672
#define MATROSKA_ID_VIDEOPROJECTIONPOSEYAW 0x7673
#define MATROSKA_ID_VIDEOPROJECTIONPOSEPITCH 0x7674
#define MATROSKA_ID_VIDEOPROJECTIONPOSEROLL 0x7675
/* IDs in the trackaudio master */
/* IDs in the trackaudio master */
#define MATROSKA_ID_AUDIOSAMPLINGFREQ 0xB5
#define MATROSKA_ID_AUDIOSAMPLINGFREQ 0xB5
#define MATROSKA_ID_AUDIOOUTSAMPLINGFREQ 0x78B5
#define MATROSKA_ID_AUDIOOUTSAMPLINGFREQ 0x78B5
...
@@ -331,6 +338,13 @@ typedef enum {
...
@@ -331,6 +338,13 @@ typedef enum {
MATROSKA_COLOUR_CHROMASITINGVERT_NB
MATROSKA_COLOUR_CHROMASITINGVERT_NB
}
MatroskaColourChromaSitingVert
;
}
MatroskaColourChromaSitingVert
;
typedef
enum
{
MATROSKA_VIDEO_PROJECTION_TYPE_RECTANGULAR
=
0
,
MATROSKA_VIDEO_PROJECTION_TYPE_EQUIRECTANGULAR
=
1
,
MATROSKA_VIDEO_PROJECTION_TYPE_CUBEMAP
=
2
,
MATROSKA_VIDEO_PROJECTION_TYPE_MESH
=
3
,
}
MatroskaVideoProjectionType
;
/*
/*
* Matroska Codec IDs, strings
* Matroska Codec IDs, strings
*/
*/
...
...
libavformat/matroskadec.c
View file @
445204cd
...
@@ -43,6 +43,7 @@
...
@@ -43,6 +43,7 @@
#include "libavutil/mathematics.h"
#include "libavutil/mathematics.h"
#include "libavutil/opt.h"
#include "libavutil/opt.h"
#include "libavutil/time_internal.h"
#include "libavutil/time_internal.h"
#include "libavutil/spherical.h"
#include "libavcodec/bytestream.h"
#include "libavcodec/bytestream.h"
#include "libavcodec/flac.h"
#include "libavcodec/flac.h"
...
@@ -161,6 +162,14 @@ typedef struct MatroskaTrackVideoColor {
...
@@ -161,6 +162,14 @@ typedef struct MatroskaTrackVideoColor {
MatroskaMasteringMeta
mastering_meta
;
MatroskaMasteringMeta
mastering_meta
;
}
MatroskaTrackVideoColor
;
}
MatroskaTrackVideoColor
;
typedef
struct
MatroskaTrackVideoProjection
{
uint64_t
type
;
EbmlBin
private
;
double
yaw
;
double
pitch
;
double
roll
;
}
MatroskaTrackVideoProjection
;
typedef
struct
MatroskaTrackVideo
{
typedef
struct
MatroskaTrackVideo
{
double
frame_rate
;
double
frame_rate
;
uint64_t
display_width
;
uint64_t
display_width
;
...
@@ -174,6 +183,7 @@ typedef struct MatroskaTrackVideo {
...
@@ -174,6 +183,7 @@ typedef struct MatroskaTrackVideo {
uint64_t
stereo_mode
;
uint64_t
stereo_mode
;
uint64_t
alpha_mode
;
uint64_t
alpha_mode
;
MatroskaTrackVideoColor
color
;
MatroskaTrackVideoColor
color
;
MatroskaTrackVideoProjection
projection
;
}
MatroskaTrackVideo
;
}
MatroskaTrackVideo
;
typedef
struct
MatroskaTrackAudio
{
typedef
struct
MatroskaTrackAudio
{
...
@@ -424,6 +434,15 @@ static const EbmlSyntax matroska_track_video_color[] = {
...
@@ -424,6 +434,15 @@ static const EbmlSyntax matroska_track_video_color[] = {
{
0
}
{
0
}
};
};
static
const
EbmlSyntax
matroska_track_video_projection
[]
=
{
{
MATROSKA_ID_VIDEOPROJECTIONTYPE
,
EBML_UINT
,
0
,
offsetof
(
MatroskaTrackVideoProjection
,
type
),
{
.
u
=
MATROSKA_VIDEO_PROJECTION_TYPE_RECTANGULAR
}
},
{
MATROSKA_ID_VIDEOPROJECTIONPRIVATE
,
EBML_BIN
,
0
,
offsetof
(
MatroskaTrackVideoProjection
,
private
)
},
{
MATROSKA_ID_VIDEOPROJECTIONPOSEYAW
,
EBML_FLOAT
,
0
,
offsetof
(
MatroskaTrackVideoProjection
,
yaw
),
{
.
f
=
0
.
0
}
},
{
MATROSKA_ID_VIDEOPROJECTIONPOSEPITCH
,
EBML_FLOAT
,
0
,
offsetof
(
MatroskaTrackVideoProjection
,
pitch
),
{
.
f
=
0
.
0
}
},
{
MATROSKA_ID_VIDEOPROJECTIONPOSEROLL
,
EBML_FLOAT
,
0
,
offsetof
(
MatroskaTrackVideoProjection
,
roll
),
{
.
f
=
0
.
0
}
},
{
0
}
};
static
const
EbmlSyntax
matroska_track_video
[]
=
{
static
const
EbmlSyntax
matroska_track_video
[]
=
{
{
MATROSKA_ID_VIDEOFRAMERATE
,
EBML_FLOAT
,
0
,
offsetof
(
MatroskaTrackVideo
,
frame_rate
)
},
{
MATROSKA_ID_VIDEOFRAMERATE
,
EBML_FLOAT
,
0
,
offsetof
(
MatroskaTrackVideo
,
frame_rate
)
},
{
MATROSKA_ID_VIDEODISPLAYWIDTH
,
EBML_UINT
,
0
,
offsetof
(
MatroskaTrackVideo
,
display_width
),
{
.
u
=-
1
}
},
{
MATROSKA_ID_VIDEODISPLAYWIDTH
,
EBML_UINT
,
0
,
offsetof
(
MatroskaTrackVideo
,
display_width
),
{
.
u
=-
1
}
},
...
@@ -433,6 +452,7 @@ static const EbmlSyntax matroska_track_video[] = {
...
@@ -433,6 +452,7 @@ static const EbmlSyntax matroska_track_video[] = {
{
MATROSKA_ID_VIDEOCOLORSPACE
,
EBML_BIN
,
0
,
offsetof
(
MatroskaTrackVideo
,
color_space
)
},
{
MATROSKA_ID_VIDEOCOLORSPACE
,
EBML_BIN
,
0
,
offsetof
(
MatroskaTrackVideo
,
color_space
)
},
{
MATROSKA_ID_VIDEOALPHAMODE
,
EBML_UINT
,
0
,
offsetof
(
MatroskaTrackVideo
,
alpha_mode
)
},
{
MATROSKA_ID_VIDEOALPHAMODE
,
EBML_UINT
,
0
,
offsetof
(
MatroskaTrackVideo
,
alpha_mode
)
},
{
MATROSKA_ID_VIDEOCOLOR
,
EBML_NEST
,
0
,
offsetof
(
MatroskaTrackVideo
,
color
),
{
.
n
=
matroska_track_video_color
}
},
{
MATROSKA_ID_VIDEOCOLOR
,
EBML_NEST
,
0
,
offsetof
(
MatroskaTrackVideo
,
color
),
{
.
n
=
matroska_track_video_color
}
},
{
MATROSKA_ID_VIDEOPROJECTION
,
EBML_NEST
,
0
,
offsetof
(
MatroskaTrackVideo
,
projection
),
{
.
n
=
matroska_track_video_projection
}
},
{
MATROSKA_ID_VIDEOPIXELCROPB
,
EBML_NONE
},
{
MATROSKA_ID_VIDEOPIXELCROPB
,
EBML_NONE
},
{
MATROSKA_ID_VIDEOPIXELCROPT
,
EBML_NONE
},
{
MATROSKA_ID_VIDEOPIXELCROPT
,
EBML_NONE
},
{
MATROSKA_ID_VIDEOPIXELCROPL
,
EBML_NONE
},
{
MATROSKA_ID_VIDEOPIXELCROPL
,
EBML_NONE
},
...
@@ -1879,6 +1899,44 @@ static int mkv_parse_video_color(AVStream *st, const MatroskaTrack *track) {
...
@@ -1879,6 +1899,44 @@ static int mkv_parse_video_color(AVStream *st, const MatroskaTrack *track) {
return
0
;
return
0
;
}
}
static
int
mkv_parse_video_projection
(
AVStream
*
st
,
const
MatroskaTrack
*
track
)
{
AVSphericalMapping
*
spherical
;
enum
AVSphericalProjection
projection
;
size_t
spherical_size
;
int
ret
;
switch
(
track
->
video
.
projection
.
type
)
{
case
MATROSKA_VIDEO_PROJECTION_TYPE_EQUIRECTANGULAR
:
if
(
track
->
video
.
projection
.
private
.
size
<
4
)
return
AVERROR_INVALIDDATA
;
projection
=
AV_SPHERICAL_EQUIRECTANGULAR
;
break
;
case
MATROSKA_VIDEO_PROJECTION_TYPE_CUBEMAP
:
if
(
track
->
video
.
projection
.
private
.
size
<
4
)
return
AVERROR_INVALIDDATA
;
projection
=
AV_SPHERICAL_CUBEMAP
;
break
;
default:
return
0
;
}
spherical
=
av_spherical_alloc
(
&
spherical_size
);
if
(
!
spherical
)
return
AVERROR
(
ENOMEM
);
spherical
->
projection
=
projection
;
spherical
->
yaw
=
(
int32_t
)(
track
->
video
.
projection
.
yaw
*
(
1
<<
16
));
spherical
->
pitch
=
(
int32_t
)(
track
->
video
.
projection
.
pitch
*
(
1
<<
16
));
spherical
->
roll
=
(
int32_t
)(
track
->
video
.
projection
.
roll
*
(
1
<<
16
));
ret
=
av_stream_add_side_data
(
st
,
AV_PKT_DATA_SPHERICAL
,
(
uint8_t
*
)
spherical
,
spherical_size
);
if
(
ret
<
0
)
return
ret
;
return
0
;
}
static
int
get_qt_codec
(
MatroskaTrack
*
track
,
uint32_t
*
fourcc
,
enum
AVCodecID
*
codec_id
)
static
int
get_qt_codec
(
MatroskaTrack
*
track
,
uint32_t
*
fourcc
,
enum
AVCodecID
*
codec_id
)
{
{
const
AVCodecTag
*
codec_tags
;
const
AVCodecTag
*
codec_tags
;
...
@@ -2361,6 +2419,10 @@ static int matroska_parse_tracks(AVFormatContext *s)
...
@@ -2361,6 +2419,10 @@ static int matroska_parse_tracks(AVFormatContext *s)
if
(
ret
<
0
)
if
(
ret
<
0
)
return
ret
;
return
ret
;
}
}
ret
=
mkv_parse_video_projection
(
st
,
track
);
if
(
ret
<
0
)
return
ret
;
}
else
if
(
track
->
type
==
MATROSKA_TRACK_TYPE_AUDIO
)
{
}
else
if
(
track
->
type
==
MATROSKA_TRACK_TYPE_AUDIO
)
{
st
->
codecpar
->
codec_type
=
AVMEDIA_TYPE_AUDIO
;
st
->
codecpar
->
codec_type
=
AVMEDIA_TYPE_AUDIO
;
st
->
codecpar
->
codec_tag
=
fourcc
;
st
->
codecpar
->
codec_tag
=
fourcc
;
...
...
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