WIP: Migrating to node3ds
This commit is contained in:
parent
1b7c77a05b
commit
9991b3891f
@ -4,46 +4,46 @@ class_name CharacterWrapper
|
|||||||
@export var die_script: GDScript = null
|
@export var die_script: GDScript = null
|
||||||
@export var owner_placeholder: CharacterBody3D = null
|
@export var owner_placeholder: CharacterBody3D = null
|
||||||
|
|
||||||
@export var interpolation_speed: float = 50.0 # How quickly the model corrects position
|
|
||||||
@export var velocity_influence: float = 1.0 # How much velocity is used for smoothing
|
|
||||||
@export var snap_threshold: float = 2.0 # If desync is larger than this, snap faster
|
|
||||||
|
|
||||||
@export var interpolation_delay: float = 0.1 # Stay 100ms behind for smooth interpolation
|
@export var interpolation_delay: float = 0.1 # Stay 100ms behind for smooth interpolation
|
||||||
|
@export var snap_threshold: float = 2.0 # If desync is larger than this, snap instantly
|
||||||
|
|
||||||
var position_buffer = [] # Stores past positions (tuples of (timestamp, position))
|
var position_buffer = [] # Stores past positions (tuples of (timestamp, position))
|
||||||
var previous_position: Vector3 = Vector3.ZERO
|
var previous_position: Vector3 = Vector3.ZERO
|
||||||
var pseudo_velocity: Vector3 = Vector3.ZERO # Approximate velocity without CharacterBody3D
|
var pseudo_velocity: Vector3 = Vector3.ZERO # Approximate velocity without CharacterBody3D
|
||||||
|
|
||||||
var previous_server_pos: Vector3 = Vector3.ZERO
|
func _physics_process(delta: float) -> void:
|
||||||
|
var server_pos = owner_placeholder.global_transform.origin
|
||||||
|
|
||||||
func _process(delta):
|
# Calculate pseudo velocity (difference per second)
|
||||||
# Record the latest server position with timestamp
|
pseudo_velocity = (server_pos - previous_position) / delta
|
||||||
|
previous_position = server_pos # Store for next frame
|
||||||
|
|
||||||
global_rotation = owner_placeholder.global_rotation
|
# Store position in buffer
|
||||||
# -- This code is 100% generated by chatGPT and I can't understand it fully yet
|
position_buffer.append([Time.get_ticks_msec() / 1000.0, server_pos])
|
||||||
|
|
||||||
var position_difference := global_position - owner_placeholder.global_position
|
# Remove old positions to keep buffer clean
|
||||||
if is_vector_a_lower_than_b(position_difference, Vector3(0.5, 0.5, 0.5)) and \
|
while position_buffer.size() > 2 and position_buffer[1][0] < (Time.get_ticks_msec() / 1000.0) - interpolation_delay:
|
||||||
is_vector_a_lower_than_b(Vector3(-0.5, -0.5, -0.5), position_difference):
|
position_buffer.pop_front()
|
||||||
var server_pos = owner_placeholder.global_transform.origin
|
|
||||||
pseudo_velocity = (server_pos - previous_position) / delta
|
|
||||||
previous_position = server_pos # Store for next frame
|
|
||||||
position_buffer.append([Time.get_ticks_msec() / 1000.0, server_pos])
|
|
||||||
|
|
||||||
|
# Get current client position
|
||||||
|
var client_pos = global_transform.origin
|
||||||
|
|
||||||
while position_buffer.size() > 2 and position_buffer[1][0] < (Time.get_ticks_msec() / 1000.0) - interpolation_delay:
|
# Check if the client is too far from the server
|
||||||
position_buffer.pop_front()
|
if client_pos.distance_to(server_pos) > snap_threshold:
|
||||||
|
global_transform.origin = server_pos # Instantly move to the correct position
|
||||||
|
position_buffer.clear() # Reset buffer to prevent interpolation from old positions
|
||||||
|
return # Skip interpolation this frame to avoid weird blending
|
||||||
|
|
||||||
if position_buffer.size() >= 2:
|
# If we have at least 2 points, interpolate between them
|
||||||
var t_now = (Time.get_ticks_msec() / 1000.0) - interpolation_delay
|
if position_buffer.size() >= 2:
|
||||||
var prev_point = position_buffer[0]
|
var t_now = (Time.get_ticks_msec() / 1000.0) - interpolation_delay
|
||||||
var next_point = position_buffer[1]
|
var prev_point = position_buffer[0]
|
||||||
|
var next_point = position_buffer[1]
|
||||||
|
|
||||||
var alpha = (t_now - prev_point[0]) / (next_point[0] - prev_point[0])
|
var alpha = (t_now - prev_point[0]) / (next_point[0] - prev_point[0])
|
||||||
alpha = clamp(alpha, 0.0, 1.0)
|
alpha = clamp(alpha, 0.0, 1.0)
|
||||||
global_transform.origin = prev_point[1].lerp(next_point[1], alpha)
|
|
||||||
else:
|
global_transform.origin = prev_point[1].lerp(next_point[1], alpha)
|
||||||
global_position = owner_placeholder.global_position
|
|
||||||
|
|
||||||
func _ready() -> void:
|
func _ready() -> void:
|
||||||
set_multiplayer_authority(multiplayer.get_unique_id())
|
set_multiplayer_authority(multiplayer.get_unique_id())
|
||||||
|
Loading…
Reference in New Issue
Block a user