v bad player explosions

This commit is contained in:
Robin Hübner 2017-08-24 21:50:28 +02:00
parent f9c1f1380d
commit 1d1d2b4439
5 changed files with 23 additions and 133 deletions

View File

@ -1,4 +1,4 @@
[gd_scene load_steps=9 format=1] [gd_scene load_steps=8 format=1]
[ext_resource path="res://Game.gd" type="Script" id=1] [ext_resource path="res://Game.gd" type="Script" id=1]
[ext_resource path="res://Minimap.tscn" type="PackedScene" id=2] [ext_resource path="res://Minimap.tscn" type="PackedScene" id=2]
@ -7,7 +7,6 @@
[ext_resource path="res://Player.tscn" type="PackedScene" id=5] [ext_resource path="res://Player.tscn" type="PackedScene" id=5]
[ext_resource path="res://raw/space.png" type="Texture" id=6] [ext_resource path="res://raw/space.png" type="Texture" id=6]
[ext_resource path="res://EnemyGrunt.tscn" type="PackedScene" id=7] [ext_resource path="res://EnemyGrunt.tscn" type="PackedScene" id=7]
[ext_resource path="res://Missile.tscn" type="PackedScene" id=8]
[node name="Game" type="Node"] [node name="Game" type="Node"]
@ -72,88 +71,4 @@ region_rect = Rect2( 0, 0, 8192, 8192 )
transform/pos = Vector2( 127.878, -20.3627 ) transform/pos = Vector2( 127.878, -20.3627 )
transform/scale = Vector2( 1.5, 1.5 ) transform/scale = Vector2( 1.5, 1.5 )
[node name="Missile" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( -185.011, -27.2074 )
[node name="Missile1" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( -406.751, 14.9641 )
[node name="Missile2" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( -529.185, 130.596 )
[node name="Missile3" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( -635.294, 254.39 )
[node name="Missile4" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( -681.546, 423.076 )
[node name="Missile5" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( -872.16, 532.262 )
[node name="Missile6" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( -935.081, 743.232 )
[node name="Missile7" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( -935.081, 743.232 )
[node name="Missile8" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( 491.753, 33.61 )
[node name="Missile9" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( 802.924, 120.89 )
[node name="Missile10" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( 954.715, 219.554 )
[node name="Missile11" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( 1106.51, 299.244 )
[node name="Missile12" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( 1227.94, 420.677 )
[node name="Missile13" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( 1356.96, 576.262 )
[node name="Missile14" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( 1459.42, 716.669 )
[node name="Missile15" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( 1573.26, 906.407 )
[node name="Missile16" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( 1675.72, 1020.25 )
[node name="Missile17" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( 1804.74, 1206.19 )
[node name="Missile18" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( -274.79, 48.7891 )
[node name="Missile19" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( -532.835, 348.576 )
[node name="Missile20" parent="." instance=ExtResource( 8 )]
transform/pos = Vector2( -631.499, 591.441 )

View File

@ -48,6 +48,7 @@ class Seek:
owner = o owner = o
func get_steering(s): func get_steering(s):
if target == null: return
var tr = target.get_ref() var tr = target.get_ref()
if tr: if tr:
# update velocity # update velocity
@ -79,6 +80,7 @@ class Arrive:
time_to_target = a time_to_target = a
func get_steering(s): func get_steering(s):
if target == null: return
var tr = target.get_ref() var tr = target.get_ref()
if tr: if tr:
if s.velocity.length() < radius: if s.velocity.length() < radius:

View File

@ -18,7 +18,6 @@ var cur_kinematic
var steering var steering
var s_seek var s_seek
var s_arrive var s_arrive
var s_avoid
# is dead? # is dead?
var is_dead = false var is_dead = false
@ -37,7 +36,6 @@ func _ready():
s_seek = km.Seek.new(self) s_seek = km.Seek.new(self)
s_arrive = km.Arrive.new(self, missile_arrive_radius, missile_arrive_speed) s_arrive = km.Arrive.new(self, missile_arrive_radius, missile_arrive_speed)
s_avoid = km.Avoid.new(self, avoid_area)
var player = get_tree().get_root().get_node("Game/Player") var player = get_tree().get_root().get_node("Game/Player")
s_seek.set_target(player) s_seek.set_target(player)
@ -91,7 +89,6 @@ func _fixed_process(delta):
s_seek.get_steering(steering) s_seek.get_steering(steering)
s_arrive.get_steering(steering) s_arrive.get_steering(steering)
s_avoid.get_steering(steering)
cur_kinematic.update(steering, delta) cur_kinematic.update(steering, delta)
if is_colliding(): if is_colliding():

View File

@ -1,4 +1,4 @@
[gd_scene load_steps=6 format=1] [gd_scene load_steps=4 format=1]
[ext_resource path="res://Missile.gd" type="Script" id=1] [ext_resource path="res://Missile.gd" type="Script" id=1]
[ext_resource path="res://raw/missile_one.png" type="Texture" id=2] [ext_resource path="res://raw/missile_one.png" type="Texture" id=2]
@ -8,18 +8,6 @@
custom_solver_bias = 0.0 custom_solver_bias = 0.0
extents = Vector2( 0.531269, 3.07443 ) extents = Vector2( 0.531269, 3.07443 )
[sub_resource type="SegmentShape2D" id=2]
custom_solver_bias = 0.0
a = Vector2( 0, 0 )
b = Vector2( 0, 10 )
[sub_resource type="SegmentShape2D" id=3]
custom_solver_bias = 0.0
a = Vector2( 0, 0 )
b = Vector2( 0, 10 )
[node name="Missile" type="KinematicBody2D"] [node name="Missile" type="KinematicBody2D"]
transform/scale = Vector2( 2, 2 ) transform/scale = Vector2( 2, 2 )
@ -67,34 +55,4 @@ shape = SubResource( 1 )
trigger = false trigger = false
_update_shape_index = 0 _update_shape_index = 0
[node name="AvoidCone" type="Area2D" parent="."]
input/pickable = true
shapes/0/shape = SubResource( 2 )
shapes/0/transform = Matrix32( -0.92388, 0.382683, -0.382683, -0.92388, 0, 0 )
shapes/0/trigger = true
shapes/1/shape = SubResource( 3 )
shapes/1/transform = Matrix32( -0.92388, -0.382683, 0.382683, -0.92388, 0, 0 )
shapes/1/trigger = true
gravity_vec = Vector2( 0, 1 )
gravity = 98.0
linear_damp = 0.1
angular_damp = 1.0
collision/layers = 4
collision/mask = 6
[node name="LeftFeeler" type="CollisionShape2D" parent="AvoidCone"]
transform/rot = 202.5
shape = SubResource( 2 )
trigger = true
_update_shape_index = 0
[node name="RightFeeler" type="CollisionShape2D" parent="AvoidCone"]
transform/rot = 157.5
shape = SubResource( 3 )
trigger = true
_update_shape_index = 1

View File

@ -1,5 +1,7 @@
extends KinematicBody2D extends KinematicBody2D
var ExplosionEffect = load("res://ExplosionEffect.tscn")
onready var sprite = get_node("Sprite") onready var sprite = get_node("Sprite")
onready var camera = get_node("Camera2D") onready var camera = get_node("Camera2D")
onready var left_particles = get_node("Sprite/LeftThruster") onready var left_particles = get_node("Sprite/LeftThruster")
@ -17,6 +19,9 @@ var ship_turn_speed = deg2rad(180) # degrees per second.. i guess?
var ship_dir = Vector2(1, 0) var ship_dir = Vector2(1, 0)
var ship_mass = 61 var ship_mass = 61
var ship_health = 100
var player_is_dead = false
var is_moving = false var is_moving = false
var missiles_locked_on = 0 var missiles_locked_on = 0
var is_engine_playing = false var is_engine_playing = false
@ -34,7 +39,7 @@ func type():
return "Player" return "Player"
func do_damage(v): func do_damage(v):
pass ship_health -= v
func get_kinematic_position(): func get_kinematic_position():
return get_global_pos() + ship_vel return get_global_pos() + ship_vel
@ -79,9 +84,22 @@ func get_closest_missile_distance():
if mis_dist < min_dist: if mis_dist < min_dist:
min_dist = mis_dist min_dist = mis_dist
return min_dist return min_dist
func player_explode():
# create explosion effect
var new_ee = ExplosionEffect.instance()
get_tree().get_root().add_child(new_ee)
new_ee.set_global_pos(get_global_pos())
player_is_dead = true
func _fixed_process(delta): func _fixed_process(delta):
if ship_health <= 0 and not player_is_dead:
player_explode()
if player_is_dead:
return
var mov_delta = Vector2(0, 0) var mov_delta = Vector2(0, 0)
turn_towards(delta, get_global_mouse_pos()) turn_towards(delta, get_global_mouse_pos())