2022 demo

This commit is contained in:
pennyrigate 2022-12-31 21:47:38 -05:00
parent c60375cb98
commit 4727fb0f55
41 changed files with 761 additions and 68 deletions

View file

@ -16,6 +16,7 @@ func _process(delta):
#Scroll screen when player is on different sector
current_sector = (player.global_position / resolution).floor()
if current_sector != last_sector:
Game.respawn_point = player.global_position + Vector2(8,0)
if scroll_h: position.x = current_sector.x * resolution.x
if scroll_v: position.y = current_sector.y * resolution.y
last_sector = current_sector

View file

@ -0,0 +1,6 @@
extends Area2D
func _on_Area2D_area_entered(area):
#Kill player
if area.is_in_group("player"):
area.get_parent().die()

View file

@ -0,0 +1,15 @@
[gd_scene load_steps=3 format=2]
[ext_resource path="res://objects/death tile/death_tile.gd" type="Script" id=1]
[sub_resource type="RectangleShape2D" id=1]
extents = Vector2( 4, 4 )
[node name="Area2D" type="Area2D"]
script = ExtResource( 1 )
[node name="CollisionShape2D" type="CollisionShape2D" parent="."]
position = Vector2( 4, 4 )
shape = SubResource( 1 )
[connection signal="area_entered" from="." to="." method="_on_Area2D_area_entered"]

View file

@ -26,7 +26,7 @@ animations = [ {
} ]
[sub_resource type="RectangleShape2D" id=5]
extents = Vector2( 5, 5 )
extents = Vector2( 4, 4 )
[node name="Bat" type="Node2D"]
script = ExtResource( 3 )
@ -39,7 +39,6 @@ flip_sprite = false
[node name="AnimatedSprite" type="AnimatedSprite" parent="."]
material = SubResource( 1 )
frames = SubResource( 4 )
frame = 1
playing = true
[node name="Area2D" type="Area2D" parent="."]

View file

@ -26,7 +26,7 @@ animations = [ {
} ]
[sub_resource type="RectangleShape2D" id=5]
extents = Vector2( 5.5, 6 )
extents = Vector2( 4, 4 )
[node name="Snake" type="Node2D"]
script = ExtResource( 3 )
@ -35,13 +35,12 @@ score_for_killing = 15
[node name="AnimatedSprite" type="AnimatedSprite" parent="."]
material = SubResource( 1 )
frames = SubResource( 4 )
frame = 1
playing = true
[node name="Area2D" type="Area2D" parent="."]
[node name="CollisionShape2D" type="CollisionShape2D" parent="Area2D"]
position = Vector2( 0.5, 2 )
position = Vector2( 0, 4 )
shape = SubResource( 5 )
[connection signal="area_entered" from="Area2D" to="." method="_on_Area2D_area_entered"]

19
objects/exit/exit.gd Normal file
View file

@ -0,0 +1,19 @@
extends Node2D
export var cost = 0
onready var label = $Label
onready var anims = $AnimationPlayer
func _ready():
anims.play("closed")
label.text = str(cost)
func _physics_process(delta):
if Game.shards >= cost:
anims.play("open")
func _on_Area2D_area_entered(area):
if area.is_in_group("player"):
if Game.score > Game.high_score: Game.high_score = Game.score
Game.change_map(load("res://maps/demo_end.tscn"))

151
objects/exit/exit.tscn Normal file
View file

