did some testing, with auto-connect button on, it still disconnects, but helps it reconnect after putting back the headset on. But forgot to mention another bad thing about when it disconnects is it looses the loaded script, so have to reload script in player whenever it disconnects. Pretty sure its disconnecting beacuse headset goes to auto sleep, can increase that time but ofcourse that drains battery. Before it lost slr support, I used to use joyfunplayer connected to slr and it never disconnected even with the headset off for long period of time, so perhaps some way to get it to stay connected is possible dunno.
edit: Or at least if could make it so player doesnt loose the script when disconnects would also be an improvement
besides that all perfect loving the player and its awesome flexibility/functionality
The actual issue might be that if you first start a SLR video+script in DeoVR and only after that connect MFP it wont load the script.
The disconnect/reconnect due to auto sleep should not matter as MFP receives new state on connect.
Or it also might be a bug in DeoVR where you need to set the script again for the api to reset inside DeoVR.
Could MFP be a buttplug.ioserver (i.e. to have buttplug input source) in the further future (e.g. 2028)?
My Intiface Central experience with OSR2 where you can only use a single unconfigurable axis is pretty meh compared to MFP axis configs/hotkeys/mapping/randomiser
(Note: I remember finding an archived C# buttplug server implementation somewhere on buttplug github)
@Yoooi so I made a nice plugin that communicates with a web overlay for quest that contains stuff like range sliders, an edging mode, etc. which are mapped to the DeoVR buttons to make it pretty much on par with the native handy toy controls in the DeoVR app, thanks for the help!
Only thing that I find weird is that I need to press the DeoVR haptic buttons twice to trigger an action. Why is that? Can this be changed / improved or am I just overlooking something?
Sure, should be done by 31.12.2028 depending on how difficult it is to make a dummy server.
Tho this would be a good feature for a plugin.
Cool! I actually wanted to make something very similar, like a dashboard/tile style page you can use to invoke actions. Using AvailableActions, AvailableProperties you should be able to make this fully dynamic/configurable.
So the buttons are really toggles, so you toggle on/off edge mode, so for a full click (off â on â off) you have to press the button it twice.
At least thats the behavior I got pressing the buttons in the UI, maybe they behave differently if you make shortcuts for them in DeoVR. You can enable trace logging and see the button events.
If there is a way to get events for on/off and the UI button press/release separately (press â release â on â press â release â off) I could add it but from my testing DeoVR only sends the feature state not button state.
The default is now changed to 1. The default was 2 because at first this was a DoubleClick shortcut that then changed to configurable amount of clicks but the default value remained.
Ahh, that explains it. Checked out the log and this is what I see for the edging button when using it bound to my controller.
First click
Received command â{âTimeâ:â2024-12-20T18:14:28.172029Zâ,âIsHoldingâ:false,âIsDownâ:true,âTypeâ:3}â
Second click
Received command â{âTimeâ:â2024-12-20T18:14:28.594306Zâ,âIsHoldingâ:false,âIsDownâ:false,âTypeâ:3}â
I think MFP only triggers the button action on IsDown true or false or something.
Personally I think it would make more sense if it triggered on each command that is received regardless of the parameters as this is more usuable. Itâs pretty inconvenient to double click some button combinations and also different from how the rest of the DeoVR app works.
In the future it would be nice to get the IsHolding and IsDown parameters as input too as that would allow us to sync with the deovr switch state and to add logic for hold for edging like DeoVR has with MFP too. This will also align with single click behavior.
Anyways, cool this is possible regardless and curious to hear your thoughts about triggering the action each time a command for a specific haptic button is received.
You know, I know your joking but even that would be fine with me. I just want to be able to register each button event so I can implement the logic I want (a single press toggle). Now you donât have that choice.
You dont need to make solutions, you can just edit the .cs files in any text editor, tho you lose intellisense.
You also dont need GlobalUsings, if you have a solution visual studio will help you add the usings at the top. The global usings for plugins are just so that you dont have to add them for each plugin if you dont use visual studio.
It already responds with the url I put into localhost:5000
Now i stumbled on how to make it play the specified chapter of the specified funscript with tge specified offset because thatâs what EDI does and thatâs what Iâm trying to clone
My current plan is running AssemblyPubliciser over mfp.dll, dnspying Internal source into a singleton, and using itâs now not private methods to run scripts
Well, you dont need my help if you want to make a plugin this way then.
If I understand correctly you can literally make that by handling one event, and publishing another.
var result = new Dictionary<DeviceAxis, IScriptResource>();
var scriptName = context.Request.Url.LocalPath.Replace("/Edi/Play/", "");
var fi = new FileInfo($"./ClassLibrary1/funscript/{scriptName}.funscript");
var fr = FunscriptReader.Default;
var readerResult = fr.FromFileInfo(fi);
if (readerResult.IsSuccess && readerResult.IsMultiAxis)
{
result.Merge(readerResult.Resources);
PublishMessage(new ChangeScriptMessage(result));
}
but it doesnât seem to do anything
âŚ
It does override the graph
⌠but only after Iâve started-stopped internal source?
And I canât seek on the graph
âŚ
I will try MediaPathChangedMessage now
Enough trying for today, hereâs what Iâve got (it doesnât really work but some pieces seem to do something somewhat close to correct) ServerPlugin.cs.txt (4.7 KB)