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.
- Fix video condition not saving time constraint, logic and collapsed state.
- Add note to network tab clarifying the requirement of the scene names having to match exactly.
Macro tab UI changes:
Cursor macro condition changes:
- Add the ability to reorder, add and remove macro conditions and actions in place.
These new controls will appear when hovering over a macro condition or action.
![]()
- Persist collapse / expanded state of conditions and actions.
- Add option to expand or collapse all macro actions or conditions.
Right click inside the conditions or actions area to access these controls.
![]()
- Prevent accidental edits of actions and conditions when scrolling by disabling scroll wheel interactions for widgets which have not explicitly gained focus by clicking on them.
Fixes:
- Extend the mouse cursor macro condition to support detecting if the cursor was moved.
![]()
- Add the option to show a frame highlighting the current screen region selected for a cursor macro condition.
![]()
- Show current cursor position.
- Fix crash on Wayland based Linux systems.
Note that functionality relying on information provided X window manager (e.g. current foreground window) might not be functional on these systems.
Important note: The minimum supported version of OBS for this update is OBS 27!
The main focus of this update was to extend the capabilities of the macro tab once again.
Additions:
Other changes:
- Add macro condition and action "hotkey"
The action will allow you to simulate key presses. (Windows and Linux only)
![]()
The condition will allow you to trigger arbitrary macros with via hotkeys in OBS.
![]()
![]()
- Add macro condition "Macro"
![]()
The macro condition "Macro" contains the condition type previously named "Count" and also adds the option to check the condition state of other macros.
This allows nesting of macro conditions in other macros.
For example the following can now be configured using this new option:
"If (scene 1 or scene 2 or scene 3 is active) for at least x amount of time"- Add macro filter condition and extend the filter action to allow modifying filter settings.
![]()
- Add macro condition "timer" (previously known as "interval")
![]()
- Add macro action and condition "scene item order"
![]()
![]()
- Add macro action "scene transform"
![]()
- Add macro condition "replay buffer"
![]()
- Add support for arguments for macro action "run"
![]()
- Add macro action "file", which will allow you to write or append to files
![]()
- Add macro condition "date"
![]()
- Add macro action and condition for virtual camera
![]()
![]()
- Add option to only trigger window condition if the foreground window changed (Thanks jan-leila!)
![]()
- Expand macro action plugin-state to support changing no-match behaviour
- Add option to select "current scene" for some macro actions and conditions to reduce the need for multiple macros for each scene
- Display more information about macros in collapsed state
Fixes:
- Abort macro actions if a wait action was aborted by manual scene change
- Place extended sequence widget in a scroll area
- Allow matching empty files with the macro file condition and file tab
- Format JSON strings whenever they are shown to the user to make editing them much easier
- Set timeouts in curl calls to avoid blocking the whole plugin
- Add a scene trigger to control virtual camera
Special thanks to ASchneider for his great support in testing and spotting bugs!
- Check for invalid settings on the transition tab which would result in the configured transitions to be ignored. (Thanks AuracleTech!)
- Do not only check for libcurl in hardcoded paths (Should only affect Linux / MacOS)
The main focus of this update was to extend the capabilities of the macro tab.
Additions:
Other changes:
- Macro actions:
- Macro conditions:
- Added generic time constraint option to most macro conditions
![]()
![]()
- Added macro condition which lets you trigger actions based on the settings or visibility or activity of sources
![]()
- Added macro condition which lets trigger specified actions at a given interval
![]()
- Added macro condition which lets you trigger actions based on how often other macros were run
![]()
- Pause macros:
- Added new network tab options:
- Added Russian locale (Thanks to Alex-1968!)
Fixes:
- Reduced logging in non-verbose mode
- The macro condition and action areas on the macro tab can now be resized
- Fix rapid scene switches by random tab
- Fix potential crash in audio macro action
- Fix fullscreen and implement maximized checks for MacOS