Sunshine Virtual Monitor provides a way to automatically enable a dedicated Virtual Display Monitor for your Sunshine Streaming Sessions.
It deactivates all the other monitors while streaming and activate them back when the stream is finished.
[!CAUTION] This should be considered BETA - it is working well for me, but at the time of writing this no one else has tested it so far.
While I'm pretty confident this will not break your computer, I don't know enough about Windows Drivers to be 100% sure. Further, there is a real risk that your displays won't come back after a streaming sesion if there is some issue with Sunshine or the scripts - during development and testing I hit quite a few of those cases; I'm confident it shouldn't happen during normal operation anymore, but just in case it does, you can escape in a few ways:
pnputil /disable-device /deviceid root\iddsampledriver
[!NOTE] If you want to be extra secure you can try to bind this command to some key combination ahead of time (make sure it runs as admin).
To do this, create a new shortcut on Desktop (
Right Click
>New
>Shortcut
) and copy/paste the command above (pnputil /disable-device /deviceid root\iddsampledriver
) in the path box.Give it a name like
Disable Virtual Display Driver
and close the window. Now go to the file properties and click in theShortcut Key
area, then enter a combination of keys to create the shortcut. (e.g.Ctrl
+Alt
+5
)Open the
Advanced...
box and check theRun as administrator
checkbox.Save and close.
DisplaySwitch 1
[!NOTE] This should enable only your primary display, which should not be the virtual monitor, allowing you to fix things up.
-
Press Windows + P
to get into the display selection dialogue, then press Tab
+ move around to select something different from the current setup. I recommend practicing this ahead of time if you want to go this route, just so you have an idea of what it feels like; in the broken case it should have the "second screen only" option pre-selected.
Connect another display to your computer - this will cause windows to try and apply a new configuration to the displays that should get signal on at least one of the real ones.
If you already have a second monitor, disconnect it - similar to the point above, might result in getting signal back.
First, download the latest release (.zip
file) and unzip it.
Then, you'll need to add a virtual display to your computer. You can follow the directions from Virtual Display Driver - afaict, this is the only way to get HDR support on a virtual monitor. Note: while the driver and device will exist, they will be disabled while sunshine isn't being used.
Once you're done adding the device, make sure to disable it. You can do this in device manager, or you can run the following command in an administrator terminal:
pnputil /disable-device /deviceid root\iddsampledriver
Then, you'll need to download MultiMonitorTool - make sure to place the extracted files in the same directory as the scripts. These scripts assume that the multi-monitor-tool in use is the 64-bit version - if you need the 32 bit version, you'll need to edit this line for the correct path:
$multitool = Join-Path -Path $filePath -ChildPath "multimonitortool-x64\MultiMonitorTool.exe"
The powershell scripts use a module called WindowsDisplayManager
- you can install this by starting a privileged powershell, and running:
Install-Module -Name WindowsDisplayManager
This is used to turn off / restore vsync when the stream starts/ends.
Just download vsync-toggle and put it in the same directory as the scripts.
After the steps above, the scripts directory will look like this
LICENSE
multimonitortool-x64 (directory)
README.md
setup_sunvdm.ps1
teardown_sunvdm.ps1
vsynctoggle-1.1.0-x86_64.exe
In all the text below, replace %PATH_TO_THIS_REPOSITORY%
with the full path to this repository.
[!NOTE] The commands below will forward the scripts output to a file in this repository, named
sunvdm.log
- this is optional and can be removed if you don't care for logs / can be directed somewhere else.
In the sunshine UI navigate to Configuration, and go to the General Tab.
At the bottom, in the Command Preparations
section, you will press the +Add
button to add a new command, with the following setup:
In the first text box the config.do_cmd
column, you will write:
cmd /C powershell.exe -executionpolicy bypass -windowstyle hidden -file "%PATH_TO_THIS_REPOSITORY%\setup_sunvdm.ps1" %SUNSHINE_CLIENT_WIDTH% %SUNSHINE_CLIENT_HEIGHT% %SUNSHINE_CLIENT_FPS% %SUNSHINE_CLIENT_HDR% > "%PATH_TO_THIS_REPOSITORY%\sunvdm.log" 2>&1
In the second text box, the config.undo_cmd
column, you will write:
cmd /C powershell.exe -executionpolicy bypass -windowstyle hidden -file "%PATH_TO_THIS_REPOSITORY%\teardown_sunvdm.ps1" >> "%PATH_TO_THIS_REPOSITORY%\sunvdm.log" 2>&1
[!WARNING] Make sure to replace
%PATH_TO_THIS_REPOSITORY%
with the correct path to the folder containing the scripts.[!NOTE] You will also select the checkbox for
config.elevated
under theconfig.run_as
column (we need to run as elevated in order to enable and disable the display device).
You can set the following in your sunshine.conf
config file:
global_prep_cmd = [{"do":"cmd /C powershell.exe -executionpolicy bypass -windowstyle hidden -file \"%PATH_TO_THIS_REPOSITORY%\\setup_sunvdm.ps1\" %SUNSHINE_CLIENT_WIDTH% %SUNSHINE_CLIENT_HEIGHT% %SUNSHINE_CLIENT_FPS% %SUNSHINE_CLIENT_HDR% > \"%PATH_TO_THIS_REPOSITORY%\\sunvdm.log\" 2>&1","undo":"cmd /C powershell.exe -executionpolicy bypass -windowstyle hidden -file \"%PATH_TO_THIS_REPOSITORY%\\teardown_sunvdm.ps1\" >> \"%PATH_TO_THIS_REPOSITORY%\\sunvdm.log\" 2>&1","elevated":"true"}]
[!NOTE] If you already have something in the
global_prep_cmd
that you setup, you should be savvy enough to know where/how to add this to the list.