diff --git a/index.html b/index.html index 32f6fa3..9be8d76 100644 --- a/index.html +++ b/index.html @@ -77,9 +77,9 @@

SteamVR Binding Setup

- After you have the instance loaded in launcher, you'll still have to setup the bindings, which is - excruciatingly difficult usually. We've managed to automate most of this, but you'll still have to do the - following at least one time: + After you have the instance loaded in launcher, you still have to setup the bindings. + If you have Index Controllers (Knuckles) or Pico Controllers, you can use our setup script + to automatically activate the bindings for you:

    @@ -89,13 +89,17 @@
  1. Select "Minecraft Folder" to open the .minecraft folder
  2. Locate the file named "setup-steamvr-bindings.vbs"
  3. Double-click the "setup-steamvr-bindings.vbs" script to run it.
  4. -
  5. the script installs the bindings for you!
  6. +
  7. The script clicks all the buttons for you in the UI for you!
+

If you don't like my dude trust me vbs script, you can copy the .json files into Documents/steamvr/input/imports/ + yourself and click the buttons in the steamVR binding webUI (the imported bindings should show up in there).

+

Manual Binding Setup

- If you don't want to use our recommended bindings, you should at least setup the following bindings: + If you you have another controller, you'll have to do this manually. The vivecraft defaults mostly work, but you'll + want to add the following bindings to the "Modded" tab of the binding UI:

- in the "Modded" tab of the binding UI. See this visual - guide for help on how to do this. +

+ See this visual + guide for help on how to do this. You'll can debind some useless vivecraft stuff like + the teleport if you're out of buttons to use.

