Unfortunately, I was not able to make obsproject/obs-browser work on Linux, so I decided to create a separate plugin using the same engine, so both plugins should have feature parity in terms of browser capabilities.
Installing (binary release)
- Download the latest release from the releases page. Make sure the release version matches obs-studio version on your system .
mkdir -p $HOME/.config/obs-studio/plugins
- Untar, e.g.:
tar -zxvf linuxbrowser0.5.2-obs21.1.2-64bit.tgz -C $HOME/.config/obs-studio/plugins/
- Install the dependencies (see Dependencies section)
You don't need to build the plugin if you've downloaded a binary release, instructions below are for people who want to compile the plugin themselves.
 Every binary release has the version number of OBS contained as part of the file name, e.g. “linuxbrowser0.5.2-obs21.1.2-64bit.tgz” refers to obs-linuxbrowser version 0.5.2 with OBS version 21.1.2.
Building from source
The following steps are NOT necessary, if you have already installed a binary release of obs-linuxbrowser!
- Download CEF minimal or standard binary release from http://opensource.spotify.com/cefbuilds/index.html 
- Extract and cd into folder
cmake ./ && make libcef_dll_wrapper
 Due to unknown reasons certain CEF versions do not work properly with OBS-Studio. See issue #63 for a list of versions which have been confirmed to be working and to track progress on this issue.
Make sure you have obs-studio installed.
cmake -DCEF_ROOT_DIR=<path to your cef dir> ..
 If you've installed OBS under an installation prefix other than
/usr (meaning include files aren't located at
/usr/include/obs and library files aren't located at
/usr/lib), you need to set
OBS_ROOT_DIR to reflect the actual installation prefix. If you don't know your installation prefix, you can also set
OBS_INCLUDE_SEARCH_DIR to the location of your OBS installation's header files and
OBS_LIBRARY_SEARCH_DIR to the location of your OBS installation's library (.so) files. In most cases, though, this is NOT required at all.
Info: If you intend to install obs-linuxbrowser system wide (though the OBS developers don't recommend that), you can add
-DINSTALL_SYSTEMWIDE=true to the CMake call. obs-linuxbrowser will then be installed to
/usr/lib/obs-plugins (binaries) and
Installing compiled sources
make installto install all plugin binaries to
- Make sure to have all dependencies installed on your system
You can enable flash by providing the path to your installed pepper flash library file and its version. Some distributions provide packages with the plugin, but you can also extract one from google chrome installation. The Flash version can be found in manifest.json that is usually found in same directory as .so file.
obs-linuxbrowser provides some JS bindings that are working the same way as the ones from obs-browser do. Additionally, a constant
window.obsstudio.linuxbrowser = true has been introduced to allow the distinction between obs-browser and obs-linuxbrowser on the website.
All off the following bindings are children of
onActiveChange(bool isActive)– called whenever the source becomes activated or deactivated
onVisibilityChange(bool isVisible)– called whenever the source is shown or hidden
linuxbrowser = true– Indicates obs-linuxbrowser is being used
pluginVersion– A string containing the plugin's version
Old version of OBS not starting with new version of obs-linuxbrowser installed
Using obs-linuxbrowser with an older OBS version than the one which has been used for compilation makes OBS break. Compile obs-linuxbrowser with the same OBS version you are going to use for streaming/recording or select a binary release whose OBS version matches the same version as yours. If you've compiled obs-linuxbrowser yourself, recompile it with the older version of OBS.
OBS-Linuxbrowser not displaying any content with certain versions of CEF
Some builds of CEF seem to be not working with obs-linuxbrowser. We weren't able to figure out the exact cause of this, but we assume that it's a CEF-related issue we can't fix. Check issue #63 for information about CEF versions that are known to be working.
Problems might also occur when updating CEF withouth recompiling obs-linuxbrowser afterwards. Please make sure to recompile obs-linuxbrowser before opening issues concerning problems with certain CEF versions.
Transparency not working correctly: Transparent white browser content appears gray on white scene background.
As stated in issue #58, there is a limitation in CEF, making it unable to detect the background of the OBS scenes. Instead, premultiplied alpha values are used, which somehow make transparent white colors appear gray (every color on the grayscale is a bit darker than normal when using transparency). With a black background, transparency seems to be working out quite fine.
This issue cannot be fixed.
OBS-Linuxbrowser not compiling, complaining about having to use ISO C++11 standard (old compiler versions)
See #88 for details. Some older compiler versions seem to have trouble with our current CMake setup. Using newer versions (e.g. GCC 8.x) should word.