add XR magic for fun

This commit is contained in:
Holly Stubbs 2025-03-07 02:44:40 +00:00
parent 4f7b20a5ca
commit 4ac2bdbe6a
12 changed files with 1920 additions and 59 deletions

View file

@ -10,8 +10,10 @@ export_filter="all_resources"
include_filter=""
exclude_filter=""
export_path=""
patches=PackedStringArray()
encryption_include_filters=""
encryption_exclude_filters=""
seed=0
encrypt_pck=false
encrypt_directory=false
script_export_mode=2
@ -39,3 +41,70 @@ progressive_web_app/icon_144x144=""
progressive_web_app/icon_180x180=""
progressive_web_app/icon_512x512=""
progressive_web_app/background_color=Color(0, 0, 0, 1)
[preset.1]
name="Windows Desktop"
platform="Windows Desktop"
runnable=true
advanced_options=false
dedicated_server=false
custom_features=""
export_filter="all_resources"
include_filter=""
exclude_filter=""
export_path="../../GodotExports/SCPCB/Windows/SCPCB.exe"
patches=PackedStringArray()
encryption_include_filters=""
encryption_exclude_filters=""
seed=0
encrypt_pck=false
encrypt_directory=false
script_export_mode=2
[preset.1.options]
custom_template/debug=""
custom_template/release=""
debug/export_console_wrapper=1
binary_format/embed_pck=true
texture_format/s3tc_bptc=true
texture_format/etc2_astc=false
binary_format/architecture="x86_64"
codesign/enable=false
codesign/timestamp=true
codesign/timestamp_server_url=""
codesign/digest_algorithm=1
codesign/description=""
codesign/custom_options=PackedStringArray()
application/modify_resources=true
application/icon=""
application/console_wrapper_icon=""
application/icon_interpolation=4
application/file_version=""
application/product_version=""
application/company_name=""
application/product_name=""
application/file_description=""
application/copyright=""
application/trademarks=""
application/export_angle=0
application/export_d3d12=0
application/d3d12_agility_sdk_multiarch=true
ssh_remote_deploy/enabled=false
ssh_remote_deploy/host="user@host_ip"
ssh_remote_deploy/port="22"
ssh_remote_deploy/extra_args_ssh=""
ssh_remote_deploy/extra_args_scp=""
ssh_remote_deploy/run_script="Expand-Archive -LiteralPath '{temp_dir}\\{archive_name}' -DestinationPath '{temp_dir}'
$action = New-ScheduledTaskAction -Execute '{temp_dir}\\{exe_name}' -Argument '{cmd_args}'
$trigger = New-ScheduledTaskTrigger -Once -At 00:00
$settings = New-ScheduledTaskSettingsSet -AllowStartIfOnBatteries -DontStopIfGoingOnBatteries
$task = New-ScheduledTask -Action $action -Trigger $trigger -Settings $settings
Register-ScheduledTask godot_remote_debug -InputObject $task -Force:$true
Start-ScheduledTask -TaskName godot_remote_debug
while (Get-ScheduledTask -TaskName godot_remote_debug | ? State -eq running) { Start-Sleep -Milliseconds 100 }
Unregister-ScheduledTask -TaskName godot_remote_debug -Confirm:$false -ErrorAction:SilentlyContinue"
ssh_remote_deploy/cleanup_script="Stop-ScheduledTask -TaskName godot_remote_debug -ErrorAction:SilentlyContinue
Unregister-ScheduledTask -TaskName godot_remote_debug -Confirm:$false -ErrorAction:SilentlyContinue
Remove-Item -Recurse -Force '{temp_dir}'"

1713
openxr_action_map.tres Normal file

File diff suppressed because it is too large Load diff

View file

@ -93,3 +93,7 @@ renderer/rendering_method="gl_compatibility"
renderer/rendering_method.mobile="gl_compatibility"
environment/defaults/default_clear_color=Color(0, 0, 0, 1)
occlusion_culling/use_occlusion_culling=true
[xr]
shaders/enabled=true

25
scenes/world/Test.tscn Normal file
View file

