Additions:
Changes:
- Added "OBS stats" condition type.
![]()
It allows performing actions based on various OBS and system load related statistics:
- FPS
- CPU usage
- RAM usage
- Average frame time
- Percentage of skipped frames
- Percentage of missed frames
- Percentage of dropped frames
- Amount of data streamed or recorded
- Current bitrate
- Added the option to check whether or not OBS is currently shutting down to the "Plugin state" condition type.
![]()
This can be useful if you want to perform actions when closing OBS. For example, if you would want to prepare for the next time you start it back up.- Added the option to toggle between a simple and a more advanced version of the date condition.
![]()
The simple view supports setting up the condition by just providing a day of the week and a time.- Added the option to highlight recently executed macros on the Macro tab.
![]()
- Added hotkey to delete macro segments.
It can be found the OBS settings' hotkey section.- Added Turkish locale (provided by @dargat)
- Allow reordering macros via drag and drop.
- Reworked the controls for the macro tab's condition and action areas.
Instead of the controls appearing under each condition or action when hovering other them, these controls were moved to the bottom of the condition and action areas respectively.
Individual conditions and actions can now be selected by clicking on them and be moved, deleted or copied using the controls mentioned before.
![]()
This should make it easier to work with large amounts of conditions or actions and especially as this avoids the conditions and actions shifting around unexpectedly when hovering over them.- Added frame around individual macro segments to visually separate them more clearly.
- Moved macro segments will now be highlighted to make it easier to track them visually.
- Removed a bunch of unnecessary collapsing animation triggering when reordering, adding or removing macro segments.
- In case of having only a few single actions or conditions in a macro the segments will no longer be stretched to fill the entire condition or action area.
- Slightly reduced spacing between macro segments.
- Reduced the space taken up by the text edit areas like they are used in the file, filter, source and transform condition and action types.
- Add context menu entry for expanding and minimizing the condition and action edit area.
- The "Show match" button of the video condition will now automatically refresh every second instead of only showing a single match.
This will make it much easier to dial in the settings needed for a successful pattern match or object detection.
Fixes:
- The last opened tab will now automatically be reopened when opening the plugin's settings dialog.
It will reset to the General tab after restarting OBS.- Allow selecting current scene, previous scene and scene groups in "Switch preview scene" action.
- Allow switching to already active scene if in studio mode.
- Use name of the macro to be copied when attempting to duplicate a macro.
- Also copy the logic type selection when duplicating conditions.
- Double clicking on items in the lists of the "Run" or "Sequence" actions will now allow you to edit the entry.
- Added the option to hide the tabs of the plugin which can be expressed via macros and reduce the visible tabs to "General", "Macro", "Network" and "Scene Group".
This setting will be set as a default in a future version.
![]()
- Fix potential crashes when adding or removing macro actions or conditions.
- Fix scene switch action blocking unexpectedly
- Fix freeze when highlighting certain widgets
Special thanks to @lindenkron for his support in testing and providing feedback!
Additions:
Fixes:
- Add "Sequence" macro action.
![]()
This new action will allow you to advance through a list of other macros' actions, advancing to the next item in the list each time this action type is performed.
An example can be found here.- Add macro action to stop other macros to the "Macro" action type.
![]()
- Add option to also check for configured volume level to the "Audio" condition type.
Notes:
- Fix unexpectedly returning true for hotkey condition.
The condition would return true after unpausing a macro, if a configured hotkey was pressed during the time the macro was paused.- Fix dock location and size not saving correctly.
- Fix potential crashes reported with the recent beta releases of OBS.
- The plugin folder structure has been slightly changed to move any dependencies the plugin ships with into a separate folder "adv-ss-plugins".
This should make it easier if you would need to manually uninstall the plugin.
Additions:
Improvements:
- Added the option create a dock widget to check and control whether or not the Advanced Scene Switcher is currently running.
You can access it via View -> Docks -> Advanced Scene Switcher.
![]()
It can be used just like any other dock and be freely placed in OBS' dock areas.
![]()
- Added the OpenVR macro condition. (Windows only for now)
![]()
This will allow you to perform actions based on where your VR Headset is currently located.
Thanks for the suggestion and support in testing @munkilicious!- Added the option to check if an audio source is muted.
![]()
- Added the condition "Studio Mode".
This will allow you to check whether or not studio mode and which preview scene is currently active.
![]()
- Added action to switch the current OBS profile.
![]()
- Added action to switch scene collections.
![]()
- Added action to import plugin settings from a file.
![]()
Fixes:
- Added the option to the "Switch scene" action to wait for the transition to complete before continuing with the next action.
![]()
This will make it much easier to set up a sequence of scene switches without having to know the duration of each transition beforehand.- Improved the scene item selection for visibility, order, and transform related macro actions and conditions.
If a particular scene item exists multiple times in the selected scene you can now choose which scene item in particular shall be selected.
![]()
The previous behaviour of selecting all scene items is also available still.
Notes:
- Fix startup behaviour settings not loading correctly, causing the plugin to always be active on startup.
- Fix crash when reordering macros which were marked to run in the background.
- Fix volume not changing when selecting a fade with a duration of zero seconds.
- Fix plugin asking to backup settings when starting the plugin for the first time.
- The OpenCV parts of the plugin have been moved outside the main plugin into a separate library.
This was done to avoid the issue (especially on Linux) of the whole plugin not being able to start if a particular version of OpenCV was not available.- I started work on the wiki for this plugin:
https://github.com/WarmUpTill/SceneSwitcher/wiki
Feel free to contribute! :)
Additions:
Improvements:
- Add macro action for triggering screenshots.
![]()
Individual sources, scenes or OBS' main output is supported.- Add macro action to display system tray notifications.
![]()
- Add hotkey to toggle pause state of macros.
![]()
This will allow setting up even more complicated hotkey actions.- Add button to manually run macro actions.
![]()
This will make it much easier to test macro actions.- Allow running macros in parallel to other macros.
![]()
Previously a macro containing actions that would take a long time to execute (e.g. the "wait" condition) would "block" the plugin from performing any other checks or actions during this time.
While in some situations, this could be the desired effect, there are certainly also situations where this is not ideal. (E.g. a continuous scene switching loop)
Checking this box will allow you to run a macro's action in parallel to other potentially running actions.- Add condition to check if the plugin is running.
![]()
This is mostly useful if you need a condition that is always true, but could also be used to perform actions if the plugin was running for a specific amount of time when combining it with a time constraint. (Small clock icon)
Changes:
- Allow setting random duration in specified range.
![]()
- The run action now also supports supplying a path to a file that is not an application itself.
So for example, if you pass it the path to an mp3 file and your default media player is VLC it will launch the VLC player and start playback of this file, just as if you would have clicked on the file's icon on the desktop.- Add option to match any or all media sources of a specific scene.
![]()
- Add the option to execute another macro's actions.
![]()
- Suggest a file name when saving settings.
- Minor UI improvements like resize lists on the macro tab to minimum necessary height.
Notes:
- Add the option to check for the source and the target scene of an ongoing transition.
![]()
At the same time the option "wait for transition to complete" was removed from the "current scene is" check as it did not really fit into that category and its description was not really formulated clearly to begin with.
Note that the behaviour has not change for any already existing macros.- Add a warning if the macro functionality is not running with highest priority.
- Update locale (zh-CN locale provided by qwe1154323937)
- The plugin is now also available via Flatpak on Linux
The main focus of this update was fixing issues and improving upon existing functionality.
Additions:
Fixes:
- Add the option to fade in/out volume changes via the "Audio" macro action.
![]()
- Add macro action "Random", which will allow you to execute other macros at random.
Paused macros will be ignored.
![]()
This should allow you to expand upon the functionality provided by the "Random" tab if needed.
I will probably expand upon this functionality in future, but I thought it wouldn't hurt to make it available to everyone in its current state.- Allow selecting source type instead of just individual sources for scene visibility action.
![]()
This should simplify some setups.- Add scene-visibility macro condition.
![]()
- Allow use of "previous scene" in scene visibility action.
- Allow interacting with OBS main window while plugin settings are opened.
Other changes:
- Fix macro un-/pause hotkeys not working once a macro was executed.
- Fix add, delete, reorder not working when changing macro segment type.
- Fix macro count not updating correctly.
- No longer check the conditions of paused macros.
This should improve the performance if you have a lot of paused macros with "expensive" conditions like video pattern matching.- Ensure contents of combo boxes are readable when changing scene/filter.
Additions:
Minor additions and changes:
- Improve the video condition's pattern matching functionality:
This option now supports the option to provide a mask for the used pattern by using the pattern's alpha channel.
![]()
In short, this will allow you to match parts of an image which are not shaped as a rectangle.
For example using the following pattern ...
![]()
... will all you to match both of the following images:
![]()
![]()
- Add option to use pattern matching for "output changed" macro condition.
![]()
This will allow to use this type of condition for "noisy" video sources like compressed video streams and thus ignore minor changes in the image output.- Improve the timer condition and add a timer action:
The timer condition was improved to now support pausing and continuing the timer.
![]()
The timer's state will now also be saved and reloaded when exiting and relaunching OBS.
So if a timer still had 10 seconds remaining of a 60 second timeout when exiting OBS, the timer will now continue at 10 seconds when restarting OBS.
A corresponding timer macro action was introduced also:
![]()
This new action will allow you to pause, continue, reset and set remaining time of timers of other macros.
Fixes:
- Add version info to the window title.
![]()
- Add "wait for transition to complete option" for current scene check on the macro tab.
![]()
- Add conditions "stream starting" and "stream stopping" to the streaming macro condition.
![]()
- Add option to display notifications when the plugin was started or stopped.
![]()
![]()
- Add description for the "minimum neighbors" parameter for the object detection.
- Reword date condition's repeat option.
- Slightly clean up general tab.
- Improve error output when the data directory cannot be found.
- Fix minimum neighbors parameter of object detection not loading correctly.
- Fix crash when switching scene collection during macro wait action.
- Fix newly created scene sequences not working when including scene groups.
- Fix scroll position being lost on the macro tab when adding or removing macro segments.
- Fix exact image match not working when using images containing alpha channel information.
- Linux: Use process names for the process macro condition and executable tab, instead of relying on window names for this functionality.
Additions:
Minor additions and changes:
- Improve video condition:
The improvements to the video condition have been achieved by relying on the functionality provided by OpenCV.
This update includes a few of the OpenCV libraries and thus increased the size of the plugin for Windows and MacOS.
Linux users will have to manually install the corresponding OpenCV 4 packages. (imgproc, objdetect)
- Added pattern matching:
Previously, you were only to perform actions based on an exact pixel-match of a selected video source and an input image.
With this new functionality you can decide how similar the input image has to be to video source output or just match parts of an image.
This can be useful if you have "noisy" video sources or cannot know the exact output of the video source beforehand.
![]()
To test if the video source is matching the pattern one can click the "Show match" button.
Below you can find an example of using the number "2" as an input pattern.
It was correctly identified and highlighted in red in the video source:
![]()
- Added object detection option:
Besides pattern matching the option to identify "objects" in video sources was added by relying OpenCV's "Haar Cascades".
![]()
A few face detection related example models have been included plugin's data directory.
An example use case brought up on GitHub would be to automatically switch scenes based on in which camera you are currently looking.
Similar to the pattern matching the "Show match" button will highlight any objects detected in the selected video source:
![]()
(Face provided by https://thispersondoesnotexist.com)
I am not sure how much use this feature will find but it was very fun to implement. ;)- Add conditions "scene changed" and "scene has not changed"
![]()
![]()
This should allow to simplify some macro setups which previously had to specify every single scene.- Added Studio mode related actions:
- Add macro condition "Scene item transform".
![]()
- Improved Hotkey action:
An option was added to specify the duration a key is held down.
Additionally, you can now limit the key presses to be sent only to OBS.
This action is now also enabled on MacOS, although it is limited to only sending simulated key presses to OBS.
![]()
- Add macro action and condition "Transition":
The new transition action will allow you to set the current transition type and duration.
![]()
The new transition condition will allow you to perform actions based on which transition is currently selected, its duration and also whether a transition is currently started or a transition ended.
![]()
An example use case would be to automatically mute the microphone during a longer fancy transition and unmute it once it completes.
Fixes:
- Escape settings when pressing "Get settings" and regular expressions are used.
![]()
- Create a copy of the previous macro segment when inserting new segment.
- Highlight newly added macro segments.
- Validate window position before setting it.
- Fix empty paths not saving on file tab.
- Fix crash on clicking "Get settings" if source or filter is null.
- Fix crash on OBS exit or when deleting sources whose settings were checked.
- Save window position and size when using ESC or the "close" button.
- Fix rapid scene switches repeatedly restarting certain transition types.
Additions:
Fixes:
- Expand date macro condition functionality.
This condition type now supports specifying a range of time during which the condition will be true.
For example:
![]()
Time ranges can be selected using the options "before", "after" and "between" and a time point can be selected using the "at" option.
- Fix crash when deleting macro that is currently running a "wait" action.
- Fix wait action causing macros to be aborted randomly.
- Fix matching settings of sources and filters using macro conditions.
Previously, depending on which version of OBS you were using, the settings would only match when using "flat" json formatting, which was not used when pressing the "Get current settings" button.- Fix writing current scene to file.
- Allow scrolling in expanded comboboxes
- Fix extended sequence aborting when using non-instant transitions
- Backwards compatibility to older settings format was removed to make sure no duplicate condition and action selections are shown on the macro tab.
Most users will not be affected by this, but just in case:
If you haven't updated the plugin in a while and are afraid that some macro settings will be lost when updating...
... make sure to backup your settings, when prompted to.
... install a previous version of the plugin to automatically convert the settings. (1.15.1 for example)
Affected settings are the old "count", "screen region" and "interval" macro conditions.