added coins, bad guys
This commit is contained in:
parent
e0f48061e7
commit
f6ad5142bf
BIN
assets/graphics/collectibles/coin.png
Normal file
BIN
assets/graphics/collectibles/coin.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 500 B |
@ -2,16 +2,16 @@
|
||||
|
||||
importer="texture"
|
||||
type="CompressedTexture2D"
|
||||
uid="uid://dvo3fyb2k6saf"
|
||||
path="res://.godot/imported/trees.png-aae64ae71e38b889bacd9a989dc53946.ctex"
|
||||
uid="uid://cco2vhmejry0v"
|
||||
path="res://.godot/imported/coin.png-20c0ec177f21de2ef8f2f0e70fa6fe8a.ctex"
|
||||
metadata={
|
||||
"vram_texture": false
|
||||
}
|
||||
|
||||
[deps]
|
||||
|
||||
source_file="res://scenes/trees.png"
|
||||
dest_files=["res://.godot/imported/trees.png-aae64ae71e38b889bacd9a989dc53946.ctex"]
|
||||
source_file="res://assets/graphics/collectibles/coin.png"
|
||||
dest_files=["res://.godot/imported/coin.png-20c0ec177f21de2ef8f2f0e70fa6fe8a.ctex"]
|
||||
|
||||
[params]
|
||||
|
BIN
assets/graphics/enemies/slime_purple.png
Normal file
BIN
assets/graphics/enemies/slime_purple.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.0 KiB |
34
assets/graphics/enemies/slime_purple.png.import
Normal file
34
assets/graphics/enemies/slime_purple.png.import
Normal file
@ -0,0 +1,34 @@
|
||||
[remap]
|
||||
|
||||
importer="texture"
|
||||
type="CompressedTexture2D"
|
||||
uid="uid://dqo6e8pa3jewf"
|
||||
path="res://.godot/imported/slime_purple.png-7c7bd1452ab1f0d8805110e20459acf6.ctex"
|
||||
metadata={
|
||||
"vram_texture": false
|
||||
}
|
||||
|
||||
[deps]
|
||||
|
||||
source_file="res://assets/graphics/enemies/slime_purple.png"
|
||||
dest_files=["res://.godot/imported/slime_purple.png-7c7bd1452ab1f0d8805110e20459acf6.ctex"]
|
||||
|
||||
[params]
|
||||
|
||||
compress/mode=0
|
||||
compress/high_quality=false
|
||||
compress/lossy_quality=0.7
|
||||
compress/hdr_compression=1
|
||||
compress/normal_map=0
|
||||
compress/channel_pack=0
|
||||
mipmaps/generate=false
|
||||
mipmaps/limit=-1
|
||||
roughness/mode=0
|
||||
roughness/src_normal=""
|
||||
process/fix_alpha_border=true
|
||||
process/premult_alpha=false
|
||||
process/normal_map_invert_y=false
|
||||
process/hdr_as_srgb=false
|
||||
process/hdr_clamp_exposure=false
|
||||
process/size_limit=0
|
||||
detect_3d/compress_to=1
|
75
scenes/badguy.tscn
Normal file
75
scenes/badguy.tscn
Normal file
@ -0,0 +1,75 @@
|
||||
[gd_scene load_steps=9 format=3 uid="uid://bk0pk4m1ln716"]
|
||||
|
||||
[ext_resource type="Script" path="res://scripts/badguy.gd" id="1_oeik4"]
|
||||
[ext_resource type="Texture2D" uid="uid://dqo6e8pa3jewf" path="res://assets/graphics/enemies/slime_purple.png" id="2_bfdny"]
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_r6wn1"]
|
||||
atlas = ExtResource("2_bfdny")
|
||||
region = Rect2(0, 24, 24, 24)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_te1wg"]
|
||||
atlas = ExtResource("2_bfdny")
|
||||
region = Rect2(24, 24, 24, 24)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_g742w"]
|
||||
atlas = ExtResource("2_bfdny")
|
||||
region = Rect2(48, 24, 24, 24)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_6ebwa"]
|
||||
atlas = ExtResource("2_bfdny")
|
||||
region = Rect2(72, 24, 24, 24)
|
||||
|
||||
[sub_resource type="SpriteFrames" id="SpriteFrames_mb27d"]
|
||||
animations = [{
|
||||
"frames": [{
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_r6wn1")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_te1wg")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_g742w")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_6ebwa")
|
||||
}],
|
||||
"loop": true,
|
||||
"name": &"idle",
|
||||
"speed": 12.0
|
||||
}]
|
||||
|
||||
[sub_resource type="RectangleShape2D" id="RectangleShape2D_blkie"]
|
||||
size = Vector2(14, 15)
|
||||
|
||||
[node name="Area2D" type="Area2D" groups=["enemies"]]
|
||||
scale = Vector2(2, 2)
|
||||
script = ExtResource("1_oeik4")
|
||||
metadata/_edit_group_ = true
|
||||
|
||||
[node name="AnimatedSprite2D" type="AnimatedSprite2D" parent="."]
|
||||
texture_filter = 1
|
||||
sprite_frames = SubResource("SpriteFrames_mb27d")
|
||||
animation = &"idle"
|
||||
autoplay = "idle"
|
||||
frame_progress = 0.396641
|
||||
|
||||
[node name="CollisionShape2D" type="CollisionShape2D" parent="."]
|
||||
position = Vector2(0, 4.5)
|
||||
shape = SubResource("RectangleShape2D_blkie")
|
||||
|
||||
[node name="RightRay" type="RayCast2D" parent="."]
|
||||
target_position = Vector2(13, 0)
|
||||
|
||||
[node name="LeftRay" type="RayCast2D" parent="."]
|
||||
target_position = Vector2(-13, 0)
|
||||
|
||||
[node name="RightFloorRay" type="RayCast2D" parent="."]
|
||||
position = Vector2(8, 3)
|
||||
target_position = Vector2(0, 11)
|
||||
|
||||
[node name="LeftFloorRay" type="RayCast2D" parent="."]
|
||||
position = Vector2(-8, 3)
|
||||
target_position = Vector2(0, 11)
|
||||
|
||||
[connection signal="body_entered" from="." to="." method="_on_body_entered"]
|
116
scenes/coin.tscn
Normal file
116
scenes/coin.tscn
Normal file
@ -0,0 +1,116 @@
|
||||
[gd_scene load_steps=17 format=3 uid="uid://cey0ymp1n0iqe"]
|
||||
|
||||
[ext_resource type="Texture2D" uid="uid://cco2vhmejry0v" path="res://assets/graphics/collectibles/coin.png" id="1_c71mt"]
|
||||
[ext_resource type="Script" path="res://scripts/coin.gd" id="1_h4xkt"]
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_n1dcx"]
|
||||
atlas = ExtResource("1_c71mt")
|
||||
region = Rect2(0, 0, 16, 16)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_13l51"]
|
||||
atlas = ExtResource("1_c71mt")
|
||||
region = Rect2(16, 0, 16, 16)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_hahrw"]
|
||||
atlas = ExtResource("1_c71mt")
|
||||
region = Rect2(32, 0, 16, 16)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_mfe8o"]
|
||||
atlas = ExtResource("1_c71mt")
|
||||
region = Rect2(48, 0, 16, 16)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_71uln"]
|
||||
atlas = ExtResource("1_c71mt")
|
||||
region = Rect2(64, 0, 16, 16)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_c7ty3"]
|
||||
atlas = ExtResource("1_c71mt")
|
||||
region = Rect2(80, 0, 16, 16)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_n435u"]
|
||||
atlas = ExtResource("1_c71mt")
|
||||
region = Rect2(96, 0, 16, 16)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_6uw02"]
|
||||
atlas = ExtResource("1_c71mt")
|
||||
region = Rect2(112, 0, 16, 16)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_xlt2g"]
|
||||
atlas = ExtResource("1_c71mt")
|
||||
region = Rect2(128, 0, 16, 16)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_367r4"]
|
||||
atlas = ExtResource("1_c71mt")
|
||||
region = Rect2(144, 0, 16, 16)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_omldi"]
|
||||
atlas = ExtResource("1_c71mt")
|
||||
region = Rect2(160, 0, 16, 16)
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_74aet"]
|
||||
atlas = ExtResource("1_c71mt")
|
||||
region = Rect2(176, 0, 16, 16)
|
||||
|
||||
[sub_resource type="SpriteFrames" id="SpriteFrames_dwt5l"]
|
||||
animations = [{
|
||||
"frames": [{
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_n1dcx")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_13l51")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_hahrw")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_mfe8o")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_71uln")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_c7ty3")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_n435u")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_6uw02")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_xlt2g")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_367r4")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_omldi")
|
||||
}, {
|
||||
"duration": 1.0,
|
||||
"texture": SubResource("AtlasTexture_74aet")
|
||||
}],
|
||||
"loop": true,
|
||||
"name": &"idle",
|
||||
"speed": 12.0
|
||||
}]
|
||||
|
||||
[sub_resource type="CircleShape2D" id="CircleShape2D_4xboy"]
|
||||
radius = 5.0
|
||||
|
||||
[node name="Area2D" type="Area2D" groups=["collectibles"]]
|
||||
script = ExtResource("1_h4xkt")
|
||||
metadata/_edit_group_ = true
|
||||
|
||||
[node name="AnimatedSprite2D" type="AnimatedSprite2D" parent="."]
|
||||
texture_filter = 1
|
||||
sprite_frames = SubResource("SpriteFrames_dwt5l")
|
||||
animation = &"idle"
|
||||
autoplay = "idle"
|
||||
frame_progress = 0.32788
|
||||
|
||||
[node name="CollisionShape2D" type="CollisionShape2D" parent="."]
|
||||
shape = SubResource("CircleShape2D_4xboy")
|
||||
debug_color = Color(0.614132, 0.536519, 0.0596093, 0.42)
|
||||
|
||||
[connection signal="body_entered" from="." to="." method="_on_body_entered"]
|
File diff suppressed because one or more lines are too long
@ -1,4 +1,4 @@
|
||||
[gd_scene load_steps=13 format=4 uid="uid://dxvvtcldbhsac"]
|
||||
[gd_scene load_steps=14 format=4 uid="uid://dxvvtcldbhsac"]
|
||||
|
||||
[ext_resource type="Texture2D" uid="uid://dordo7deet5y0" path="res://assets/graphics/terrains/backgrounds/forestbackground.png" id="1_fca7k"]
|
||||
[ext_resource type="Texture2D" uid="uid://cukevm4avtgnp" path="res://assets/graphics/terrains/backgrounds/sky.png" id="2_7a0hu"]
|
||||
@ -8,6 +8,7 @@
|
||||
[ext_resource type="PackedScene" uid="uid://b2hyqfqh02ep6" path="res://scenes/player.tscn" id="6_4x3pf"]
|
||||
[ext_resource type="Script" path="res://scripts/trigger.gd" id="7_vcera"]
|
||||
[ext_resource type="PackedScene" uid="uid://djkjmi7bo58uv" path="res://scenes/crate.tscn" id="8_q5n2b"]
|
||||
[ext_resource type="PackedScene" uid="uid://cey0ymp1n0iqe" path="res://scenes/coin.tscn" id="9_iql8u"]
|
||||
|
||||
[sub_resource type="TileSetAtlasSource" id="TileSetAtlasSource_v72u6"]
|
||||
texture = ExtResource("5_qoo1j")
|
||||
@ -455,5 +456,21 @@ rotation = -0.0982481
|
||||
[node name="RigidBody2D" parent="crates" instance=ExtResource("8_q5n2b")]
|
||||
position = Vector2(501, 265)
|
||||
|
||||
[node name="coins" type="Node2D" parent="."]
|
||||
|
||||
[node name="Area2D" parent="coins" instance=ExtResource("9_iql8u")]
|
||||
position = Vector2(72, 107)
|
||||
script = null
|
||||
|
||||
[node name="Area2D2" parent="coins" instance=ExtResource("9_iql8u")]
|
||||
position = Vector2(-42, 11)
|
||||
script = null
|
||||
|
||||
[node name="Area2D3" parent="coins" instance=ExtResource("9_iql8u")]
|
||||
position = Vector2(-55, 295)
|
||||
|
||||
[node name="Area2D4" parent="coins" instance=ExtResource("9_iql8u")]
|
||||
position = Vector2(321, 198)
|
||||
|
||||
[connection signal="areaTrigger" from="Area2D" to="." method="_on_trigger"]
|
||||
[connection signal="body_entered" from="Area2D" to="Area2D" method="_on_body_entered"]
|
||||
|
@ -200,8 +200,8 @@ offset = Vector2(0, -30)
|
||||
|
||||
[node name="AnimatedSprite2D" type="AnimatedSprite2D" parent="."]
|
||||
texture_filter = 1
|
||||
position = Vector2(-1, -4)
|
||||
position = Vector2(-1, -3)
|
||||
scale = Vector2(1.29167, 1.29167)
|
||||
sprite_frames = SubResource("SpriteFrames_52pno")
|
||||
animation = &"playerJump"
|
||||
animation = &"playerIdle"
|
||||
autoplay = "playerIdle"
|
||||
|
BIN
scenes/trees.png
BIN
scenes/trees.png
Binary file not shown.
Before Width: | Height: | Size: 20 KiB |
32
scripts/badguy.gd
Normal file
32
scripts/badguy.gd
Normal file
@ -0,0 +1,32 @@
|
||||
class_name BadGuy extends Area2D
|
||||
|
||||
@onready var sprite: AnimatedSprite2D = $AnimatedSprite2D
|
||||
@onready var right_ray: RayCast2D = $RightRay
|
||||
@onready var left_ray: RayCast2D = $LeftRay
|
||||
@onready var right_floor_ray: RayCast2D = $RightFloorRay
|
||||
@onready var left_floor_ray: RayCast2D = $LeftFloorRay
|
||||
|
||||
const speed := 60
|
||||
|
||||
var direction = 1
|
||||
|
||||
signal playerHurt
|
||||
|
||||
func _process(delta: float) -> void:
|
||||
if not right_floor_ray.is_colliding():
|
||||
#about to fall off the right
|
||||
direction = -1
|
||||
sprite.flip_h = not sprite.flip_h
|
||||
if not left_floor_ray.is_colliding():
|
||||
#about to fall off the left
|
||||
sprite.flip_h = not sprite.flip_h
|
||||
direction = 1
|
||||
|
||||
position.x += direction*speed*delta
|
||||
|
||||
func _on_body_entered(body: Node2D) -> void:
|
||||
if body.is_in_group("player"):
|
||||
print("player hurt")
|
||||
playerHurt.emit()
|
||||
# queue_free()
|
||||
|
9
scripts/coin.gd
Normal file
9
scripts/coin.gd
Normal file
@ -0,0 +1,9 @@
|
||||
class_name Coin extends Area2D
|
||||
|
||||
signal coinCollected
|
||||
|
||||
func _on_body_entered(body: Node2D) -> void:
|
||||
if body.is_in_group("player"):
|
||||
coinCollected.emit()
|
||||
queue_free()
|
||||
|
@ -3,11 +3,16 @@ extends Node2D
|
||||
var timer:= Timer.new()
|
||||
var secondCount= 99
|
||||
var totalCrates := 0
|
||||
var totalCoins := 0
|
||||
var totalBadGuys := 0
|
||||
var totalCoinsCollected := 0
|
||||
var cratesDestroyed := 0
|
||||
|
||||
var player:Resource
|
||||
|
||||
# level info
|
||||
var levels = ["res://scenes/game.tscn", "res://scenes/level2.tscn"]
|
||||
var timers = [20, 15]
|
||||
var timers = [30, 30]
|
||||
var currentLevel = 0
|
||||
|
||||
#Gamecontroller signals
|
||||
@ -16,6 +21,8 @@ signal levelComplete(leveltoLoad)
|
||||
|
||||
# Called when the node enters the scene tree for the first time.
|
||||
func _ready() -> void:
|
||||
player = load("res://scripts/res/playerstats.tres")
|
||||
print("Player Health: "+str(player.health))
|
||||
print("Number of levels: "+str(levels.size()))
|
||||
add_child(timer)
|
||||
timer.wait_time = 1
|
||||
@ -33,6 +40,17 @@ func secondCounter():
|
||||
print("TIME IS UP")
|
||||
levelComplete.emit(levels[currentLevel])
|
||||
|
||||
func playerDamaged():
|
||||
print("GC knows player took damage")
|
||||
player.health = max(player.health-10, 0)
|
||||
print("Player Health: "+str(player.health))
|
||||
|
||||
|
||||
|
||||
func coinCollected():
|
||||
totalCoinsCollected += 1
|
||||
print("DING! Coins collected: "+ str(totalCoinsCollected) )
|
||||
|
||||
func bulletHit(body):
|
||||
print("Game controller knows bullet hit something")
|
||||
if body.is_in_group("destructables"):
|
||||
@ -48,7 +66,14 @@ func bulletHit(body):
|
||||
levelComplete.emit(levels[currentLevel])
|
||||
else:
|
||||
print("Crates Remaining: "+str(totalCrates) )
|
||||
|
||||
|
||||
# Coming from scenemanager
|
||||
func countCrates(value):
|
||||
totalCrates = value
|
||||
|
||||
func countCoins(value):
|
||||
totalCoins = value
|
||||
|
||||
func countBadGuys(value):
|
||||
totalBadGuys = value
|
||||
|
||||
|
5
scripts/res/characterStats.gd
Normal file
5
scripts/res/characterStats.gd
Normal file
@ -0,0 +1,5 @@
|
||||
class_name CharacterStats extends Resource
|
||||
|
||||
@export var max_health:int = 100
|
||||
@export var starting_health:int = 100
|
||||
@export var health:int = 100
|
9
scripts/res/playerstats.tres
Normal file
9
scripts/res/playerstats.tres
Normal file
@ -0,0 +1,9 @@
|
||||
[gd_resource type="Resource" script_class="CharacterStats" load_steps=2 format=3 uid="uid://hdyv13v8yr88"]
|
||||
|
||||
[ext_resource type="Script" path="res://scripts/res/characterStats.gd" id="1_d4qjr"]
|
||||
|
||||
[resource]
|
||||
script = ExtResource("1_d4qjr")
|
||||
max_health = 150
|
||||
starting_health = 100
|
||||
health = 100
|
9
scripts/res/slimestats.tres
Normal file
9
scripts/res/slimestats.tres
Normal file
@ -0,0 +1,9 @@
|
||||
[gd_resource type="Resource" script_class="CharacterStats" load_steps=2 format=3 uid="uid://3vw8xffecvtj"]
|
||||
|
||||
[ext_resource type="Script" path="res://scripts/res/characterStats.gd" id="1_74dik"]
|
||||
|
||||
[resource]
|
||||
script = ExtResource("1_74dik")
|
||||
max_health = 60
|
||||
starting_health = 50
|
||||
health = 50
|
@ -2,21 +2,37 @@ extends Node
|
||||
# @onready var game: Node2D = $".."
|
||||
|
||||
@onready var crates: Node2D = $"../crates"
|
||||
@onready var coins: Node2D = $"../coins"
|
||||
@onready var enemies: Node2D = $"../enemies"
|
||||
|
||||
var theBullet = preload("res://scenes/bullet.tscn")
|
||||
var bulletArray:Array = []
|
||||
|
||||
var totalCrates := 0
|
||||
|
||||
# Called when the node enters the scene tree for the first time.
|
||||
func _ready() -> void:
|
||||
var totalCrates = 0
|
||||
GameController.reset()
|
||||
GameController.destroyBox.connect(boxDestroy)
|
||||
for obj in crates.get_children():
|
||||
if obj.is_in_group("destructables"):
|
||||
totalCrates += 1
|
||||
GameController.countCrates(totalCrates)
|
||||
|
||||
var totalCoins = 0
|
||||
for obj in coins.get_children():
|
||||
if obj.is_in_group("collectibles"):
|
||||
totalCoins += 1
|
||||
obj.coinCollected.connect(GameController.coinCollected)
|
||||
GameController.countCoins(totalCoins)
|
||||
|
||||
var totalEnemies = 0
|
||||
for obj in enemies.get_children():
|
||||
if obj.is_in_group("enemies"):
|
||||
totalEnemies += 1
|
||||
obj.playerHurt.connect(GameController.playerDamaged)
|
||||
GameController.countBadGuys(totalEnemies)
|
||||
|
||||
GameController.countCrates(totalCrates)
|
||||
# Subscribe to signals
|
||||
GameController.levelComplete.connect(changeLevel)
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user