This commit is contained in:
Logan 2020-07-21 17:49:04 -05:00
parent f2829a8046
commit 6b52d24e74
16 changed files with 167 additions and 19 deletions

View file

@ -6,5 +6,5 @@ func _process(delta):
if get_overlapping_bodies().size() != 0: if get_overlapping_bodies().size() != 0:
print("1") print("1")
if Input.is_action_pressed("open"): if Input.is_action_pressed("open"):
Player.current_scene = "res://levels/World.tscn" Player.current_scene = "res://levels/Level 1.tscn"
get_tree().change_scene("res://levels/test.tscn") get_tree().change_scene("res://levels/Level 1.tscn")

View file

@ -26,6 +26,7 @@ extents = Vector2( 14, 13 )
texture = ExtResource( 1 ) texture = ExtResource( 1 )
centered = false centered = false
hframes = 2 hframes = 2
frame = 1
[node name="AnimationPlayer" type="AnimationPlayer" parent="."] [node name="AnimationPlayer" type="AnimationPlayer" parent="."]
"anims/Door Opening" = SubResource( 1 ) "anims/Door Opening" = SubResource( 1 )

View file

@ -3,7 +3,7 @@ extends Node
var position: Vector2 = Vector2() var position: Vector2 = Vector2()
var health = null var health = null
var energy = null var energy = null
var unlocked: Array = [Globals.Conduit2] var unlocked: Array = []
var current_scene: String var current_scene: String
func respawn(): func respawn():

View file

@ -176,7 +176,7 @@ __meta__ = {
} }
[node name="Player" parent="." instance=ExtResource( 2 )] [node name="Player" parent="." instance=ExtResource( 2 )]
position = Vector2( -25.7683, 148.492 ) position = Vector2( 1919.33, 146.658 )
[node name="text" type="Node2D" parent="."] [node name="text" type="Node2D" parent="."]
position = Vector2( -5.81107, -6.20908 ) position = Vector2( -5.81107, -6.20908 )

View file

