add checkpoint area handling

This commit is contained in:
interfisch 2024-11-05 08:18:14 +01:00
parent f59a3c43e9
commit d120c82ff6
7 changed files with 81 additions and 21 deletions

View file

@ -10,7 +10,7 @@ config_version=5
[application] [application]
config/name="CustomInputTest" config/name="One-Button Racing"
run/main_scene="res://scenes/menu.tscn" run/main_scene="res://scenes/menu.tscn"
config/features=PackedStringArray("4.3", "Forward Plus") config/features=PackedStringArray("4.3", "Forward Plus")
config/icon="res://icon.svg" config/icon="res://icon.svg"
@ -27,5 +27,5 @@ window/stretch/mode="canvas_items"
2d_physics/layer_1="walls" 2d_physics/layer_1="walls"
2d_physics/layer_2="walldetection" 2d_physics/layer_2="walldetection"
2d_physics/layer_3="Finish" 2d_physics/layer_3="Marking"
2d_physics/layer_4="Checkpoint" 2d_physics/layer_4="Layer 4"

View file

@ -45,7 +45,8 @@ one_shot = true
[node name="RayCast_Car" type="RayCast2D" parent="CharacterBody_Car"] [node name="RayCast_Car" type="RayCast2D" parent="CharacterBody_Car"]
position = Vector2(-15, 0) position = Vector2(-15, 0)
target_position = Vector2(31, 0) target_position = Vector2(31, 0)
collision_mask = 4 collision_mask = 12
collide_with_areas = true
[node name="collisionEnableTimer" type="Timer" parent="CharacterBody_Car"] [node name="collisionEnableTimer" type="Timer" parent="CharacterBody_Car"]
wait_time = 0.1 wait_time = 0.1

View file

