add XR magic for fun
This commit is contained in:
parent
4f7b20a5ca
commit
4ac2bdbe6a
12 changed files with 1920 additions and 59 deletions
|
@ -10,8 +10,10 @@ export_filter="all_resources"
|
||||||
include_filter=""
|
include_filter=""
|
||||||
exclude_filter=""
|
exclude_filter=""
|
||||||
export_path=""
|
export_path=""
|
||||||
|
patches=PackedStringArray()
|
||||||
encryption_include_filters=""
|
encryption_include_filters=""
|
||||||
encryption_exclude_filters=""
|
encryption_exclude_filters=""
|
||||||
|
seed=0
|
||||||
encrypt_pck=false
|
encrypt_pck=false
|
||||||
encrypt_directory=false
|
encrypt_directory=false
|
||||||
script_export_mode=2
|
script_export_mode=2
|
||||||
|
@ -39,3 +41,70 @@ progressive_web_app/icon_144x144=""
|
||||||
progressive_web_app/icon_180x180=""
|
progressive_web_app/icon_180x180=""
|
||||||
progressive_web_app/icon_512x512=""
|
progressive_web_app/icon_512x512=""
|
||||||
progressive_web_app/background_color=Color(0, 0, 0, 1)
|
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
1713
openxr_action_map.tres
Normal file
File diff suppressed because it is too large
Load diff
|
@ -93,3 +93,7 @@ renderer/rendering_method="gl_compatibility"
|
||||||
renderer/rendering_method.mobile="gl_compatibility"
|
renderer/rendering_method.mobile="gl_compatibility"
|
||||||
environment/defaults/default_clear_color=Color(0, 0, 0, 1)
|
environment/defaults/default_clear_color=Color(0, 0, 0, 1)
|
||||||
occlusion_culling/use_occlusion_culling=true
|
occlusion_culling/use_occlusion_culling=true
|
||||||
|
|
||||||
|
[xr]
|
||||||
|
|
||||||
|
shaders/enabled=true
|
||||||
|
|
25
scenes/world/Test.tscn
Normal file
25
scenes/world/Test.tscn
Normal 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")
|
11
scenes/world/XrDynamicMap.tscn
Normal file
11
scenes/world/XrDynamicMap.tscn
Normal 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
41
scenes/world/XrSetup.tscn
Normal 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")
|
|
@ -12,6 +12,8 @@ var player: Player
|
||||||
|
|
||||||
var FPSfactor: float
|
var FPSfactor: float
|
||||||
|
|
||||||
|
var VRMode: bool = false
|
||||||
|
|
||||||
func GetTextureFromCache(rawFileName:String):
|
func GetTextureFromCache(rawFileName:String):
|
||||||
var fixedName = rawFileName.replace("\\", "/")
|
var fixedName = rawFileName.replace("\\", "/")
|
||||||
if textureCache.has(fixedName):
|
if textureCache.has(fixedName):
|
||||||
|
@ -165,7 +167,26 @@ var difficulties: Array = Utils.Init1DArray(4)
|
||||||
|
|
||||||
var SelectedDifficulty: Difficulty
|
var SelectedDifficulty: Difficulty
|
||||||
|
|
||||||
|
var xrInterface: XRInterface
|
||||||
|
var xrSetup: XrSetup
|
||||||
|
|
||||||
func _ready():
|
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")
|
options = INI.Load("res://options.ini")
|
||||||
materials = INI.Load("res://Data/materials.ini")
|
materials = INI.Load("res://Data/materials.ini")
|
||||||
|
|
||||||
|
|
|
@ -12,11 +12,18 @@ var sprintBar: Control
|
||||||
var Hud: Control
|
var Hud: Control
|
||||||
var map: Node3D
|
var map: Node3D
|
||||||
|
|
||||||
|
var xrSetup: XrSetup
|
||||||
|
|
||||||
func _ready() -> void:
|
func _ready() -> void:
|
||||||
map = get_parent()
|
map = get_parent()
|
||||||
Global.player = self
|
Global.player = self
|
||||||
head = $Head
|
head = $Head
|
||||||
camera = $Head/Camera
|
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
|
floorRay = $FloorRay
|
||||||
floorPick = $FloorPick
|
floorPick = $FloorPick
|
||||||
blinkIconBG = $HUD/BlinkIconBG
|
blinkIconBG = $HUD/BlinkIconBG
|
||||||
|
@ -35,8 +42,6 @@ func _ready() -> void:
|
||||||
#End Select
|
#End Select
|
||||||
BlinkTimer = BLINKFREQ
|
BlinkTimer = BLINKFREQ
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
var CurrSpeed: float
|
var CurrSpeed: float
|
||||||
var CrouchState: float
|
var CrouchState: float
|
||||||
var Crouch: float
|
var Crouch: float
|
||||||
|
@ -281,8 +286,9 @@ func _process(delta: float) -> void:
|
||||||
Crouch = 0
|
Crouch = 0
|
||||||
|
|
||||||
#RotateEntity Collider, WrapAngle(EntityPitch(Camera)), WrapAngle(EntityYaw(Camera)), 0
|
#RotateEntity Collider, WrapAngle(EntityPitch(Camera)), WrapAngle(EntityYaw(Camera)), 0
|
||||||
camera.rotation.x = deg_to_rad(Rotation.x)
|
if not Global.VRMode:
|
||||||
head.rotation.y = deg_to_rad(Rotation.y)
|
camera.rotation.x = deg_to_rad(Rotation.x)
|
||||||
|
head.rotation.y = deg_to_rad(Rotation.y)
|
||||||
|
|
||||||
movementSpeed = movementSpeed * NoClipSpeed
|
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 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
|
var cameraBob = (Global.Sin(Shake) / (20.0 + CrouchState * 20.0)) * 0.6
|
||||||
|
|
||||||
camera.rotation.x = deg_to_rad(Rotation.x)
|
if not Global.VRMode:
|
||||||
camera.rotation.z = deg_to_rad(cameraRoll * 0.5)
|
camera.rotation.x = deg_to_rad(Rotation.x)
|
||||||
camera.position.y = cameraBob
|
camera.rotation.z = deg_to_rad(cameraRoll * 0.5)
|
||||||
#head.position.y = 1.15 + 0.6 * (1 - CrouchState)
|
camera.position.y = cameraBob
|
||||||
head.position.y = cameraBob + 0.9 + CrouchState * -0.3
|
#head.position.y = 1.15 + 0.6 * (1 - CrouchState)
|
||||||
head.rotation.y = deg_to_rad(Rotation.y)
|
head.position.y = cameraBob + 0.9 + CrouchState * -0.3
|
||||||
|
head.rotation.y = deg_to_rad(Rotation.y)
|
||||||
|
|
||||||
var CollidedFloor = false
|
var CollidedFloor = false
|
||||||
if floorRay.is_colliding():
|
if floorRay.is_colliding():
|
||||||
|
@ -455,12 +462,13 @@ func snapDownToFloorCheck():
|
||||||
const CONTROLLER_DEADZONE = 0.20;
|
const CONTROLLER_DEADZONE = 0.20;
|
||||||
func _input(event: InputEvent) -> void:
|
func _input(event: InputEvent) -> void:
|
||||||
if event is InputEventMouseMotion:
|
if event is InputEventMouseMotion:
|
||||||
Rotation.y -= event.relative.x / 2
|
if not Global.VRMode:
|
||||||
Rotation.x -= event.relative.y / 2
|
Rotation.y -= event.relative.x / 2
|
||||||
if Rotation.x > 70:
|
Rotation.x -= event.relative.y / 2
|
||||||
Rotation.x = 70
|
if Rotation.x > 70:
|
||||||
if Rotation.x < -70:
|
Rotation.x = 70
|
||||||
Rotation.x = -70
|
if Rotation.x < -70:
|
||||||
|
Rotation.x = -70
|
||||||
#event.velocity
|
#event.velocity
|
||||||
if event is InputEventJoypadMotion:
|
if event is InputEventJoypadMotion:
|
||||||
# LeftRight = 2, UpDown = 3
|
# LeftRight = 2, UpDown = 3
|
||||||
|
|
|
@ -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
|
|
|
@ -1 +0,0 @@
|
||||||
uid://qgv7j32s51vr
|
|
11
src/XRSetup.gd
Normal file
11
src/XRSetup.gd
Normal 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
1
src/XRSetup.gd.uid
Normal file
|
@ -0,0 +1 @@
|
||||||
|
uid://cr0a5b6avy81f
|
Loading…
Add table
Reference in a new issue