@ -7,13 +7,13 @@
[node name="Node2D" type="Node2D"] [node name="Node2D" type="Node2D"]
[node name="TileMap" parent="." instance=ExtResource( 2 )] [node name="TileMap" parent="." instance=ExtResource( 2 )]
tile_data = PoolIntArray( 65536, 0, 8, 65537, 0, 10, 65538, 0, 10, 65539, 0, 10, 65540, 0, 10, 65541, 0, 10, 65542, 0, 10, 65543, 0, 10, 65544, 0, 10, 65545, 0, 10, 65546, 0, 10, 65547, 0, 10, 65548, 0, 10, 65549, 0, 10, 65550, 0, 10, 65551, 0, 10, 65552, 0, 10, 65553, 0, 10, 65554, 0, 10, 65555, 0, 10, 65556, 0, 10, 65557, 0, 10, 65558, 0, 10, 65559, 0, 10, 65560, 0, 10, 65561, 0, 10, 65562, 0, 10, 65563, 0, 10, 65564, 0, 10, 65565, 0, 10, 65566, 0, 10, 65567, 0, 10, 65568, 0, 10, 65569, 0, 11, 131072, 0, 65544, 131073, 0, 131078, 131074, 0, 196617, 131075, 0, 196617, 131076, 0, 196617, 131077, 0, 196617, 131078, 0, 196617, 131079, 0, 196617, 131080, 0, 196617, 131081, 0, 196617, 131082, 0, 196617, 131083, 0, 196617, 131084, 0, 196617, 131085, 0, 196617, 131086, 0, 196617, 131087, 0, 196617, 131088, 0, 196617, 131089, 0, 196617, 131090, 0, 196617, 131091, 0, 196617, 131092, 0, 196617, 131093, 0, 196617, 131094, 0, 196617, 131095, 0, 196617, 131096, 0, 196617, 131097, 0, 196617, 131098, 0, 196617, 131099, 0, 196617, 131100, 0, 196617, 131101, 0, 196617, 131102, 0, 196617, 131103, 0, 196617, 131104, 0, 196617, 131105, 0, 196619, 196608, 0, 65544, 196609, 0, 131083, 262144, 0, 65544, 262145, 0, 131083, 327680, 0, 65544, 327681, 0, 131083, 393216, 0, 65544, 393217, 0, 131083, 458752, 0, 65544, 458753, 0, 131083, 524288, 0, 65544, 524289, 0, 131083, 589824, 0, 65544, 589825, 0, 131083, 589858, 0, 8, 589859, 0, 11, 655360, 0, 65544, 655361, 0, 131083, 655394, 0, 65544, 655395, 0, 131083, 720896, 0, 65544, 720897, 0, 65542, 720898, 0, 10, 720899, 0, 10, 720900, 0, 10, 720901, 0, 10, 720902, 0, 10, 720903, 0, 10, 720904, 0, 10, 720905, 0, 10, 720906, 0, 10, 720907, 0, 10, 720908, 0, 10, 720909, 0, 10, 720910, 0, 10, 720911, 0, 10, 720912, 0, 10, 720913, 0, 10, 720914, 0, 10, 720915, 0, 10, 720916, 0, 10, 720917, 0, 10, 720918, 0, 10, 720919, 0, 10, 720920, 0, 10, 720921, 0, 10, 720922, 0, 10, 720923, 0, 10, 720924, 0, 10, 720925, 0, 10, 720926, 0, 10, 720927, 0, 10, 720928, 0, 10, 720929, 0, 10, 720930, 0, 65541, 720931, 0, 131083, 786432, 0, 196616, 786433, 0, 196617, 786434, 0, 196617, 786435, 0, 196617, 786436, 0, 196617, 786437, 0, 196617, 786438, 0, 196617, 786439, 0, 196617, 786440, 0, 196617, 786441, 0, 196617, 786442, 0, 196617, 786443, 0, 196617, 786444, 0, 196617, 786445, 0, 196617, 786446, 0, 196617, 786447, 0, 196617, 786448, 0, 196617, 786449, 0, 196617, 786450, 0, 196617, 786451, 0, 196617, 786452, 0, 196617, 786453, 0, 196617, 786454, 0, 196617, 786455, 0, 196617, 786456, 0, 196617, 786457, 0, 196617, 786458, 0, 196617, 786459, 0, 196617, 786460, 0, 196617, 786461, 0, 196617, 786462, 0, 196617, 786463, 0, 196617, 786464, 0, 196617, 786465, 0, 196617, 786466, 0, 196617, 786467, 0, 196619 ) tile_data = PoolIntArray( 65536, 0, 8, 65537, 0, 10, 65538, 0, 10, 65539, 0, 10, 65540, 0, 10, 65541, 0, 10, 65542, 0, 10, 65543, 0, 10, 65544, 0, 10, 65545, 0, 10, 65546, 0, 10, 65547, 0, 10, 65548, 0, 10, 65549, 0, 10, 65550, 0, 10, 65551, 0, 10, 65552, 0, 10, 65553, 0, 10, 65554, 0, 10, 65555, 0, 10, 65556, 0, 10, 65557, 0, 10, 65558, 0, 10, 65559, 0, 10, 65560, 0, 10, 65561, 0, 10, 65562, 0, 10, 65563, 0, 10, 65564, 0, 10, 65565, 0, 10, 65566, 0, 10, 65567, 0, 10, 65568, 0, 10, 65569, 0, 11, 131072, 0, 65544, 131073, 0, 131078, 131074, 0, 196617, 131075, 0, 196617, 131076, 0, 196617, 131077, 0, 196617, 131078, 0, 196617, 131079, 0, 196617, 131080, 0, 196617, 131081, 0, 196617, 131082, 0, 196617, 131083, 0, 196617, 131084, 0, 196617, 131085, 0, 196617, 131086, 0, 196617, 131087, 0, 196617, 131088, 0, 196617, 131089, 0, 196617, 131090, 0, 196617, 131091, 0, 196617, 131092, 0, 196617, 131093, 0, 196617, 131094, 0, 196617, 131095, 0, 196617, 131096, 0, 196617, 131097, 0, 196617, 131098, 0, 196617, 131099, 0, 196617, 131100, 0, 196617, 131101, 0, 196617, 131102, 0, 196617, 131103, 0, 196617, 131104, 0, 196617, 131105, 0, 196619, 196608, 0, 65544, 196609, 0, 131083, 262144, 0, 65544, 262145, 0, 131083, 327680, 0, 65544, 327681, 0, 131083, 393216, 0, 65544, 393217, 0, 131083, 458752, 0, 65544, 458753, 0, 131083, 524288, 0, 65544, 524289, 0, 131083, 589824, 0, 65544, 589825, 0, 131083, 589838, 0, 0, 589858, 0, 8, 589859, 0, 11, 655360, 0, 65544, 655361, 0, 131083, 655374, 0, 65540, 655375, 0, 11, 655394, 0, 65544, 655395, 0, 131083, 720896, 0, 65544, 720897, 0, 65542, 720898, 0, 10, 720899, 0, 10, 720900, 0, 10, 720901, 0, 10, 720902, 0, 10, 720903, 0, 10, 720904, 0, 10, 720905, 0, 10, 720906, 0, 10, 720907, 0, 10, 720908, 0, 10, 720909, 0, 10, 720910, 0, 65541, 720911, 0, 65542, 720912, 0, 10, 720913, 0, 10, 720914, 0, 10, 720915, 0, 10, 720916, 0, 10, 720917, 0, 10, 720918, 0, 10, 720919, 0, 10, 720920, 0, 10, 720921, 0, 10, 720922, 0, 10, 720923, 0, 10, 720924, 0, 10, 720925, 0, 10, 720926, 0, 10, 720927, 0, 10, 720928, 0, 10, 720929, 0, 10, 720930, 0, 65541, 720931, 0, 131083, 786432, 0, 196616, 786433, 0, 196617, 786434, 0, 196617, 786435, 0, 196617, 786436, 0, 196617, 786437, 0, 196617, 786438, 0, 196617, 786439, 0, 196617, 786440, 0, 196617, 786441, 0, 196617, 786442, 0, 196617, 786443, 0, 196617, 786444, 0, 196617, 786445, 0, 196617, 786446, 0, 196617, 786447, 0, 196617, 786448, 0, 196617, 786449, 0, 196617, 786450, 0, 196617, 786451, 0, 196617, 786452, 0, 196617, 786453, 0, 196617, 786454, 0, 196617, 786455, 0, 196617, 786456, 0, 196617, 786457, 0, 196617, 786458, 0, 196617, 786459, 0, 196617, 786460, 0, 196617, 786461, 0, 196617, 786462, 0, 196617, 786463, 0, 196617, 786464, 0, 196617, 786465, 0, 196617, 786466, 0, 196617, 786467, 0, 196619 )
[node name="Player" parent="." instance=ExtResource( 1 )] [node name="Player" parent="." instance=ExtResource( 1 )]
position = Vector2( 60, 176 ) position = Vector2( 60, 176 )
[node name="Ogre" parent="." instance=ExtResource( 3 )] [node name="Ogre" parent="." instance=ExtResource( 3 )]
position = Vector2( 366, 166 ) position = Vector2( 286, 170 )
[node name="Ogre2" parent="." instance=ExtResource( 3 )] [node name="Ogre2" parent="." instance=ExtResource( 3 )]
position = Vector2( 430, 164 ) position = Vector2( 347, 159 )