@ -1,4 +1,4 @@
[gd_scene load_steps=5 format=4 uid="uid://dghq8c8asg7h1"] [gd_scene load_steps=6 format=4 uid="uid://dghq8c8asg7h1"]
[ext_resource type="TileSet" uid="uid://beswbm12qkkxk" path="res://sprites/spritesheet_road/bg_road.tres" id="2_i1338"] [ext_resource type="TileSet" uid="uid://beswbm12qkkxk" path="res://sprites/spritesheet_road/bg_road.tres" id="2_i1338"]
[ext_resource type="TileSet" uid="uid://buu8w8n61kbxf" path="res://sprites/spritesheet_road/markings.tres" id="3_ktygs"] [ext_resource type="TileSet" uid="uid://buu8w8n61kbxf" path="res://sprites/spritesheet_road/markings.tres" id="3_ktygs"]
@ -7,6 +7,9 @@
[sub_resource type="TileSet" id="TileSet_5knbn"] [sub_resource type="TileSet" id="TileSet_5knbn"]
tile_size = Vector2i(128, 128) tile_size = Vector2i(128, 128)
[sub_resource type="RectangleShape2D" id="RectangleShape2D_daqun"]
size = Vector2(23, 106.5)
[node name="Map" type="Node"] [node name="Map" type="Node"]
[node name="Background" type="TileMapLayer" parent="."] [node name="Background" type="TileMapLayer" parent="."]
@ -37,3 +40,27 @@ tile_set = ExtResource("4_r58io")
[node name="road_l" type="TileMapLayer" parent="."] [node name="road_l" type="TileMapLayer" parent="."]
tile_map_data = PackedByteArray("AAAFAP//AAADAAAAAHAFAAAAAAACAAAAAHAEAP//AAADAAEAAHAHAAAAAAAHAAIAAHAHAAEAAAAGAAIAAHAGAAAAAAAHAAMAAHAHAAIAAAAHAAMAACAHAAMAAAAHAAIAACAGAAMAAAAGAAIAACAFAAMAAAAHAAEAAGAFAAQAAAAGAAEAAGAEAAQAAAAGAAAAAGADAAQAAgABAAAAAEACAAQAAgABAAAAAEABAAQAAgABAAAAAEAAAAQAAgADAAEAAED+/wQAAAAHAAMAAED9/wMAAAAGAAIAAED9/wQAAAAHAAIAAED//wQAAgABAAAAAED9/wIAAgADAAAAABD+/wIAAgABAAAAAHD//wIAAgABAAAAAHAAAAIAAgABAAAAAHABAAIAAgABAAAAAHABAAEAAgABAAAAAFAAAAEAAgABAAAAAFD//wEAAgABAAAAAFD+/wEAAgABAAAAAFD9/wEAAgABAAAAAFD8/wEAAgAGAAIAAED8/wIAAgAAAAIAAAD7/wIAAgAGAAEAAAD7/wMAAgAAAAIAAAD6/wMAAgAEAAIAAAADAP//AgABAAAAAHACAP//AgABAAAAAHABAP//AgABAAAAAHAAAP//AgABAAAAAHD/////AgABAAAAAHD+////AgABAAAAAHD9////AgABAAAAAHD8////AgABAAAAAHD7////AgABAAAAAHD6////AgAFAAIAAED5////AgAAAAIAAHD4/wAAAgAAAAIAAHD3/wEAAgAAAAIAAHD5/wAAAgAGAAEAAHD4/wEAAgAGAAEAAHD3/wIAAgADAAIAAAD7/wQAAAAAAAUAAED7/wUAAAABAAUAAED6/wQAAAAAAAQAAED9/wUAAAADAAAAAHD9/wYAAAACAAAAAHD8/wUAAAADAAEAAHD+/wYAAgAFAAAAAFD+/wUAAgADAAAAABD//wUAAgABAAAAAHAAAAUAAgABAAAAAHABAAUAAgABAAAAAHACAAUAAgADAAAAAAACAAYAAgADAAAAAFAAAAgAAAAGAAIAAFAAAAkAAAAHAAIAAFD//wkAAAAHAAMAAFABAAYAAAAAAAQAABABAAcAAAAAAAUAABAAAAcAAAABAAUAABD+/wkAAgABAAAAAFD9/wkAAgABAAAAAFD8/wkAAAAGAAAAAHD7/wgAAAAHAAEAAHD7/wkAAAAGAAEAAHD6/wgAAgABAAAAAFD5/wgAAgABAAAAAFD4/wgAAAAGAAIAADD3/wcAAAAHAAMAADD3/wgAAAAHAAIAADD3/wQAAgADAAEAADD3/wYAAgABAAAAADD3/wUAAgABAAAAADD3/wMAAgABAAAAADACAAIAAgAFAAAAAFACAAEAAgAFAAAAAHA=") tile_map_data = PackedByteArray("AAAFAP//AAADAAAAAHAFAAAAAAACAAAAAHAEAP//AAADAAEAAHAHAAAAAAAHAAIAAHAHAAEAAAAGAAIAAHAGAAAAAAAHAAMAAHAHAAIAAAAHAAMAACAHAAMAAAAHAAIAACAGAAMAAAAGAAIAACAFAAMAAAAHAAEAAGAFAAQAAAAGAAEAAGAEAAQAAAAGAAAAAGADAAQAAgABAAAAAEACAAQAAgABAAAAAEABAAQAAgABAAAAAEAAAAQAAgADAAEAAED+/wQAAAAHAAMAAED9/wMAAAAGAAIAAED9/wQAAAAHAAIAAED//wQAAgABAAAAAED9/wIAAgADAAAAABD+/wIAAgABAAAAAHD//wIAAgABAAAAAHAAAAIAAgABAAAAAHABAAIAAgABAAAAAHABAAEAAgABAAAAAFAAAAEAAgABAAAAAFD//wEAAgABAAAAAFD+/wEAAgABAAAAAFD9/wEAAgABAAAAAFD8/wEAAgAGAAIAAED8/wIAAgAAAAIAAAD7/wIAAgAGAAEAAAD7/wMAAgAAAAIAAAD6/wMAAgAEAAIAAAADAP//AgABAAAAAHACAP//AgABAAAAAHABAP//AgABAAAAAHAAAP//AgABAAAAAHD/////AgABAAAAAHD+////AgABAAAAAHD9////AgABAAAAAHD8////AgABAAAAAHD7////AgABAAAAAHD6////AgAFAAIAAED5////AgAAAAIAAHD4/wAAAgAAAAIAAHD3/wEAAgAAAAIAAHD5/wAAAgAGAAEAAHD4/wEAAgAGAAEAAHD3/wIAAgADAAIAAAD7/wQAAAAAAAUAAED7/wUAAAABAAUAAED6/wQAAAAAAAQAAED9/wUAAAADAAAAAHD9/wYAAAACAAAAAHD8/wUAAAADAAEAAHD+/wYAAgAFAAAAAFD+/wUAAgADAAAAABD//wUAAgABAAAAAHAAAAUAAgABAAAAAHABAAUAAgABAAAAAHACAAUAAgADAAAAAAACAAYAAgADAAAAAFAAAAgAAAAGAAIAAFAAAAkAAAAHAAIAAFD//wkAAAAHAAMAAFABAAYAAAAAAAQAABABAAcAAAAAAAUAABAAAAcAAAABAAUAABD+/wkAAgABAAAAAFD9/wkAAgABAAAAAFD8/wkAAAAGAAAAAHD7/wgAAAAHAAEAAHD7/wkAAAAGAAEAAHD6/wgAAgABAAAAAFD5/wgAAgABAAAAAFD4/wgAAAAGAAIAADD3/wcAAAAHAAMAADD3/wgAAAAHAAIAADD3/wQAAgADAAEAADD3/wYAAgABAAAAADD3/wUAAgABAAAAADD3/wMAAgABAAAAADACAAIAAgAFAAAAAFACAAEAAgAFAAAAAHA=")
tile_set = ExtResource("4_r58io") tile_set = ExtResource("4_r58io")
[node name="area_finish" type="Area2D" parent="."]
collision_layer = 4
collision_mask = 4
[node name="CollisionShape2D" type="CollisionShape2D" parent="area_finish"]
position = Vector2(89.5, -0.5)
shape = SubResource("RectangleShape2D_daqun")
[node name="area_cp1" type="Area2D" parent="."]
collision_layer = 4
collision_mask = 4
[node name="CollisionShape2D" type="CollisionShape2D" parent="area_cp1"]
position = Vector2(267, 575.5)
shape = SubResource("RectangleShape2D_daqun")
[node name="area_cp2" type="Area2D" parent="."]
collision_layer = 4
collision_mask = 4
[node name="CollisionShape2D" type="CollisionShape2D" parent="area_cp2"]
position = Vector2(235, 833.75)
shape = SubResource("RectangleShape2D_daqun")

