Hi All,
I've had an attempt at implementing blending modes for sources, which has been previously requested in these two threads:
obsproject.com
ideas.obsproject.com
I've implemented it in a way that makes use of the existing blending state set up for compositing a source texture onto the scene, so unfortunately it's not a 'plugin', but is effectively 'free' from a performance point of view (for sources that were already being rendered to their own texture). As such, I was somewhat limited to implementing blending modes which are representable by specific combinations of src/dst blend factors & blend ops - the list of implemented blending modes is:
Here are some examples (for comparison to the blending modes defined here: https://www.w3.org/TR/compositing/#blendingseparable):
data:image/s3,"s3://crabby-images/0e1a5/0e1a56fe5de76df779664b52e7f1b8ff5f4260e1" alt="normal_blending.png normal_blending.png"
data:image/s3,"s3://crabby-images/1979d/1979dff0258297b800644abe2b4e59911707bc3a" alt="additive_blending.png additive_blending.png"
data:image/s3,"s3://crabby-images/878ca/878cac762552540007360d985759abcd998ba88a" alt="subtractive_blending.png subtractive_blending.png"
data:image/s3,"s3://crabby-images/d313a/d313a9256dca993768c69900cb8f69a8b75847e1" alt="screen_blending.png screen_blending.png"
data:image/s3,"s3://crabby-images/d2941/d29416bf8bd6d305709b3d4db5b654a104f2872f" alt="multiply_blending.png multiply_blending.png"
data:image/s3,"s3://crabby-images/a1d3b/a1d3b1f42ddd0f6eb8d92438f076dacdfa278a38" alt="lighten_blending.png lighten_blending.png"
data:image/s3,"s3://crabby-images/00464/0046414ef1e9a2114e100bf75df2f0a26b9cea62" alt="darken_blending.png darken_blending.png"
data:image/s3,"s3://crabby-images/0aec2/0aec2bc06e09f9dd62091104336a03331a038610" alt="darken_blending_fix.png darken_blending_fix.png"
So far I've only tested this on macOS, so I've been unable to test the d3d11 changes I've made. If anyone is willing to test, then I've put the changes here:
https://github.com/jw0z96/obs-studio/tree/source-blending-modes
If anyone has any advice for how these changes could be implemented as a plugin, rather than as changes to obs-studio's rendering backend, then I'm open to suggestions :)
Thanks!
I've had an attempt at implementing blending modes for sources, which has been previously requested in these two threads:
Blend modes for sources
I searched around the web and these forums a bit but couldn't find any mentions of this. Seems like something that might've been mentioned or requested before, but I don't see anything. For anyone who uses Photoshop, blend modes will probably be familiar. The wikipedia page for it explains it...
data:image/s3,"s3://crabby-images/ac948/ac9486a8f9d85c4807be445b7ab87e8d10548914" alt="ideas.obsproject.com"
Add blend modes for dynamic sources · OBS Studio Ideas and Suggestions
Adding this option will give a lot of new creative possibilities to OBS users. Although such an option already exists as an Image Mask Filter (it has
data:image/s3,"s3://crabby-images/f468d/f468d2f23c3fc87de0c708215d12e9b66f0e35fd" alt="ideas.obsproject.com"
I've implemented it in a way that makes use of the existing blending state set up for compositing a source texture onto the scene, so unfortunately it's not a 'plugin', but is effectively 'free' from a performance point of view (for sources that were already being rendered to their own texture). As such, I was somewhat limited to implementing blending modes which are representable by specific combinations of src/dst blend factors & blend ops - the list of implemented blending modes is:
- Normal
- Additive
- Subtractive
- Screen
- Multiply
- Lighten
- Darken (works incorrectly for transparent images - but a workaround could be to re-export the transparent image with a white background.)
Here are some examples (for comparison to the blending modes defined here: https://www.w3.org/TR/compositing/#blendingseparable):
data:image/s3,"s3://crabby-images/0e1a5/0e1a56fe5de76df779664b52e7f1b8ff5f4260e1" alt="normal_blending.png normal_blending.png"
data:image/s3,"s3://crabby-images/1979d/1979dff0258297b800644abe2b4e59911707bc3a" alt="additive_blending.png additive_blending.png"
data:image/s3,"s3://crabby-images/878ca/878cac762552540007360d985759abcd998ba88a" alt="subtractive_blending.png subtractive_blending.png"
data:image/s3,"s3://crabby-images/d313a/d313a9256dca993768c69900cb8f69a8b75847e1" alt="screen_blending.png screen_blending.png"
data:image/s3,"s3://crabby-images/d2941/d29416bf8bd6d305709b3d4db5b654a104f2872f" alt="multiply_blending.png multiply_blending.png"
data:image/s3,"s3://crabby-images/a1d3b/a1d3b1f42ddd0f6eb8d92438f076dacdfa278a38" alt="lighten_blending.png lighten_blending.png"
data:image/s3,"s3://crabby-images/00464/0046414ef1e9a2114e100bf75df2f0a26b9cea62" alt="darken_blending.png darken_blending.png"
data:image/s3,"s3://crabby-images/0aec2/0aec2bc06e09f9dd62091104336a03331a038610" alt="darken_blending_fix.png darken_blending_fix.png"
So far I've only tested this on macOS, so I've been unable to test the d3d11 changes I've made. If anyone is willing to test, then I've put the changes here:
https://github.com/jw0z96/obs-studio/tree/source-blending-modes
If anyone has any advice for how these changes could be implemented as a plugin, rather than as changes to obs-studio's rendering backend, then I'm open to suggestions :)
Thanks!