-
Notifications
You must be signed in to change notification settings - Fork 1.5k
Build QtAV
Uninstall QtAV SDK before building to avoid header files confliction. Run sdk_uninstall.bat/sh under your build dir
Shadow build is recommended (required for mac build).
-
Get QtAV source code
use git
git clone https://github.com/wang-bin/QtAV.git cd QtAV && git submodule update --init
-
FFmpeg>=1.0/Libav>=9.0. The latest release is recommended.
You can download latest prebuilt FFmpeg, or build yourself.
- If using OSX, installing
ffmpeg
viabrew
is also ok.
- If using OSX, installing
-
Libass headers is required if you need ass subtitle rendering support.
For windows, download http://sourceforge.net/projects/qtav/files/depends/QtAV-depends-windows-x86%2Bx64.7z/download and using bin, include, lib
in the package is enough to build.
Other requirements are:
-
Windows
If using Visual Studio, the Windows 10 SDK or Windows 8.1 SDK
OpenAL(Optional). OpenAL is not required since QtAV1.8.0. XAudio2 is always used. XAudio2 supports XP~windows 10 and Windows Store apps. Windows 8 and later natively supports XAudio2. For Windows 7 and older, you have to install the driver from DirectX to run.
-
OS X, iOS None. AudioToolbox and System OpenAL is used
-
Android
On Windows you must put
mingw32-make.exe
in one of%PATH%
to avoid qmake error. -
Ubuntu
OpenAL(recommended) or PulseAudio. To enable all supported features, you must install libass, XVideo and VA-API dev packages.
sudo apt-get install libopenal-dev libpulse-dev libva-dev libxv-dev libass-dev libegl1-mesa-dev
You may have to install VA-API drivers to make VA-API available at runtime
You MUST let your compiler know where FFmpeg headers and libraries are. Otherwise you will get an error when running qmake. If they are already be where they should be, for example you install from apt on ubunt, just skip this step.
Choose one of the following methods.
It's the simplest and best way. Qt include and lib dir are always searched in QtAV. It should work for all platforms, including android, iOS, WinRT and meego etc.
Take Windows for example, Qt is installed in C:\Qt\5.7\msvc2015_64\
. Goto that dir and put ffmpeg headers to include\
, libs to lib\
Extract ffmpeg to QtAV source dir. add 2 lines in .qmake.conf
INCLUDEPATH += $$PWD/ffmpeg/include
LIBS += -L$$PWD/ffmpeg/lib
-
VC:
INCLUDE
andLIB
command line:
set INCLUDE=ffmpeg_path\include;openal_path\include;%INCLUDE% set LIB=ffmpeg_path\lib;openal_path\lib;%LIB%
-
gcc/clang:
CPATH
andLIBRARY_PATH
unix shell environment(including mingw with sh.exe) command line
export CPATH=ffmpeg_path/include:openal_path/include:$CPATH export LIBRARY_PATH=ffmpeg_path/lib:openal_path/lib:$LIBRARY_PATH export LD_LIBRARY_PATH=ffmpeg_path/lib:openal_path/lib:$LD_LIBRARY_PATH
windows cmd.exe environment without UNIX Shell command line
set CPATH=ffmpeg_path\include;openal_path\include;%CPATH% set LIBRARY_PATH=ffmpeg_path\lib;openal_path\lib;%LIBRARY_PATH%
-
If build in QtCreator, open 'Projects' page and add/append the environment/values.
-
If using OSX and your
ffmpeg
is installed via brew (brew install ffmpeg
), you can:export CPATH=/usr/local/Cellar/ffmpeg/[VERSION]/include:$CPATH export LIBRARY_PATH=/usr/local/Cellar/ffmpeg/[VERSION]/lib:$LIBRARY_PATH export DYLD_LIBRARY_PATH=/usr/local/Cellar/ffmpeg/[VERSION]/lib:$DYLD_LIBRARY_PATH ~/Qt/5.7/clang_64/bin/qmake [QtAV Repo Directory]/QtAV.pro
-
Command line build
For most platforms, just run
mkdir your_build_dir cd your_build_dir qmake QtAV_source_dir/QtAV.pro make -j4
It's strongly recommended not to build in source dir(especially OSX).
qmake will check the required libraries to make sure they can be found by compiler.
Then qmake will create a cache file
.qmake.cache
in your build dir. Cache file stores the dependencies check results, for example, whether openal is available. If you want to recheck, you can either delete.qmake.cache
and run qmake again, or runqmake QtAV_source_dir/QtAV.pro -r "CONFIG+=recheck"
WARNING: If you are in windows mingw with sh.exe environment, you may need run qmake twice. I have not found out the reason behind this phenomenon.
QtAV 1.12 supports cmake. cmake + ninja can reduce build time. You have to set QTDIR to the installed qt path, otherwise cmake will find Qt5 in system default dirs.
cmake -GNinja -DCMAKE_BUILD_TYPE=RelWithDebInfo -DQTDIR=C:\Qt\5.8\msvc2015 qtav_src_dir
ninja
ninja install
I don't put any vs project file in QtAV, because it's easy to create by qmake.
Open a correct VS Prompt, for example, to build UWP for mobile, open VS2015 prompt for arm. Then run command there
%QTDIR%\bin\qmake -r -tp vc QtAV.pro
Where QTDIR is the corresponding Qt version directory, for example D:\Qt\5.7\winphone_arm
for windows phone 8.1. Then sln and vcxproj(vcproj) files will be created. Run msbuild /m
to build the projects (/m
option will break the build since qt5.7, just remove it). You can also open QtAV.sln in your Visual Studio to Compile it.
Another solution is using Qt vs plugin. It will help you to load qmake projects(not tested).
QtCreator will detect VC compiler if it is installed. So it's easy to build in QtCreator
You may get qmake error libavutil is required, but compiler can not find it
. That's because mingw32-make.exe
can not be found in the config test step. An workaround is put your mingw32-make.exe
to one of %PATH%
dirs
run
debuild -us -uc
in QtAV source tree
QtAV >=1.4.2 supports linking to static ffmpeg and openal libs. It's disabled by default. To enable it, add
CONFIG += static_ffmpeg static_openal
in $QtAV/.qmake.conf for Qt5 or $QtAV_BUILD_DIR/.qmake.cache
If QtAV, FFmpeg and OpenAL are built on newer OS, some symbols will not be found on 12.04. For example, clock_gettime is in both librt and glibc2.17, we must force the linker link against librt because 12.04 glibc does not have that symbol. add
CONFIG += glibc_compat
to .qmake.conf or .qmake.cache
You can read the build log to see how they work.
- qmake error
Checking for avutil... no
Make sure ffmpeg headers and libs can be found by compiler. Read config.log in build dir for details.