@ -0,0 +1,151 @@
[gd_scene load_steps=9 format=2]
[ext_resource path="res://scripts/theme.tres" type="Theme" id=1]
[ext_resource path="res://objects/exit/exit.gd" type="Script" id=2]
[ext_resource path="res://graphics/exit/exit.png" type="Texture" id=3]
[ext_resource path="res://scripts/1px_border.gdshader" type="Shader" id=4]
[sub_resource type="ShaderMaterial" id=1]
shader = ExtResource( 4 )
shader_param/border_color = Color( 0, 0, 0, 1 )
shader_param/border_corners = true
[sub_resource type="RectangleShape2D" id=2]
extents = Vector2( 8, 7.5 )
[sub_resource type="Animation" id=3]
resource_name = "closed"
tracks/0/type = "value"
tracks/0/path = NodePath("Sprite:region_rect")
tracks/0/interp = 1
tracks/0/loop_wrap = true
tracks/0/imported = false
tracks/0/enabled = true
tracks/0/keys = {
"times": PoolRealArray( 0 ),
"transitions": PoolRealArray( 1 ),
"update": 0,
"values": [ Rect2( 0, 0, 16, 24 ) ]
}
tracks/1/type = "value"
tracks/1/path = NodePath("Area2D/CollisionShape2D:disabled")
tracks/1/interp = 1
tracks/1/loop_wrap = true
tracks/1/imported = false
tracks/1/enabled = true
tracks/1/keys = {
"times": PoolRealArray( 0 ),
"transitions": PoolRealArray( 1 ),
"update": 1,
"values": [ true ]
}
tracks/2/type = "value"
tracks/2/path = NodePath("Label:visible")
tracks/2/interp = 1
tracks/2/loop_wrap = true
tracks/2/imported = false
tracks/2/enabled = true
tracks/2/keys = {
"times": PoolRealArray( 0 ),
"transitions": PoolRealArray( 1 ),
"update": 1,
"values": [ true ]
}
tracks/3/type = "value"
tracks/3/path = NodePath("Sprite:modulate")
tracks/3/interp = 1
tracks/3/loop_wrap = true
tracks/3/imported = false
tracks/3/enabled = true
tracks/3/keys = {
"times": PoolRealArray( 0 ),
"transitions": PoolRealArray( 1 ),
"update": 0,
"values": [ Color( 1, 1, 1, 1 ) ]
}
[sub_resource type="Animation" id=4]
resource_name = "open"
length = 0.8
loop = true
tracks/0/type = "value"
tracks/0/path = NodePath("Sprite:region_rect")
tracks/0/interp = 1
tracks/0/loop_wrap = true
tracks/0/imported = false
tracks/0/enabled = true
tracks/0/keys = {
"times": PoolRealArray( 0 ),
"transitions": PoolRealArray( 1 ),
"update": 0,
"values": [ Rect2( 16, 0, 16, 24 ) ]
}
tracks/1/type = "value"
tracks/1/path = NodePath("Area2D/CollisionShape2D:disabled")
tracks/1/interp = 1
tracks/1/loop_wrap = true
tracks/1/imported = false
tracks/1/enabled = true
tracks/1/keys = {
"times": PoolRealArray( 0 ),
"transitions": PoolRealArray( 1 ),
"update": 1,
"values": [ false ]
}
tracks/2/type = "value"
tracks/2/path = NodePath("Label:visible")
tracks/2/interp = 1
tracks/2/loop_wrap = true
tracks/2/imported = false
tracks/2/enabled = true
tracks/2/keys = {
"times": PoolRealArray( 0 ),
"transitions": PoolRealArray( 1 ),
"update": 1,
"values": [ false ]
}
tracks/3/type = "value"
tracks/3/path = NodePath("Sprite:modulate")
tracks/3/interp = 1
tracks/3/loop_wrap = true
tracks/3/imported = false
tracks/3/enabled = true
tracks/3/keys = {
"times": PoolRealArray( 0, 0.4, 0.8 ),
"transitions": PoolRealArray( 1, 1, 1 ),
"update": 0,
"values": [ Color( 1, 0, 0, 1 ), Color( 0, 1, 0.203922, 1 ), Color( 1, 0, 0, 1 ) ]
}
[node name="Exit" type="Node2D"]
z_index = -1
script = ExtResource( 2 )
[node name="Label" type="Label" parent="."]
visible = false
margin_left = -3.0
margin_top = -15.0
margin_right = 37.0
margin_bottom = 5.0
theme = ExtResource( 1 )
text = "2"
[node name="Sprite" type="Sprite" parent="."]
material = SubResource( 1 )
texture = ExtResource( 3 )
region_enabled = true
region_rect = Rect2( 0, 0, 16, 24 )
[node name="Area2D" type="Area2D" parent="."]
z_index = -3
[node name="CollisionShape2D" type="CollisionShape2D" parent="Area2D"]
position = Vector2( 0, 4.5 )
shape = SubResource( 2 )
disabled = true
[node name="AnimationPlayer" type="AnimationPlayer" parent="."]
anims/closed = SubResource( 3 )
anims/open = SubResource( 4 )
[connection signal="area_entered" from="Area2D" to="." method="_on_Area2D_area_entered"]

View file

@ -9,6 +9,8 @@ onready var blue_star = $BlueStar
onready var magenta_star = $MagentaStar
onready var score_counter = $ScoreCounter
onready var arrow_counter = $ArrowCounter
onready var lives_counter = $LivesCounter
onready var high_counter = $HighCounter
func _physics_process(delta):
#Gold Counter
@ -25,3 +27,8 @@ func _physics_process(delta):
score_counter.text = "%06d" % Game.score
#Arrow Counter
arrow_counter.text = "%02d" % Game.arrows
##TOUCH UP LATER
#Lives counter
lives_counter.text = str("LIVES:") + str(Game.lives)
#High counter
high_counter.text = str("HIGH:") + str("%06d" % Game.high_score)