View file

@ -1,4 +1,5 @@
extends Beam extends Beam
func _ready(): func _ready():
energy_cost = 1 energy_cost = 0
damage = 0.5

View file

@ -3,7 +3,6 @@
[ext_resource path="res://magic/Beams/EcoBeam.png" type="Texture" id=1] [ext_resource path="res://magic/Beams/EcoBeam.png" type="Texture" id=1]
[ext_resource path="res://magic/Beams/EcoBeam.gd" type="Script" id=2] [ext_resource path="res://magic/Beams/EcoBeam.gd" type="Script" id=2]
[node name="EcoBeam" type="Node2D"] [node name="EcoBeam" type="Node2D"]
script = ExtResource( 2 ) script = ExtResource( 2 )

View file

@ -0,0 +1,5 @@
extends Beam
func _ready():
damage = 3
energy_cost = 5

View file

@ -0,0 +1,23 @@
[gd_scene load_steps=3 format=2]
[ext_resource path="res://magic/Beams/ExplosiveBeam.gd" type="Script" id=1]
[ext_resource path="res://magic/Beams/ExplosiveBeam.png" type="Texture" id=2]
[node name="ExplosiveBeam" type="Node2D"]
script = ExtResource( 1 )
[node name="Beam" type="Sprite" parent="."]
position = Vector2( 0, -4 )
texture = ExtResource( 2 )
centered = false
region_enabled = true
region_rect = Rect2( 0, 0, 8, 8 )
[node name="Begin" type="Sprite" parent="."]
[node name="RayCast2D" type="RayCast2D" parent="."]
enabled = true
cast_to = Vector2( 400, 0 )
collision_mask = 6
[node name="End" type="Position2D" parent="."]

