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
4e4b74a6
Commit
4e4b74a6
authored
Oct 30, 2020
by
Jerome Wu
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add theora and vorbis build scripts, tests and examples
parent
b1d5fc0c
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
116 additions
and
8 deletions
+116
-8
README.md
README.md
+13
-0
build.sh
build.sh
+4
-2
build-ffmpeg.sh
wasm/build-scripts/build-ffmpeg.sh
+1
-1
build-theora.sh
wasm/build-scripts/build-theora.sh
+26
-0
build-vorbis.sh
wasm/build-scripts/build-vorbis.sh
+5
-1
var.sh
wasm/build-scripts/var.sh
+3
-1
utils.js
wasm/examples/browser/js/utils.js
+1
-0
theora.html
wasm/examples/browser/theora.html
+42
-0
vorbis.html
wasm/examples/browser/vorbis.html
+1
-1
config.js
wasm/tests/config.js
+1
-1
theora.test.js
wasm/tests/theora.test.js
+18
-0
vorbis.test.js
wasm/tests/vorbis.test.js
+1
-1
No files found.
README.md
View file @
4e4b74a6
...
...
@@ -33,6 +33,16 @@ $ bash build.sh
If nothing goes wrong, you can find JavaScript files in
`wasm/dist`
.
## Test
Once the build completes, you can test with following scripts:
```
$ cd wasm
$ npm install
$ npm test
```
## Configuration
#### Base
...
...
@@ -45,9 +55,12 @@ If nothing goes wrong, you can find JavaScript files in `wasm/dist`.
-
x264 (mp4): 0.160.x
-
x265 (mp4): 3.4 (only works with
`-pix_fmt yuv420p10le`
and
`-pix_fmt yuv420p12le`
)
-
libvpx (webm): 1.9.0
-
theora (ogv): 1.1.1
#### Audio
-
wavpack (wav): 5.3.0
-
lame (mp3): 3.100
-
fdk-aac (aac); 2.0.1
-
ogg: 1.3.4
-
vorbis (ogg): 1.3.6
build.sh
View file @
4e4b74a6
...
...
@@ -21,9 +21,11 @@ $SCRIPT_ROOT/build-lame.sh
# build fdk-aac
$SCRIPT_ROOT
/build-fdk-aac.sh
# build ogg
#
$SCRIPT_ROOT/build-ogg.sh
$SCRIPT_ROOT
/build-ogg.sh
# build vorbis
# $SCRIPT_ROOT/build-vorbis.sh
$SCRIPT_ROOT
/build-vorbis.sh
# build theora
$SCRIPT_ROOT
/build-theora.sh
# configure FFmpeg with Emscripten
$SCRIPT_ROOT
/configure-ffmpeg.sh
# build ffmpeg.wasm core
...
...
wasm/build-scripts/build-ffmpeg.sh
View file @
4e4b74a6
...
...
@@ -9,7 +9,7 @@ FLAGS=(
-I
.
-I
./fftools
-I
$BUILD_DIR
/include
-Llibavcodec
-Llibavdevice
-Llibavfilter
-Llibavformat
-Llibavresample
-Llibavutil
-Llibpostproc
-Llibswscale
-Llibswresample
-L
$BUILD_DIR
/lib
-Wno-deprecated-declarations
-Wno-pointer-sign
-Wno-implicit-int-float-conversion
-Wno-switch
-Wno-parentheses
-Qunused-arguments
-lavdevice
-lavfilter
-lavformat
-lavcodec
-lswresample
-lswscale
-lavutil
-lpostproc
-lm
-lx264
-lx265
-lvpx
-lwavpack
-lmp3lame
-lfdk-aac
-pthread
-lavdevice
-lavfilter
-lavformat
-lavcodec
-lswresample
-lswscale
-lavutil
-lpostproc
-lm
-lx264
-lx265
-lvpx
-lwavpack
-lmp3lame
-lfdk-aac
-
lvorbis
-lvorbisenc
-lvorbisfile
-logg
-ltheora
-ltheoraenc
-ltheoradec
-
pthread
fftools/ffmpeg_opt.c fftools/ffmpeg_filter.c fftools/ffmpeg_hw.c fftools/cmdutils.c fftools/ffmpeg.c
-o
wasm/dist/ffmpeg-core.js
-s
USE_SDL
=
2
# use SDL2
...
...
wasm/build-scripts/build-theora.sh
0 → 100755
View file @
4e4b74a6
#!/bin/bash
set
-euo
pipefail
source
$(
dirname
$0
)
/var.sh
LIB_PATH
=
third_party/theora
CFLAGS
=
"-s USE_PTHREADS=1
$OPTIM_FLAGS
-I
$BUILD_DIR
/include"
LDFLAGS
=
"-L
$BUILD_DIR
/lib"
CONF_FLAGS
=(
--prefix
=
$BUILD_DIR
# install library in a build directory for FFmpeg to include
--host
=
i686-linux
# use i686 linux
--enable-shared
=
no
# disable shared library
--enable-docs
=
no
--enable-fast-install
=
no
--disable-spec
--disable-asm
--disable-examples
--disable-oggtest
# disable ogg tests
--disable-vorbistest
# disable vorbis tests
--disable-sdltest
# disable sdl tests
)
echo
"CONF_FLAGS=
${
CONF_FLAGS
[@]
}
"
(
cd
$LIB_PATH
&&
\
CFLAGS
=
$CFLAGS
LDFLAGS
=
$LDFLAGS
emconfigure ./autogen.sh
"
${
CONF_FLAGS
[@]
}
"
)
emmake make
-C
$LIB_PATH
clean
emmake make
-C
$LIB_PATH
install
-j
wasm/build-scripts/build-vorbis.sh
View file @
4e4b74a6
...
...
@@ -10,12 +10,16 @@ CONF_FLAGS=(
--prefix
=
$BUILD_DIR
# install library in a build directory for FFmpeg to include
--host
=
i686-linux
# use i686 linux
--enable-shared
=
no
# disable shared library
--disable-oggtest
# disable tests
--enable-docs
=
no
--enable-examples
=
no
--enable-fast-install
=
no
--disable-oggtest
# disable oggtests
)
echo
"CONF_FLAGS=
${
CONF_FLAGS
[@]
}
"
(
cd
$LIB_PATH
&&
\
emconfigure ./autogen.sh
&&
\
CFLAGS
=
$CFLAGS
LDFLAGS
=
$LDFLAGS
emconfigure ./configure
"
${
CONF_FLAGS
[@]
}
"
)
# (cd $LIB_PATH && \
# CFLAGS=$CFLAGS LDFLAGS=$LDFLAGS emconfigure ./autogen.sh "${CONF_FLAGS[@]}")
emmake make
-C
$LIB_PATH
clean
emmake make
-C
$LIB_PATH
install
-j
wasm/build-scripts/var.sh
View file @
4e4b74a6
...
...
@@ -52,13 +52,15 @@ FFMPEG_CONFIG_FLAGS_BASE=(
--enable-libwavpack
# enable libwavpack
--enable-libmp3lame
# enable libmp3lame
--enable-libfdk-aac
# enable libfdk-aac
# --enable-libvorbis # enable libvorbis
--enable-libtheora
# enable libtheora
--enable-libvorbis
# enable libvorbis
--disable-debug
# disable debug info, required by closure
--disable-runtime-cpudetect
# disable runtime cpu detect
--disable-autodetect
# disable external libraries auto detect
--extra-cflags
=
"
$CFLAGS
"
--extra-cxxflags
=
"
$CFLAGS
"
--extra-ldflags
=
"
$LDFLAGS
"
--pkg-config-flags
=
"--static"
--nm
=
"llvm-nm"
--ar
=
emar
--as
=
llvm-as
...
...
wasm/examples/browser/js/utils.js
View file @
4e4b74a6
...
...
@@ -38,6 +38,7 @@ const runFFmpeg = async (ifilename, data, args, ofilename) => {
console
.
log
(
m
);
},
print
:
(
m
)
=>
{
console
.
log
(
m
);
if
(
m
.
startsWith
(
'FFMPEG_END'
))
{
resolve
();
}
...
...
wasm/examples/browser/theora.html
0 → 100644
View file @
4e4b74a6
<html>
<head>
<style>
html
,
body
{
margin
:
0
;
width
:
100%
;
height
:
100%
}
body
{
display
:
flex
;
flex-direction
:
column
;
align-items
:
center
;
}
</style>
</head>
<body>
<h3>
Upload a video to transcode to ogv (theora) and play!
</h3>
<video
id=
"output-video"
controls
></video><br/>
<input
type=
"file"
id=
"uploader"
>
<p
id=
"message"
>
Upload a video
</p>
<script
type=
"text/javascript"
src=
"./js/utils.js"
></script>
<script
type=
"text/javascript"
>
const
message
=
document
.
getElementById
(
'message'
);
const
transcode
=
async
({
target
:
{
files
}
})
=>
{
const
IN_FILE_NAME
=
'video.avi'
;
const
OUT_FILE_NAME
=
'video.ogv'
;
const
args
=
[
'-i'
,
IN_FILE_NAME
,
'-c:v'
,
'libtheora'
,
OUT_FILE_NAME
];
message
.
innerHTML
=
'Writing file to MEMFS'
;
const
data
=
new
Uint8Array
(
await
readFromBlobOrFile
(
files
[
0
]));
const
now
=
Date
.
now
();
console
.
time
(
`[
${
now
}
]
${
files
[
0
].
name
}
execution time`
);
message
.
innerHTML
=
'Start to transcode'
;
const
{
file
}
=
await
runFFmpeg
(
IN_FILE_NAME
,
data
,
args
,
OUT_FILE_NAME
)
const
video
=
document
.
getElementById
(
'output-video'
);
video
.
src
=
URL
.
createObjectURL
(
new
Blob
([
file
.
buffer
],
{
type
:
'video/ogv'
}));
console
.
timeEnd
(
`[
${
now
}
]
${
files
[
0
].
name
}
execution time`
);
};
document
.
getElementById
(
'uploader'
).
addEventListener
(
'change'
,
transcode
);
</script>
<script
type=
"text/javascript"
src=
"../../dist/ffmpeg-core.js"
></script>
</body>
</html>
wasm/examples/browser/
next/
vorbis.html
→
wasm/examples/browser/vorbis.html
View file @
4e4b74a6
...
...
@@ -14,7 +14,7 @@
</style>
</head>
<body>
<h3>
Upload a wav file to transcode to
aac
and play!
</h3>
<h3>
Upload a wav file to transcode to
ogg
and play!
</h3>
<audio
id=
"output-audio"
controls
></audio><br/>
<input
type=
"file"
id=
"uploader"
>
<p
id=
"message"
>
Upload a wav file
</p>
...
...
wasm/tests/config.js
View file @
4e4b74a6
module
.
exports
=
{
TIMEOUT
:
6
0000
,
TIMEOUT
:
12
0000
,
};
wasm/tests/theora.test.js
0 → 100644
View file @
4e4b74a6
const
fs
=
require
(
'fs'
);
const
path
=
require
(
'path'
);
const
{
TIMEOUT
}
=
require
(
'./config'
);
const
{
runFFmpeg
}
=
require
(
'./utils'
);
const
IN_FILE_NAME
=
'video-1s.avi'
;
const
OUT_FILE_NAME
=
'video.ogv'
;
const
OGV_SIZE
=
29561
;
let
aviData
=
null
;
beforeAll
(()
=>
{
aviData
=
Uint8Array
.
from
(
fs
.
readFileSync
(
path
.
join
(
__dirname
,
'data'
,
IN_FILE_NAME
)));
});
test
(
'convert avi to ogv'
,
async
()
=>
{
const
args
=
[
'-i'
,
IN_FILE_NAME
,
'-c:v'
,
'libtheora'
,
OUT_FILE_NAME
];
const
{
fileSize
}
=
await
runFFmpeg
(
IN_FILE_NAME
,
aviData
,
args
,
OUT_FILE_NAME
);
expect
(
fileSize
).
toBe
(
OGV_SIZE
);
},
TIMEOUT
);
wasm/tests/
next/vorbis
.js
→
wasm/tests/
vorbis.test
.js
View file @
4e4b74a6
...
...
@@ -4,7 +4,7 @@ const { TIMEOUT } = require('./config');
const
{
runFFmpeg
}
=
require
(
'./utils'
);
const
IN_FILE_NAME
=
'audio-1s.wav'
;
const
OUT_FILE_NAME
=
'audio.ogg'
;
const
OGG_SIZE
=
4239
;
const
OGG_SIZE
=
7712
;
let
wavData
=
null
;
beforeAll
(()
=>
{
...
...
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