@ -0,0 +1,25 @@
[gd_scene load_steps=3 format=3 uid="uid://gc8dmdpmhxk5"]
[ext_resource type="PackedScene" uid="uid://bxibyn63ycvwo" path="res://scenes/world/XrSetup.tscn" id="1_uel4q"]
[sub_resource type="BoxMesh" id="BoxMesh_b77k8"]
[node name="Test" type="Node3D"]
[node name="XrOrigin" parent="." instance=ExtResource("1_uel4q")]
[node name="MeshInstance3D" type="MeshInstance3D" parent="."]
transform = Transform3D(0.873517, 0.486793, 0, -0.439843, 0.789269, -0.428478, -0.20858, 0.374283, 0.903552, -3.76044, 0, 0)
mesh = SubResource("BoxMesh_b77k8")
[node name="MeshInstance3D2" type="MeshInstance3D" parent="."]
transform = Transform3D(0.40947, -0.707359, 0.576175, -0.212914, 0.540017, 0.814279, -0.887131, -0.456099, 0.0705146, 0.354805, 0, -4.08396)
mesh = SubResource("BoxMesh_b77k8")
[node name="MeshInstance3D3" type="MeshInstance3D" parent="."]
transform = Transform3D(-0.00492204, -0.0975042, -0.174553, -0.0879686, 0.157854, -0.0856956, 0.179548, 0.0746669, -0.0467713, -2.02994, -0.0159459, -0.577685)
mesh = SubResource("BoxMesh_b77k8")
[node name="MeshInstance3D4" type="MeshInstance3D" parent="."]
transform = Transform3D(0.150185, 0.124727, -0.0434474, -0.0425827, 0.108003, 0.162856, 0.125025, -0.113042, 0.107658, 0.849757, -0.0159459, 4.45435)
mesh = SubResource("BoxMesh_b77k8")

View file

@ -0,0 +1,11 @@
[gd_scene load_steps=2 format=3 uid="uid://bgvs6njbg352u"]
[ext_resource type="PackedScene" uid="uid://bc46lc1tdvrio" path="res://scenes/world/DynamicMap.tscn" id="1_2nwmf"]
[node name="XrDynamicMap" type="Node3D"]
[node name="SubViewport" type="SubViewport" parent="."]
use_xr = true
size = Vector2i(0, 0)
[node name="DynamicMap" parent="SubViewport" instance=ExtResource("1_2nwmf")]

41
scenes/world/XrSetup.tscn Normal file
View file

@ -0,0 +1,41 @@
[gd_scene load_steps=5 format=3 uid="uid://bxibyn63ycvwo"]
[ext_resource type="Script" uid="uid://cr0a5b6avy81f" path="res://src/XRSetup.gd" id="1_wg80d"]
[sub_resource type="StandardMaterial3D" id="StandardMaterial3D_547rj"]
resource_local_to_scene = true
transparency = 1
shading_mode = 0
texture_filter = 0
[sub_resource type="PlaneMesh" id="PlaneMesh_737xf"]
material = SubResource("StandardMaterial3D_547rj")
size = Vector2(1, 0.563)
[sub_resource type="CapsuleMesh" id="CapsuleMesh_vwp3e"]
radius = 0.0025
height = 0.05
[node name="XrOrigin" type="XROrigin3D"]
world_scale = 0.5
script = ExtResource("1_wg80d")
[node name="XRCamera3D" type="XRCamera3D" parent="."]
[node name="Screen" type="MeshInstance3D" parent="XRCamera3D"]
transform = Transform3D(1, 0, 0, 0, -4.37114e-08, -1, 0, 1, -4.37114e-08, 0, 0, -0.75)
visible = false
mesh = SubResource("PlaneMesh_737xf")
[node name="XRControllerL" type="XRController3D" parent="."]
tracker = &"left_hand"
[node name="MeshInstance3D" type="MeshInstance3D" parent="XRControllerL"]
mesh = SubResource("CapsuleMesh_vwp3e")
[node name="XRControllerR" type="XRController3D" parent="."]
tracker = &"right_hand"
[node name="MeshInstance3D2" type="MeshInstance3D" parent="XRControllerR"]
mesh = SubResource("CapsuleMesh_vwp3e")
skeleton = NodePath("../../XRControllerL")

View file

@ -12,6 +12,8 @@ var player: Player
var FPSfactor: float
var VRMode: bool = false
func GetTextureFromCache(rawFileName:String):
var fixedName = rawFileName.replace("\\", "/")
if textureCache.has(fixedName):
@ -165,7 +167,26 @@ var difficulties: Array = Utils.Init1DArray(4)
var SelectedDifficulty: Difficulty
var xrInterface: XRInterface
var xrSetup: XrSetup
func _ready():
if Global.VRMode:
xrInterface = XRServer.find_interface("OpenXR")
if xrInterface and xrInterface.is_initialized():
print("OpenXR initialized successfully")
# Turn off v-sync!
DisplayServer.window_set_vsync_mode(DisplayServer.VSYNC_DISABLED)
# Change our main viewport to output to the HMD
get_viewport().use_xr = true
#xrSetup = load("res://scenes/world/XrSetup.tscn").instantiate()
#add_child(xrSetup)
else:
print("OpenXR not initialized, please check if your headset is connected")
options = INI.Load("res://options.ini")
materials = INI.Load("res://Data/materials.ini")

View file