View file

@ -6,6 +6,9 @@ extends CharacterBody2D
const COLLISIONMASK_FINISH=3 #set in road_overlay const COLLISIONMASK_FINISH=3 #set in road_overlay
const COLLISIONMASK_CHECKPOINT=4 #set in road_overlay const COLLISIONMASK_CHECKPOINT=4 #set in road_overlay
var checkpoints :Array[String]=[] #gets set on car creation
var checkpointtimes :Array[float]=[]
const ROAD_R_NAME="road_r" const ROAD_R_NAME="road_r"
const ROAD_L_NAME="road_l" const ROAD_L_NAME="road_l"
@ -65,6 +68,8 @@ var playerid=0
func _ready() -> void: func _ready() -> void:
collision_shape.disabled=true #disable collisions on start. also to avoid collision when initially setting position collision_shape.disabled=true #disable collisions on start. also to avoid collision when initially setting position
func _physics_process(delta: float) -> void: func _physics_process(delta: float) -> void:
acceleration=Vector2.ZERO acceleration=Vector2.ZERO
check_markers() check_markers()
@ -200,10 +205,26 @@ func calculate_steering(delta:float):
func check_markers(): func check_markers():
if ray_cast_car.is_colliding(): if ray_cast_car.is_colliding():
#print("Marker: "+str(ray_cast_car.get_collider())) #print("Marker: "+str(ray_cast_car.get_collider()))
if ray_cast_car.get_collision_mask_value(COLLISIONMASK_FINISH): #if ray_cast_car.get_collision_mask_value(COLLISIONMASK_FINISH):
print("Player "+str(playerid)+" Finished") # print("Player "+str(playerid)+" Finished")
if ray_cast_car.get_collision_mask_value(COLLISIONMASK_CHECKPOINT): #if ray_cast_car.get_collision_mask_value(COLLISIONMASK_CHECKPOINT):
print("Player "+str(playerid)+" Checkpint") var rcc_collidername=ray_cast_car.get_collider().name
if rcc_collidername=="area_finish":
var num_cp_collected=0
for cpt in checkpointtimes:
if cpt>0:
num_cp_collected+=1
#print("Player "+str(playerid)+" drove through Finish")
if num_cp_collected==checkpointtimes.size():
print("Player "+str(playerid)+" Finished")
#TODO: get final time
checkpointtimes.fill(0)
elif rcc_collidername.begins_with("area_cp"):
var checkpoint_i=checkpoints.find(rcc_collidername)
if checkpoint_i>=0 and checkpointtimes[checkpoint_i]==0: #found and no time for this cp yet
checkpointtimes[checkpoint_i]=10 # TODO: set actual time here
print("Player "+str(playerid)+" Checkpoint "+str(ray_cast_car.get_collider().name))
func constrain(val,a,b): func constrain(val,a,b):
var vmin=min(a,b) var vmin=min(a,b)

