build instructions for windows - obsproject/obs-studio GitHub Wiki
NOTE: Since July 2023, obs-studio
uses an updated build system on Windows that automates most steps required in old build systems. Build instructions for the legacy build system for OBS Studio 28.0 to 29.1 are retained at Legacy Build Instructions For Windows.
- Windows 10 1909+ (or Windows 11)
- Visual Studio 2022 (at least Community Edition)
- Windows 11 SDK (minimum 10.0.22621.0)
- C++ ATL for latest v143 build tools (x86 & x64)
- MSVC v143 - VS 2022 C++ x64/x86 build tools (Latest)
- Git for Windows
- CMake 3.28 or newer
-
Clone the repository including submodules:
git clone --recursive https://github.com/obsproject/obs-studio.git
-
Set current directory to
obs-studio
-
Check available CMake presets:
cmake --list-presets
-
Select the
windows-x64
preset:cmake --preset windows-x64
- Available and supported architectures are:
x64
- x86 (32-bit) builds of obs-studio are no longer supported
- Any other CMake variables can be provided as usual and can also override variables set by the preset if necessary
- Available and supported architectures are:
- Open the Visual Studio solution file in the generated build directory (
build_x64\obs-studio.sln
) - Select the build configuration that you want to build (Debug, MinSizeRel, Release, RelWithDebInfo)
- Press
<Control>+<Shift>+<B>
to build the solution (Build -> Build Solution)- Alternatively, press
<F5>
to build and run it (Debug -> Start Debugging)
- Alternatively, press
Alternatively the project can also be built on the command line:
- Make sure the current directory is set to the
obs-studio
source code directory (if you continued from "Configuring Build Project" above, you are already there) - Run
cmake --build --preset windows-x64
- Run the app by navigating to
.\build_x64\rundir\<Debug|Release|RelWithDebInfo|MinSizeRel>\bin\64bit
, either on command line or in File Explorer, and runobs64.exe
.
While it is possible to do so, we generally do not recommend running OBS from command line.
Custom build options can be provided to CMake. You can either:
- Specify them directly as cache variables
- From command line when Configuring Build Project:
cmake --preset windows-x64 -DENABLE_BROWSER:BOOL=OFF
) - In the CMake GUI
- From command line when Configuring Build Project:
- Override them in a CMake User Preset specified in your local CMakeUserPresets.json
If you want to use the Virtual Camera created by this build, you will have to run its install script and also remove the Virtual Camera from a standard OBS installation first:
-
To uninstall the OBS Virtual Camera
- Close any applications that were using the OBS Virtual Camera.
- In the OBS Studio installation directory, run
data\obs-plugins\win-dshow\virtualcam-uninstall.bat
as administrator.
-
To install an OBS Virtual Camera:
- In the OBS Studio artifact directory (for Visual Studio builds, this is
<BUILD DIRECTORY>/rundir/<CONFIG>
), rundata\obs-plugins\win-dshow\virtualcam-install.bat
as administrator.
- In the OBS Studio artifact directory (for Visual Studio builds, this is
Don't forget to uninstall your build's virtual camera before cleaning/deleting your build files.
Use of clang-format
is required for pull requests, and OBS targets the version shipped with Visual Studio 2022 17.9, clang-format 17.0.3
. If you are using Visual Studio 2022 17.9, it should automatically format code for you.
To configure any other Visual Studio installation to use clang-format 17.0.3
:
- Download and install LLVM 17.0.3.
- Run Visual Studio, select
Tools -> Options
from the menu.- Go to
Text Editor -> C/C++ -> Code Style -> Formatting -> General
. - Enable "Use custom clang-format.exe" and enter the file name, e.g.
C:\Program Files\LLVM\bin\clang-format.exe
. - The default keyboard shortcut for formatting a document (Edit.FormatDocument) is Ctrl+K, Ctrl+D.
- Go to