View file

@ -115,6 +115,22 @@ margin_bottom = 21.0
theme = ExtResource( 10 )
text = "000000"
[node name="HighCounter" type="Label" parent="HUD"]
margin_left = 178.0
margin_top = 178.0
margin_right = 262.0
margin_bottom = 198.0
theme = ExtResource( 10 )
text = "High:000000"
[node name="LivesCounter" type="Label" parent="HUD"]
margin_left = 1.0
margin_top = 178.0
margin_right = 85.0
margin_bottom = 198.0
theme = ExtResource( 10 )
text = "Lives:2"
[node name="ArrowCounter" type="Label" parent="HUD"]
margin_left = 237.0
margin_top = 1.0

View file

@ -24,8 +24,11 @@ var jump_force = 150
var doublejump_force = 120
var current_ladder = null #Used for checking climbing every frame instead of area entered
var can_doublejump = true
var can_move_in_air = false
#Positions
var arrowpos = Vector2(5,3)
#Tiles
onready var deathtiles = map.get_node("Death")
##Preload
var pre_arrow = preload("res://objects/player/arrow_projectile.tscn")
@ -95,8 +98,9 @@ func _process_walk():
collision.get_collider().push(collision.normal)
func _process_idle_walk():
can_doublejump = false
can_move_in_air = false
velocity.y = 0
can_doublejump = true
#Goto Fall
if !is_on_floor(): current_state = State.FALL
#Goto Jump
@ -123,6 +127,8 @@ func _process_fall():
if is_on_floor():
current_state = State.IDLE
return
#Cant move in air
if !can_move_in_air: velocity.x = 0
func _process_jump_fall():
check_double_jump()
@ -131,6 +137,7 @@ func _process_jump_fall():
check_shoot()
func _process_climb():
can_move_in_air = true
can_doublejump = true
#Graphics
anims.play("climb")
@ -184,6 +191,8 @@ func check_jump():
position.x -= sprite.scale.x * 5
anims.set_speed_scale(1)
# Jump
can_doublejump = true
can_move_in_air = true
velocity.y = 0
jump_pressure = 0
current_state = State.JUMP
@ -209,9 +218,10 @@ func check_shoot():
anims.play("shoot air") #Shoot immediately in air
func move(hsp,vsp,flip:bool):
velocity.x = hsp * axis.x
#Flip
if flip: if sign(axis.x) != 0: sprite.scale.x = axis.x
if is_on_floor() or can_move_in_air:
velocity.x = hsp * axis.x
#Flip
if flip: if sign(axis.x) != 0: sprite.scale.x = axis.x
func check_ladder():
if climb_ray.get_collider() != null:
@ -231,7 +241,20 @@ func check_ladder():
climb_ray.position.x = 4 * sprite.scale.x
func die():
get_tree().reload_current_scene()
position = Game.respawn_point
Game.lives -= 1
Game.play_sound(Game.a_die,Game.ac_die)
if Game.lives < 0:
if Game.score > Game.high_score: Game.high_score = Game.score
Game.score = 0
Game.golds = 0
Game.stars = [false,false,false,false,false]
Game.shards = 0
Game.arrows = 0
Game.lives = 2
Game.ac_climb.stop()
get_tree().reload_current_scene()
func _on_AnimationPlayer_animation_finished(anim_name):
#Return to idle after slash
@ -255,3 +278,4 @@ func debug():
if Input.is_action_pressed("debug_move_player"):
position = get_viewport().get_mouse_position()
print(get_viewport().get_mouse_position())

View file

@ -93,15 +93,17 @@ script = ExtResource( 1 )
[node name="Sprite" type="Sprite" parent="."]
position = Vector2( 4, 4 )
rotation = 1.5708
texture = ExtResource( 2 )
region_enabled = true
region_rect = Rect2( 0, 0, 8, 8 )
region_rect = Rect2( 8, 0, 8, 8 )
[node name="StaticBody2D" type="StaticBody2D" parent="."]
[node name="CollisionShape2D" type="CollisionShape2D" parent="StaticBody2D"]
position = Vector2( 4, 4 )
shape = SubResource( 1 )
disabled = true
[node name="AnimationPlayer" type="AnimationPlayer" parent="."]
anims/idle = SubResource( 2 )