Compare commits
43 Commits
another-se
...
556f0dbb27
Author | SHA1 | Date | |
---|---|---|---|
556f0dbb27
|
|||
e77a828fca
|
|||
ee402b1077
|
|||
b1d76d433a
|
|||
1f6eff86c8
|
|||
f9a260e3ab
|
|||
212a40081d
|
|||
9991b3891f
|
|||
1b7c77a05b
|
|||
6441456788
|
|||
95ee0542cf
|
|||
691e0ea8bc
|
|||
5a0e3cc6b9
|
|||
7c761752c9
|
|||
6795fdeacd
|
|||
fb05bc4dd1
|
|||
6528957ce1
|
|||
6ad263e081
|
|||
75f482a548
|
|||
ad7c3ea5f9
|
|||
ccc43e9c4b
|
|||
275d697f60
|
|||
e922911f92
|
|||
b3d2461961
|
|||
906502a18e
|
|||
8126b28464
|
|||
90cd42c1cf
|
|||
7a36a173b5
|
|||
6e3d4b47dd
|
|||
60c3694ba6
|
|||
67b981365e
|
|||
8e06eadf1d
|
|||
57a8f1fef3
|
|||
fa311dfb13
|
|||
7341d4036d
|
|||
6219397137
|
|||
ee8a65a67b
|
|||
dee082c7e4
|
|||
084d8248c7
|
|||
b6bf2b4616
|
|||
5ab840cdd8
|
|||
89992b1ef4
|
|||
ad95c99149 |
@ -72,35 +72,7 @@ func _on_load_map(map_name: String) -> void:
|
|||||||
if scene.can_instantiate():
|
if scene.can_instantiate():
|
||||||
var node: Node3D = scene.instantiate()
|
var node: Node3D = scene.instantiate()
|
||||||
logger.info("loading map: " + map_name)
|
logger.info("loading map: " + map_name)
|
||||||
$LevelLoader/MultiplayerSpawner.spawn_function = _map_spawn_function
|
level_root.add_child(node)
|
||||||
$LevelLoader/MultiplayerSpawner.spawn(map_name)
|
|
||||||
#level_root.add_child(node)
|
|
||||||
else:
|
else:
|
||||||
logger.error("Can't initialize")
|
logger.error("Can't initialize")
|
||||||
|
|
||||||
var thread: Thread
|
|
||||||
var map_node: Node
|
|
||||||
var mutex: Mutex
|
|
||||||
|
|
||||||
func _load_the_map_in_thread(map_name):
|
|
||||||
var path_tmpl := "res://scenes/maps/maps/%s"
|
|
||||||
var path := path_tmpl % map_name
|
|
||||||
|
|
||||||
if not ResourceLoader.exists(path):
|
|
||||||
logger.error("map " + map_name + " doesn't exist")
|
|
||||||
mutex.lock()
|
|
||||||
var scene: PackedScene = ResourceLoader.load(path)
|
|
||||||
if scene.can_instantiate():
|
|
||||||
map_node = scene.instantiate()
|
|
||||||
mutex.unlock()
|
|
||||||
|
|
||||||
func _map_spawn_function(map_name: Variant) -> Node:
|
|
||||||
thread = Thread.new()
|
|
||||||
mutex = Mutex.new()
|
|
||||||
thread.start(Callable(self, "_load_the_map_in_thread").bind(map_name))
|
|
||||||
await thread.wait_to_finish()
|
|
||||||
mutex.lock()
|
|
||||||
var result = map_node
|
|
||||||
mutex.unlock()
|
|
||||||
return result
|
|
||||||
|
|
||||||
|
@ -6,4 +6,13 @@
|
|||||||
editor_description = "This node serves a starting point for the game. When the game is running as a dedicated server it's supposed to read the config file and start the server, when the game is running in a default mode, it should render the main menu"
|
editor_description = "This node serves a starting point for the game. When the game is running as a dedicated server it's supposed to read the config file and start the server, when the game is running in a default mode, it should render the main menu"
|
||||||
script = ExtResource("1_eb14f")
|
script = ExtResource("1_eb14f")
|
||||||
|
|
||||||
|
[node name="LevelLoader" type="Node" parent="."]
|
||||||
|
editor_description = "This node is supposed to make it possible to sync the server data across all the possible players"
|
||||||
|
|
||||||
|
[node name="Level" type="Node3D" parent="LevelLoader"]
|
||||||
|
|
||||||
|
[node name="MultiplayerSpawner" type="MultiplayerSpawner" parent="LevelLoader"]
|
||||||
|
_spawnable_scenes = PackedStringArray("res://scenes/maps/maps/lowpoly_tdm_1.tscn")
|
||||||
|
spawn_path = NodePath("../Level")
|
||||||
|
|
||||||
[connection signal="load_map" from="." to="." method="_on_load_map"]
|
[connection signal="load_map" from="." to="." method="_on_load_map"]
|
||||||
|
@ -3,7 +3,7 @@ class_name MapController
|
|||||||
|
|
||||||
const PLAYER_SPAWNER: String = "res://scenes/maps/base/player_spawner/player_spawner.tscn"
|
const PLAYER_SPAWNER: String = "res://scenes/maps/base/player_spawner/player_spawner.tscn"
|
||||||
const BULLET_SPAWNER: String = "res://scenes/maps/base/bullet_spawner/bullet_spawner.tscn"
|
const BULLET_SPAWNER: String = "res://scenes/maps/base/bullet_spawner/bullet_spawner.tscn"
|
||||||
const WORLD: String = "res://scenes/maps/maps/world.tscn"
|
|
||||||
var player_spawner: PlayerSpawnerController
|
var player_spawner: PlayerSpawnerController
|
||||||
var bullet_spawner: BulletSpawnerController
|
var bullet_spawner: BulletSpawnerController
|
||||||
var client_node: Node3D
|
var client_node: Node3D
|
||||||
@ -14,10 +14,7 @@ var client_node: Node3D
|
|||||||
func _ready() -> void:
|
func _ready() -> void:
|
||||||
# add player spawner
|
# add player spawner
|
||||||
var err: Error = OK
|
var err: Error = OK
|
||||||
err = _add_world()
|
|
||||||
if err != OK:
|
|
||||||
push_error("Couldn't load world")
|
|
||||||
return
|
|
||||||
err = _add_player_spawner()
|
err = _add_player_spawner()
|
||||||
if err != OK:
|
if err != OK:
|
||||||
push_error("Couldn't load player spawner")
|
push_error("Couldn't load player spawner")
|
||||||
@ -36,7 +33,16 @@ func _ready() -> void:
|
|||||||
_request_spawn.rpc_id(1)
|
_request_spawn.rpc_id(1)
|
||||||
|
|
||||||
|
|
||||||
@rpc("call_local", "unreliable", "any_peer")
|
# Called every frame. 'delta' is the elapsed time since the previous frame.
|
||||||
|
func _process(delta: float) -> void:
|
||||||
|
if multiplayer.is_server():
|
||||||
|
pass
|
||||||
|
#var active_players = player_spawner._get_root().get_children()
|
||||||
|
#for n in active_players:
|
||||||
|
#if not Server.players.has(n.owner_id):
|
||||||
|
#_remove_player(n.owner_id)
|
||||||
|
|
||||||
|
@rpc("call_local", "reliable", "any_peer")
|
||||||
func _request_spawn():
|
func _request_spawn():
|
||||||
var id: int = multiplayer.get_remote_sender_id()
|
var id: int = multiplayer.get_remote_sender_id()
|
||||||
_spawn_player(id)
|
_spawn_player(id)
|
||||||
@ -48,7 +54,7 @@ func _spawn_player(id: int):
|
|||||||
var position := controlled_node.shared_node.global_position
|
var position := controlled_node.shared_node.global_position
|
||||||
_spawn_player_controller_node.rpc_id(id, position.x, position.y, position.z)
|
_spawn_player_controller_node.rpc_id(id, position.x, position.y, position.z)
|
||||||
|
|
||||||
@rpc("any_peer", "call_local", "unreliable")
|
@rpc("any_peer", "call_local", "reliable")
|
||||||
func _spawn_player_controller_node(x: float, y: float, z: float):
|
func _spawn_player_controller_node(x: float, y: float, z: float):
|
||||||
var path := "res://scenes/player/player_node.tscn"
|
var path := "res://scenes/player/player_node.tscn"
|
||||||
var scene: PackedScene = ResourceLoader.load(path)
|
var scene: PackedScene = ResourceLoader.load(path)
|
||||||
@ -67,17 +73,6 @@ func spawn_player_model(owner_node: CharacterBody3D, owner_id: int):
|
|||||||
func _remove_player(id: int):
|
func _remove_player(id: int):
|
||||||
player_spawner.remove_player(id)
|
player_spawner.remove_player(id)
|
||||||
|
|
||||||
func _add_world() -> Error :
|
|
||||||
if not ResourceLoader.exists(WORLD):
|
|
||||||
return ERR_DOES_NOT_EXIST
|
|
||||||
var scene: PackedScene = ResourceLoader.load(WORLD)
|
|
||||||
if not scene.can_instantiate():
|
|
||||||
return ERR_CANT_OPEN
|
|
||||||
|
|
||||||
var node: Node3D = scene.instantiate()
|
|
||||||
add_child(node)
|
|
||||||
return OK
|
|
||||||
|
|
||||||
func _add_player_spawner() -> Error :
|
func _add_player_spawner() -> Error :
|
||||||
if not ResourceLoader.exists(PLAYER_SPAWNER):
|
if not ResourceLoader.exists(PLAYER_SPAWNER):
|
||||||
return ERR_DOES_NOT_EXIST
|
return ERR_DOES_NOT_EXIST
|
||||||
|
@ -6,10 +6,14 @@
|
|||||||
script = ExtResource("1_2hsyd")
|
script = ExtResource("1_2hsyd")
|
||||||
|
|
||||||
[node name="PlayersSpawner" type="MultiplayerSpawner" parent="."]
|
[node name="PlayersSpawner" type="MultiplayerSpawner" parent="."]
|
||||||
_spawnable_scenes = PackedStringArray("res://scenes/player/server_node.tscn")
|
_spawnable_scenes = PackedStringArray("res://scenes/player/server_node.tscn", "res://scenes/characters/y-bot/character.tscn")
|
||||||
spawn_path = NodePath("../Players")
|
spawn_path = NodePath("../Players")
|
||||||
spawn_limit = 100
|
spawn_limit = 100
|
||||||
|
|
||||||
[node name="Players" type="Node3D" parent="."]
|
[node name="Players" type="Node3D" parent="."]
|
||||||
|
|
||||||
[node name="Models" type="Node3D" parent="."]
|
[node name="Models" type="Node3D" parent="."]
|
||||||
|
|
||||||
|
[node name="ModelSpawner" type="MultiplayerSpawner" parent="."]
|
||||||
|
_spawnable_scenes = PackedStringArray("res://scenes/characters/y-bot/character.tscn")
|
||||||
|
spawn_path = NodePath("../Models")
|
||||||
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -60,8 +60,6 @@ func _on_create_pressed() -> void:
|
|||||||
func _on_join_server_pressed() -> void:
|
func _on_join_server_pressed() -> void:
|
||||||
var ip: String = $JoinServerMenu/Host/TextEdit.text
|
var ip: String = $JoinServerMenu/Host/TextEdit.text
|
||||||
var port: int = $JoinServerMenu/Port/TextEdit.text.to_int()
|
var port: int = $JoinServerMenu/Port/TextEdit.text.to_int()
|
||||||
|
|
||||||
GameServerAutoload.join_server(ip, port)
|
GameServerAutoload.join_server(ip, port)
|
||||||
_get_game_root().load_map.emit(GameServerAutoload.current_map)
|
|
||||||
visible = false
|
visible = false
|
||||||
|
|
||||||
|
@ -2,4 +2,4 @@ extends Control
|
|||||||
class_name Hud
|
class_name Hud
|
||||||
|
|
||||||
@onready var camera: Camera3D = $SubViewportContainer/SubViewport/Camera3D
|
@onready var camera: Camera3D = $SubViewportContainer/SubViewport/Camera3D
|
||||||
@onready var gun_mount: Node3D = $SubViewportContainer/SubViewport/Camera3D/GunMount
|
@onready var gun_mount: Node3D = $SubViewportContainer/SubViewport/Camera3D/GunMounta
|
||||||
|
@ -22,6 +22,7 @@ func _ready() -> void:
|
|||||||
|
|
||||||
|
|
||||||
@onready var bullet_trace_distance: Node3D = $BulletTraceDistance
|
@onready var bullet_trace_distance: Node3D = $BulletTraceDistance
|
||||||
|
@onready var bullet_trail_end: Node3D = $BulletTrailEnd
|
||||||
@onready var gun_animation = $ShotAnimation
|
@onready var gun_animation = $ShotAnimation
|
||||||
func shoot() -> Error:
|
func shoot() -> Error:
|
||||||
if can_shoot:
|
if can_shoot:
|
||||||
|
Reference in New Issue
Block a user