View file

@ -0,0 +1,31 @@
extends Beam
func _ready():
energy_cost = 3
damage = 1
func activate():
$Beam.visible = true
$RayCast2D.enabled = true
$Area2D.monitoring = true
func get_collider():
var r = []
for b in $Area2D.get_overlapping_bodies():
r.append(b)
return r
func deactivate():
$Beam.visible = false
$RayCast2D.enabled = false
$Area2D.monitoring = false
func _physics_process(delta):
$RayCast2D.cast_to = max_cast
if $RayCast2D.is_colliding():
$End.global_position = $RayCast2D.get_collision_point()
else:
$End.position = max_cast
$Beam.region_rect.end.x = $End.position.length()
$Area2D/CollisionShape2D.shape.extents.x = $End.position.length() / 2
$Area2D.position.x = $End.position.length() / 2

View file

@ -0,0 +1,36 @@
[gd_scene load_steps=4 format=2]
[ext_resource path="res://magic/Beams/PhantomBeam.png" type="Texture" id=1]
[ext_resource path="res://magic/Beams/PhantomBeam.gd" type="Script" id=2]
[sub_resource type="RectangleShape2D" id=1]
extents = Vector2( 4, 4 )
[node name="PhantomBeam" type="Node2D"]
script = ExtResource( 2 )
[node name="Beam" type="Sprite" parent="."]
position = Vector2( 0, -4 )
texture = ExtResource( 1 )
centered = false
region_enabled = true
region_rect = Rect2( 0, 0, 8, 8 )
[node name="Begin" type="Sprite" parent="."]
[node name="RayCast2D" type="RayCast2D" parent="."]
enabled = true
cast_to = Vector2( 400, 0 )
collision_mask = 2
[node name="End" type="Position2D" parent="."]
[node name="Area2D" type="Area2D" parent="."]
monitorable = false
collision_layer = 0
collision_mask = 4
[node name="CollisionShape2D" type="CollisionShape2D" parent="Area2D"]
modulate = Color( 0.945313, 1, 0, 1 )
position = Vector2( 4, 0 )
shape = SubResource( 1 )

12
magic/Beams/WaveBeam.gd Normal file
View file

@ -0,0 +1,12 @@
extends Beam
func _ready():
energy_cost = 2
damage = 1
func get_collider():
var c = $RayCast2D.get_collider()
if c != null and c.has_method("get_type") and c.get_type() == "enemy":
print("knock")
c.do_knockback($RayCast2D.get_collision_normal())
return $RayCast2D.get_collider()

23
magic/Beams/WaveBeam.tscn Normal file
View file

@ -0,0 +1,23 @@
[gd_scene load_steps=3 format=2]
[ext_resource path="res://magic/Beams/WaveBeam.gd" type="Script" id=1]
[ext_resource path="res://magic/Beams/KnockbackBeam.png" type="Texture" id=2]
[node name="WaveBeam" type="Node2D"]
script = ExtResource( 1 )
[node name="Beam" type="Sprite" parent="."]
position = Vector2( 0, -4 )
texture = ExtResource( 2 )
centered = false
region_enabled = true
region_rect = Rect2( 0, 0, 8, 8 )
[node name="Begin" type="Sprite" parent="."]
[node name="RayCast2D" type="RayCast2D" parent="."]
enabled = true
cast_to = Vector2( 400, 0 )
collision_mask = 6
[node name="End" type="Position2D" parent="."]