+ If you do make a binding for the controllers you like (or find something better than our recommended bindings), + save it as a personal binding, upload the json file (it's in Documents/steamvr/input) to catbox + or wherever and let us know in the thread so we can update our script.

diff --git a/index.toml b/index.toml index 767830c..0e46d41 100644 --- a/index.toml +++ b/index.toml @@ -2527,6 +2527,10 @@ hash = "074647ab0fdff44721c7b3ba624295c78dbdc54ec00962f2cf0acedd63d065d3" file = "org.jrbudda.vivecraft.steamvrinput_knuckles.json" hash = "7a8d134d5fbffb799116c3c7d0a91fcb76a4d57347508538286585dd5339b181" +[[files]] +file = "org.jrbudda.vivecraft.steamvrinput_pico_controller.json" +hash = "5983d9c50c2fd5b02f5899d41864bf4d7a1796e040af7b429d6d4debf6150b7c" + [[files]] file = "patchouli_books/vrcrawler/advancements/grant_book_on_first_join.json" hash = "941da34c9ff77339118c23bbf3db07aaa44e38fb068f1619e6bab12a3b60168a" @@ -2565,7 +2569,7 @@ hash = "3223d26ef6c683a5a016a7749c30121457b4f7218641f0db48dbf7ebbab28e48" [[files]] file = "setup-steamvr-bindings.ps1" -hash = "38d2fd63756957a14e4443cbe5b68d09dc3d609b297e038370935dfa8132b842" +hash = "d8e740fb42dd7151137b10c79bd4c39139468c0e10e17ecbefbca3f87aa908d4" [[files]] file = "setup-steamvr-bindings.vbs" diff --git a/org.jrbudda.vivecraft.steamvrinput_pico_controller.json b/org.jrbudda.vivecraft.steamvrinput_pico_controller.json new file mode 100644 index 0000000..ca8182a --- /dev/null +++ b/org.jrbudda.vivecraft.steamvrinput_pico_controller.json @@ -0,0 +1,332 @@ +{ + "action_manifest_version" : 0, + "alias_info" : {}, + "app_key" : "org.jrbudda.vivecraft.steamvrinput", + "bindings" : { + "/actions/climbey" : { + "sources" : [ + { + "inputs" : { + "click" : { + "output" : "/actions/climbey/in/vivecraft.key.climbeygrab" + } + }, + "mode" : "button", + "path" : "/user/hand/left/input/trigger" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/climbey/in/vivecraft.key.climbeyjump" + } + }, + "mode" : "button", + "path" : "/user/hand/left/input/grip" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/climbey/in/vivecraft.key.climbeyjump" + } + }, + "mode" : "button", + "path" : "/user/hand/right/input/grip" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/climbey/in/vivecraft.key.climbeygrab" + } + }, + "mode" : "button", + "path" : "/user/hand/right/input/trigger" + } + ] + }, + "/actions/global" : { + "haptics" : [ + { + "output" : "/actions/global/out/lefthaptic", + "path" : "/user/hand/left/output/haptic" + }, + { + "output" : "/actions/global/out/righthaptic", + "path" : "/user/hand/right/output/haptic" + } + ], + "poses" : [ + { + "output" : "/actions/global/in/lefthand", + "path" : "/user/hand/left/pose/raw" + }, + { + "output" : "/actions/global/in/righthand", + "path" : "/user/hand/right/pose/raw" + } + ], + "sources" : [ + { + "inputs" : { + "click" : { + "output" : "/actions/global/in/key.inventory" + } + }, + "mode" : "trigger", + "path" : "/user/hand/left/input/trigger" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/global/in/vivecraft.key.ingamemenubutton" + } + }, + "mode" : "trigger", + "path" : "/user/hand/left/input/grip" + } + ] + }, + "/actions/gui" : { + "sources" : [ + { + "inputs" : { + "click" : { + "output" : "/actions/gui/in/vivecraft.key.guirightclick" + } + }, + "mode" : "button", + "path" : "/user/hand/right/input/grip" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/gui/in/vivecraft.key.guileftclick" + } + }, + "mode" : "button", + "path" : "/user/hand/right/input/trigger" + }, + { + "inputs" : { + "scroll" : { + "output" : "/actions/gui/in/vivecraft.key.guiscrollaxis" + } + }, + "mode" : "scroll", + "parameters" : { + "scroll_mode" : "discrete" + }, + "path" : "/user/hand/right/input/joystick" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/gui/in/vivecraft.key.guishift" + } + }, + "mode" : "toggle_button", + "path" : "/user/hand/left/input/joystick" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/gui/in/vivecraft.key.guimiddleclick" + } + }, + "mode" : "trigger", + "path" : "/user/hand/left/input/trigger" + } + ] + }, + "/actions/ingame" : { + "sources" : [ + { + "inputs" : { + "click" : { + "output" : "/actions/ingame/in/key.attack" + } + }, + "mode" : "button", + "path" : "/user/hand/right/input/trigger" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/ingame/in/key.jump" + } + }, + "mode" : "button", + "path" : "/user/hand/right/input/b" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/ingame/in/key.sneak" + } + }, + "mode" : "toggle_button", + "path" : "/user/hand/right/input/a" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/ingame/in/key.sprint" + }, + "position" : { + "output" : "/actions/ingame/in/vivecraft.key.freemovestrafe" + } + }, + "mode" : "joystick", + "path" : "/user/hand/left/input/joystick" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/ingame/in/vivecraft.key.hotbarprev" + } + }, + "mode" : "button", + "path" : "/user/hand/left/input/x" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/ingame/in/vivecraft.key.hotbarnext" + } + }, + "mode" : "button", + "path" : "/user/hand/left/input/y" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/ingame/in/vivecraft.key.radialmenu" + }, + "position" : { + "output" : "/actions/ingame/in/vivecraft.key.freemovestrafe" + } + }, + "mode" : "trackpad", + "path" : "/user/hand/left/input/trackpad" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/ingame/in/key.use" + } + }, + "mode" : "trigger", + "path" : "/user/hand/right/input/grip" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/ingame/in/vivecraft.key.hotbarnext" + } + }, + "mode" : "button", + "path" : "/user/hand/right/input/application_menu" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/ingame/in/key.jump" + } + }, + "mode" : "trackpad", + "path" : "/user/hand/right/input/trackpad" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/ingame/in/vivecraft.key.hotbarprev" + } + }, + "mode" : "button", + "path" : "/user/hand/left/input/application_menu" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/ingame/in/vivecraft.key.radialmenu" + }, + "position" : { + "output" : "/actions/ingame/in/vivecraft.key.freemoverotate" + } + }, + "mode" : "joystick", + "path" : "/user/hand/right/input/joystick" + } + ] + }, + "/actions/keyboard" : { + "sources" : [ + { + "inputs" : { + "click" : { + "output" : "/actions/keyboard/in/vivecraft.key.keyboardshift" + } + }, + "mode" : "button", + "path" : "/user/hand/left/input/grip" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/keyboard/in/vivecraft.key.keyboardshift" + } + }, + "mode" : "button", + "path" : "/user/hand/right/input/grip" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/keyboard/in/vivecraft.key.keyboardclick" + } + }, + "mode" : "button", + "path" : "/user/hand/left/input/trigger" + }, + { + "inputs" : { + "click" : { + "output" : "/actions/keyboard/in/vivecraft.key.keyboardclick" + } + }, + "mode" : "button", + "path" : "/user/hand/right/input/trigger" + } + ] + }, + "/actions/mod" : { + "chords" : [ + { + "inputs" : [ + [ "/user/hand/left/input/joystick", "single" ], + [ "/user/hand/right/input/joystick", "single" ] + ], + "output" : "/actions/mod/in/keybinds.combatroll.roll" + } + ], + "sources" : [ + { + "inputs" : {}, + "mode" : "button", + "path" : "/user/hand/left/input/joystick" + }, + { + "inputs" : {}, + "mode" : "button", + "path" : "/user/hand/right/input/joystick" + } + ] + } + }, + "category" : "steamvr_input", + "controller_type" : "pico_controller", + "description" : "I suffered greatly while making this work.\nPressing down both sticks at once will make you combat roll forward, however you will need to unbind shader reloading in options.txt in Minecraft's folder, by rewriting\nkey_iris.keybind.reload:key.keyboard.r to key_iris.keybind.reload:key.keyboard.unknown\n- X and Y is used to cycle the hotbar, B will jump and A will sneak.\n- Clicking the left stick while running will toggle sprint until you stop moving.\n- Clicking the right stick will open the radial menu.\n- Gripping with left hand will close open menus and open the pause menu.\n- Right grip will use or place items\n\n", + "interaction_profile" : "", + "name" : "Pico Controller bindings for /vrg/ crawler", + "options" : {}, + "simulated_actions" : [] +} diff --git a/pack.toml b/pack.toml index e4a212d..5b1564f 100644 --- a/pack.toml +++ b/pack.toml @@ -5,7 +5,7 @@ pack-format = "packwiz:1.1.0" [index] file = "index.toml" hash-format = "sha256" -hash = "206423fa663b9ade121ddcca6535192f9ded700b548c11d35fb2bb595dff93d1" +hash = "6534cd29e763deb62427190d662355708e41c37700372d62543785e074b9e6a3" [versions] fabric = "0.16.0" diff --git a/setup-steamvr-bindings.ps1 b/setup-steamvr-bindings.ps1 index 8fed399..5157a02 100644 --- a/setup-steamvr-bindings.ps1 +++ b/setup-steamvr-bindings.ps1 @@ -35,41 +35,93 @@ if (-not (Test-Path $steamVRImportDir)) { New-Item -ItemType Directory -Path $steamVRImportDir -Force } -# Destination path for the bindings file -$destBindingsFile = Join-Path -Path $steamVRImportDir -ChildPath "org.jrbudda.vivecraft.steamvrinput_knuckles.json" +# Function to copy and import bindings +function Import-SteamVRBinding { + param ( + [string]$bindingsFilePath, + [string]$controllerType + ) -# Copy the bindings file -Copy-Item -Path $sourceBindingsFile -Destination $destBindingsFile -Force + $fileName = Split-Path $bindingsFilePath -Leaf + $destBindingsFile = Join-Path -Path $steamVRImportDir -ChildPath $fileName -Write-Host "Calling SteamVR API..." -# Convert the destination file path to a file URI -$fileUri = [System.Uri]::new($destBindingsFile).AbsoluteUri + # Copy the bindings file + Copy-Item -Path $bindingsFilePath -Destination $destBindingsFile -Force -# Construct the body with the correct file URI -$body = @{ - app_key = "org.jrbudda.vivecraft.steamvrinput" - controller_type = "knuckles" - url = $fileUri -} | ConvertTo-Json + Write-Host "Calling SteamVR API for $controllerType..." + # Convert the destination file path to a file URI + $fileUri = [System.Uri]::new($destBindingsFile).AbsoluteUri -try { - $response = Invoke-WebRequest -UseBasicParsing -Uri "http://localhost:27062/input/selectconfig.action" ` - -Method POST ` - -Headers @{ - "Accept" = "application/json, text/plain, */*" - "Origin" = "http://localhost:27062" - "Referer" = "http://localhost:27062/dashboard/controllerbinding.html" - } ` - -ContentType "application/json" ` - -Body $body + # Construct the body with the correct file URI + $body = @{ + app_key = "org.jrbudda.vivecraft.steamvrinput" + controller_type = $controllerType + url = $fileUri + } | ConvertTo-Json - if ($response.StatusCode -eq 200) { - $wshell = New-Object -ComObject Wscript.Shell - $wshell.Popup("Sucessfully set recommended SteamVR bindings for Vivecraft.", 0, "Success", 0x0 + 0x40) + try { + $response = Invoke-WebRequest -UseBasicParsing -Uri "http://localhost:27062/input/selectconfig.action" ` + -Method POST ` + -Headers @{ + "Accept" = "application/json, text/plain, */*" + "Origin" = "http://localhost:27062" + "Referer" = "http://localhost:27062/dashboard/controllerbinding.html" + } ` + -ContentType "application/json" ` + -Body $body + + if ($response.StatusCode -eq 200) { + Write-Host "Successfully set recommended SteamVR bindings for Vivecraft ($controllerType)." + } + } + catch { + Write-Error "Failed to call the API for $controllerType: $_" + return $false + } + + return $true +} + +# Get the directory that the script is in +$currentDir = Split-Path -Parent $MyInvocation.MyCommand.Definition + +# Define bindings and controller types +$bindings = @( + @{ + File = "org.jrbudda.vivecraft.steamvrinput_knuckles.json" + Type = "knuckles" + }, + @{ + File = "org.jrbudda.vivecraft.steamvrinput_pico_controller.json" + Type = "pico_controller" + } + # Add more bindings here as needed +) + +$allSucceeded = $true + +foreach ($binding in $bindings) { + $sourceBindingsFile = Join-Path -Path $currentDir -ChildPath $binding.File + + # Ensure the source file exists + if (-not (Test-Path $sourceBindingsFile)) { + Write-Error "Bindings file not found: $sourceBindingsFile" + $allSucceeded = $false + continue + } + + $result = Import-SteamVRBinding -bindingsFilePath $sourceBindingsFile -controllerType $binding.Type + if (-not $result) { + $allSucceeded = $false } } -catch { - Write-Error "Failed to call the API: $_" - $null = $Host.UI.RawUI.ReadKey("NoEcho,IncludeKeyDown") - exit 1 + +if ($allSucceeded) { + $wshell = New-Object -ComObject Wscript.Shell + $wshell.Popup("Successfully set recommended SteamVR bindings for Vivecraft for all controller types.", 0, "Success", 0x0 + 0x40) +} else { + $wshell = New-Object -ComObject Wscript.Shell + $wshell.Popup("Some errors occurred while setting SteamVR bindings. Please check the console for details.", 0, "Warning", 0x0 + 0x30) } + +$null = $Host.UI.RawUI.ReadKey("NoEcho,IncludeKeyDown")