View file

@ -14,9 +14,13 @@ func setPosition(p:Vector2):
func setPlayerinformation(playerid, playercolor): func setPlayerinformation(playerid, playercolor):
cbcar.playerid=playerid cbcar.playerid=playerid
#TODO set playercolor
carbody.modulate = playercolor carbody.modulate = playercolor
func setCheckpoints(cps):
cbcar.checkpoints=cps
cbcar.checkpointtimes.resize(cps.size())
cbcar.checkpointtimes.fill(0.0)
func move_and_slide(): func move_and_slide():
cbcar.move_and_slide() cbcar.move_and_slide()

View file

@ -16,6 +16,21 @@ var zoom_normal=2
# Called when the node enters the scene tree for the first time. # Called when the node enters the scene tree for the first time.
func _ready() -> void: func _ready() -> void:
#Load Map
#var num_checkpoints=0
var checkpoints :Array[String]=[]
var mapscene=load("res://scenes/map_01.tscn")
var mapsceneinstance=mapscene.instantiate()
add_child(mapsceneinstance)
for mapc in mapsceneinstance.get_children():
if mapc.name.begins_with("area_cp"):
#num_checkpoints+=1
checkpoints.append(mapc.name)
print(str(checkpoints.size())+" Checkpoints found")
var i=0 var i=0
#for playerkey in Gamestate.getPlayerkeys(): #create all players #for playerkey in Gamestate.getPlayerkeys(): #create all players
for player in Gamestate.getPlayers(): for player in Gamestate.getPlayers():
@ -25,16 +40,13 @@ func _ready() -> void:
newcarinstance.setPlayerinformation(i,player.color) newcarinstance.setPlayerinformation(i,player.color)
newcarinstance.setPosition(Vector2(0,ceil(i/2.0)*(fmod(i,2)-0.5)*2.0*caroffset)) newcarinstance.setPosition(Vector2(0,ceil(i/2.0)*(fmod(i,2)-0.5)*2.0*caroffset))
newcarinstance.setCheckpoints(checkpoints)
#print("Position car "+str(i)+" = "+str(ceil(i/2.0)*(fmod(i,2)-0.5)*2.0*caroffset)) #print("Position car "+str(i)+" = "+str(ceil(i/2.0)*(fmod(i,2)-0.5)*2.0*caroffset))
print("carpos is ="+str(newcarinstance.getPosition())+" instancepos="+str(newcarinstance.position)) print("carpos is ="+str(newcarinstance.getPosition())+" instancepos="+str(newcarinstance.position))
i+=1 i+=1
#Load Map
var mapscene=load("res://scenes/map_01.tscn")
var mapsceneinstance=mapscene.instantiate()
add_child(mapsceneinstance)
# Called every frame. 'delta' is the elapsed time since the previous frame. # Called every frame. 'delta' is the elapsed time since the previous frame.

View file

@ -6,16 +6,11 @@
texture = ExtResource("1_hbu2l") texture = ExtResource("1_hbu2l")
texture_region_size = Vector2i(128, 128) texture_region_size = Vector2i(128, 128)
0:0/0 = 0 0:0/0 = 0
0:0/0/physics_layer_0/polygon_0/points = PackedVector2Array(-64, -35, 56, -35, 56, -13, -64, -13)
1:0/0 = 0 1:0/0 = 0
1:0/0/physics_layer_0/polygon_0/points = PackedVector2Array(-64, -35, 64, -35, 64, -13, -64, -13)
2:0/0 = 0 2:0/0 = 0
2:0/0/physics_layer_1/polygon_0/points = PackedVector2Array(-64, -2, 64, -2, 64, 4, -64, 4)
[resource] [resource]
tile_size = Vector2i(128, 128) tile_size = Vector2i(128, 128)
physics_layer_0/collision_layer = 4 physics_layer_0/collision_layer = 0
physics_layer_0/collision_mask = 4 physics_layer_0/collision_mask = 0
physics_layer_1/collision_layer = 8
physics_layer_1/collision_mask = 8
sources/1 = SubResource("TileSetAtlasSource_3gx66") sources/1 = SubResource("TileSetAtlasSource_3gx66")