View file

@ -3,16 +3,22 @@ extends Wand
func _ready(): func _ready():
$ProjectileSpawn.add_child(Globals.ecobeam_ps.instance()) $ProjectileSpawn.add_child(Globals.ecobeam_ps.instance())
$ProjectileSpawn/EcoBeam.deactivate() $ProjectileSpawn/EcoBeam.deactivate()
$ProjectileSpawn.add_child(Globals.phantombeam_ps.instance())
$ProjectileSpawn/PhantomBeam.deactivate()
$ProjectileSpawn.add_child(Globals.wavebeam_ps.instance())
$ProjectileSpawn/WaveBeam.deactivate()
$ProjectileSpawn.add_child(Globals.explosivebeam_ps.instance())
$ProjectileSpawn/ExplosiveBeam.deactivate()
func get_beam_type(p): func get_beam_type(p):
if p == Globals.Magic[Globals.Projectile1]: if p == Globals.Magic[Globals.Projectile1]:
return $ProjectileSpawn/EcoBeam return $ProjectileSpawn/EcoBeam
elif p == Globals.Magic[Globals.Projectile2]: elif p == Globals.Magic[Globals.Projectile2]:
return null return $ProjectileSpawn/PhantomBeam
elif p == Globals.Magic[Globals.Projectile3]: elif p == Globals.Magic[Globals.Projectile3]:
return null return $ProjectileSpawn/WaveBeam
elif p == Globals.Magic[Globals.Projectile4]: elif p == Globals.Magic[Globals.Projectile4]:
return null return $ProjectileSpawn/ExplosiveBeam
else: else:
return null return null
@ -23,10 +29,16 @@ func fire(projectile):
if $ShootDelay.is_stopped(): if $ShootDelay.is_stopped():
$ShootDelay.start() $ShootDelay.start()
var c = beam.get_collider() var c = beam.get_collider()
print(c) if typeof(c) == TYPE_ARRAY:
for body in c:
if body != null and body.has_method("get_type") && body.get_type() == "enemy":
body.health -= beam.damage
body.play_hit()
else:
if c != null and c.has_method("get_type") && c.get_type() == "enemy": if c != null and c.has_method("get_type") && c.get_type() == "enemy":
c.health -= beam.damage c.health -= beam.damage
return beam.energy_cost c.play_hit()
return 0
func _input(event): func _input(event):
if event.is_action_released("shoot"): if event.is_action_released("shoot"):

View file

@ -161,6 +161,11 @@ inventory={
"events": [ Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"alt":false,"shift":false,"control":false,"meta":false,"command":false,"pressed":false,"scancode":69,"unicode":0,"echo":false,"script":null) "events": [ Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"alt":false,"shift":false,"control":false,"meta":false,"command":false,"pressed":false,"scancode":69,"unicode":0,"echo":false,"script":null)
] ]
} }
open={
"deadzone": 0.5,
"events": [ Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":0,"alt":false,"shift":false,"control":false,"meta":false,"command":false,"pressed":false,"scancode":70,"unicode":0,"echo":false,"script":null)
]
}
[layer_names] [layer_names]

View file

@ -18,9 +18,9 @@ var projectile3_ps = preload("res://magic/Projectiles/WaveProjectile.tscn")
var projectile4_ps = preload("res://magic/Projectiles/ExplosiveProjectile.tscn") var projectile4_ps = preload("res://magic/Projectiles/ExplosiveProjectile.tscn")
var ecobeam_ps = preload("res://magic/Beams/EcoBeam.tscn") var ecobeam_ps = preload("res://magic/Beams/EcoBeam.tscn")
var phasebeam_ps var phantombeam_ps = preload("res://magic/Beams/PhantomBeam.tscn")
var wavebeam_ps var wavebeam_ps = preload("res://magic/Beams/WaveBeam.tscn")
var explosivebeam_ps var explosivebeam_ps = preload("res://magic/Beams/ExplosiveBeam.tscn")
var Magic: Array = [ var Magic: Array = [
conduit1_ps, conduit1_ps,