@ -12,11 +12,18 @@ var sprintBar: Control
var Hud: Control
var map: Node3D
var xrSetup: XrSetup
func _ready() -> void:
map = get_parent()
Global.player = self
head = $Head
camera = $Head/Camera
if Global.VRMode:
camera.queue_free()
xrSetup = load("res://scenes/world/XrSetup.tscn").instantiate()
add_child(xrSetup)
camera = xrSetup.camera
floorRay = $FloorRay
floorPick = $FloorPick
blinkIconBG = $HUD/BlinkIconBG
@ -35,8 +42,6 @@ func _ready() -> void:
#End Select
BlinkTimer = BLINKFREQ
var CurrSpeed: float
var CrouchState: float
var Crouch: float
@ -281,8 +286,9 @@ func _process(delta: float) -> void:
Crouch = 0
#RotateEntity Collider, WrapAngle(EntityPitch(Camera)), WrapAngle(EntityYaw(Camera)), 0
camera.rotation.x = deg_to_rad(Rotation.x)
head.rotation.y = deg_to_rad(Rotation.y)
if not Global.VRMode:
camera.rotation.x = deg_to_rad(Rotation.x)
head.rotation.y = deg_to_rad(Rotation.y)
movementSpeed = movementSpeed * NoClipSpeed
@ -340,12 +346,13 @@ func _process(delta: float) -> void:
var cameraRoll = max(min(Global.Sin(Shake / 2) * 2.5 * min(Injuries + 0.25, 3.0), 8.0), -8.0)
var cameraBob = (Global.Sin(Shake) / (20.0 + CrouchState * 20.0)) * 0.6
camera.rotation.x = deg_to_rad(Rotation.x)
camera.rotation.z = deg_to_rad(cameraRoll * 0.5)
camera.position.y = cameraBob
#head.position.y = 1.15 + 0.6 * (1 - CrouchState)
head.position.y = cameraBob + 0.9 + CrouchState * -0.3
head.rotation.y = deg_to_rad(Rotation.y)
if not Global.VRMode:
camera.rotation.x = deg_to_rad(Rotation.x)
camera.rotation.z = deg_to_rad(cameraRoll * 0.5)
camera.position.y = cameraBob
#head.position.y = 1.15 + 0.6 * (1 - CrouchState)
head.position.y = cameraBob + 0.9 + CrouchState * -0.3
head.rotation.y = deg_to_rad(Rotation.y)
var CollidedFloor = false
if floorRay.is_colliding():
@ -455,12 +462,13 @@ func snapDownToFloorCheck():
const CONTROLLER_DEADZONE = 0.20;
func _input(event: InputEvent) -> void:
if event is InputEventMouseMotion:
Rotation.y -= event.relative.x / 2
Rotation.x -= event.relative.y / 2
if Rotation.x > 70:
Rotation.x = 70
if Rotation.x < -70:
Rotation.x = -70
if not Global.VRMode:
Rotation.y -= event.relative.x / 2
Rotation.x -= event.relative.y / 2
if Rotation.x > 70:
Rotation.x = 70
if Rotation.x < -70:
Rotation.x = -70
#event.velocity
if event is InputEventJoypadMotion:
# LeftRight = 2, UpDown = 3

View file

@ -1,42 +0,0 @@
extends Node
;~IDEal Editor Parameters:
;~F#1#14#29#13B#343#535#545#5B1#630#68D#6B4#6C2#6CC#6D9#8CA#8EB#93F#976#983#9BD
;~F#9CE#9EE#9F7#A01#A10#B0B#B2D#DE2#E29#E3F#E4B#E68#EB9#ED2#FA1#10A3#1123#113C#115B#11C6
;~F#11D3#11EC#1284#1439#152D#1581#1633#16D4#1796#17A9#187A#18A7#18C4#18EB#191B#1941#1969#19BB#19F8#1A29
;~F#1A3C#1AFD#1B6A#1B7D#1B8B#1BCF#1BF0#1CDE#1D53#1E50#1ED1#1F1F#1F24#1F73#1F79#213E
;~B#10D3#1DD1
;~C#Blitz3D

View file

@ -1 +0,0 @@
uid://qgv7j32s51vr

11
src/XRSetup.gd Normal file
View file

@ -0,0 +1,11 @@
extends XROrigin3D
class_name XrSetup
@onready var camera = $XRCamera3D
@onready var screen = $XRCamera3D/Screen
#func _ready() -> void:
#var shit = ViewportTexture.new()
#shit.viewport_path = get_viewport().get_path()
#print(shit.viewport_path)
#screen.mesh.material.albedo_texture = get_viewport().get_texture()

1
src/XRSetup.gd.uid Normal file
View file

@ -0,0 +1 @@
uid://cr0a5b6avy81f