Added changes from week 2 videoa
This commit is contained in:
parent
90bdd35020
commit
3b09af598b
@ -21,3 +21,16 @@ folder_colors={
|
|||||||
"res://scenes/": "green",
|
"res://scenes/": "green",
|
||||||
"res://scripts/": "orange"
|
"res://scripts/": "orange"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[input]
|
||||||
|
|
||||||
|
Shove={
|
||||||
|
"deadzone": 0.5,
|
||||||
|
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":90,"key_label":0,"unicode":122,"location":0,"echo":false,"script":null)
|
||||||
|
]
|
||||||
|
}
|
||||||
|
Shoot={
|
||||||
|
"deadzone": 0.5,
|
||||||
|
"events": [Object(InputEventKey,"resource_local_to_scene":false,"resource_name":"","device":-1,"window_id":0,"alt_pressed":false,"shift_pressed":false,"ctrl_pressed":false,"meta_pressed":false,"pressed":false,"keycode":0,"physical_keycode":88,"key_label":0,"unicode":120,"location":0,"echo":false,"script":null)
|
||||||
|
]
|
||||||
|
}
|
||||||
|
17
scenes/bullet.tscn
Normal file
17
scenes/bullet.tscn
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
[gd_scene load_steps=3 format=3 uid="uid://b53r5iysu7d4t"]
|
||||||
|
|
||||||
|
[ext_resource type="Script" path="res://scripts/bullet.gd" id="1_qubif"]
|
||||||
|
|
||||||
|
[sub_resource type="RectangleShape2D" id="RectangleShape2D_qxj7e"]
|
||||||
|
size = Vector2(19, 4)
|
||||||
|
|
||||||
|
[node name="Area2D" type="Area2D"]
|
||||||
|
script = ExtResource("1_qubif")
|
||||||
|
metadata/_edit_group_ = true
|
||||||
|
|
||||||
|
[node name="CollisionShape2D" type="CollisionShape2D" parent="."]
|
||||||
|
position = Vector2(-0.5, 0)
|
||||||
|
shape = SubResource("RectangleShape2D_qxj7e")
|
||||||
|
debug_color = Color(0.717124, 0, 0.290401, 0.42)
|
||||||
|
|
||||||
|
[connection signal="body_entered" from="." to="." method="_on_body_entered"]
|
@ -1,8 +1,8 @@
|
|||||||
[gd_scene load_steps=9 format=3 uid="uid://dhgts0kodsujx"]
|
[gd_scene load_steps=8 format=3 uid="uid://dhgts0kodsujx"]
|
||||||
|
|
||||||
[ext_resource type="PackedScene" uid="uid://djkjmi7bo58uv" path="res://scenes/crate.tscn" id="1_6shkr"]
|
[ext_resource type="PackedScene" uid="uid://djkjmi7bo58uv" path="res://scenes/crate.tscn" id="1_6shkr"]
|
||||||
[ext_resource type="Script" path="res://scripts/gameController.gd" id="1_7tjsy"]
|
[ext_resource type="Script" path="res://scripts/gameController.gd" id="1_7tjsy"]
|
||||||
[ext_resource type="Script" path="res://scripts/charController.gd" id="2_uc4yi"]
|
[ext_resource type="PackedScene" uid="uid://b2hyqfqh02ep6" path="res://scenes/player.tscn" id="3_bssht"]
|
||||||
[ext_resource type="Script" path="res://scripts/trigger.gd" id="3_t4lk8"]
|
[ext_resource type="Script" path="res://scripts/trigger.gd" id="3_t4lk8"]
|
||||||
|
|
||||||
[sub_resource type="RectangleShape2D" id="RectangleShape2D_n7xvc"]
|
[sub_resource type="RectangleShape2D" id="RectangleShape2D_n7xvc"]
|
||||||
@ -11,9 +11,6 @@ size = Vector2(92, 20)
|
|||||||
[sub_resource type="WorldBoundaryShape2D" id="WorldBoundaryShape2D_gasd3"]
|
[sub_resource type="WorldBoundaryShape2D" id="WorldBoundaryShape2D_gasd3"]
|
||||||
distance = -484.0
|
distance = -484.0
|
||||||
|
|
||||||
[sub_resource type="CircleShape2D" id="CircleShape2D_uvblg"]
|
|
||||||
radius = 32.5576
|
|
||||||
|
|
||||||
[sub_resource type="CircleShape2D" id="CircleShape2D_5ph8t"]
|
[sub_resource type="CircleShape2D" id="CircleShape2D_5ph8t"]
|
||||||
radius = 62.0
|
radius = 62.0
|
||||||
|
|
||||||
@ -27,30 +24,13 @@ metadata/_edit_group_ = true
|
|||||||
[node name="CollisionShape2D" type="CollisionShape2D" parent="firstPlatform"]
|
[node name="CollisionShape2D" type="CollisionShape2D" parent="firstPlatform"]
|
||||||
shape = SubResource("RectangleShape2D_n7xvc")
|
shape = SubResource("RectangleShape2D_n7xvc")
|
||||||
|
|
||||||
[node name="RigidBody2D" parent="." instance=ExtResource("1_6shkr")]
|
|
||||||
position = Vector2(605, 106)
|
|
||||||
rotation = -0.706362
|
|
||||||
|
|
||||||
[node name="RigidBody2D2" parent="." instance=ExtResource("1_6shkr")]
|
|
||||||
position = Vector2(603, 208)
|
|
||||||
|
|
||||||
[node name="Floor" type="StaticBody2D" parent="."]
|
[node name="Floor" type="StaticBody2D" parent="."]
|
||||||
|
|
||||||
[node name="CollisionShape2D" type="CollisionShape2D" parent="Floor"]
|
[node name="CollisionShape2D" type="CollisionShape2D" parent="Floor"]
|
||||||
shape = SubResource("WorldBoundaryShape2D_gasd3")
|
shape = SubResource("WorldBoundaryShape2D_gasd3")
|
||||||
|
|
||||||
[node name="RigidBody2D4" parent="." instance=ExtResource("1_6shkr")]
|
[node name="CharacterBody2D" parent="." instance=ExtResource("3_bssht")]
|
||||||
position = Vector2(629, 37)
|
position = Vector2(188, 575)
|
||||||
|
|
||||||
[node name="CharacterBody2D" type="CharacterBody2D" parent="."]
|
|
||||||
position = Vector2(524, 393)
|
|
||||||
script = ExtResource("2_uc4yi")
|
|
||||||
PUSH_FORCE = 100
|
|
||||||
metadata/_edit_group_ = true
|
|
||||||
|
|
||||||
[node name="CollisionShape2D" type="CollisionShape2D" parent="CharacterBody2D"]
|
|
||||||
shape = SubResource("CircleShape2D_uvblg")
|
|
||||||
debug_color = Color(0.872789, 0.000463018, 0.842707, 0.42)
|
|
||||||
|
|
||||||
[node name="Area2D" type="Area2D" parent="."]
|
[node name="Area2D" type="Area2D" parent="."]
|
||||||
position = Vector2(952, 434)
|
position = Vector2(952, 434)
|
||||||
@ -61,8 +41,17 @@ metadata/_edit_group_ = true
|
|||||||
shape = SubResource("CircleShape2D_5ph8t")
|
shape = SubResource("CircleShape2D_5ph8t")
|
||||||
debug_color = Color(0.630721, 0.529414, 1.92523e-07, 0.42)
|
debug_color = Color(0.630721, 0.529414, 1.92523e-07, 0.42)
|
||||||
|
|
||||||
[node name="RigidBody2D3" parent="." instance=ExtResource("1_6shkr")]
|
[node name="RigidBody2D" parent="." groups=["pushables"] instance=ExtResource("1_6shkr")]
|
||||||
position = Vector2(534, 53)
|
position = Vector2(209, 113)
|
||||||
|
rotation = 2.09219
|
||||||
|
|
||||||
|
[node name="RigidBody2D2" parent="." groups=["pushables"] instance=ExtResource("1_6shkr")]
|
||||||
|
position = Vector2(595, 192)
|
||||||
|
rotation = 4.86807
|
||||||
|
|
||||||
|
[node name="RigidBody2D3" parent="." groups=["pushables"] instance=ExtResource("1_6shkr")]
|
||||||
|
position = Vector2(373, 200)
|
||||||
|
rotation = -0.0982481
|
||||||
|
|
||||||
[connection signal="areaTrigger" from="Area2D" to="." method="_on_trigger"]
|
[connection signal="areaTrigger" from="Area2D" to="." method="_on_trigger"]
|
||||||
[connection signal="body_entered" from="Area2D" to="Area2D" method="_on_body_entered"]
|
[connection signal="body_entered" from="Area2D" to="Area2D" method="_on_body_entered"]
|
||||||
|
27
scenes/player.tscn
Normal file
27
scenes/player.tscn
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
[gd_scene load_steps=3 format=3 uid="uid://b2hyqfqh02ep6"]
|
||||||
|
|
||||||
|
[ext_resource type="Script" path="res://scripts/charController.gd" id="1_4o8do"]
|
||||||
|
|
||||||
|
[sub_resource type="CircleShape2D" id="CircleShape2D_uvblg"]
|
||||||
|
radius = 32.5576
|
||||||
|
|
||||||
|
[node name="CharacterBody2D" type="CharacterBody2D"]
|
||||||
|
script = ExtResource("1_4o8do")
|
||||||
|
PUSH_FORCE = 100
|
||||||
|
metadata/_edit_group_ = true
|
||||||
|
|
||||||
|
[node name="CollisionShape2D" type="CollisionShape2D" parent="."]
|
||||||
|
shape = SubResource("CircleShape2D_uvblg")
|
||||||
|
debug_color = Color(0.872789, 0.000463018, 0.842707, 0.42)
|
||||||
|
|
||||||
|
[node name="RightRay" type="RayCast2D" parent="."]
|
||||||
|
target_position = Vector2(76, 0)
|
||||||
|
|
||||||
|
[node name="LeftRay" type="RayCast2D" parent="."]
|
||||||
|
target_position = Vector2(-76, 0)
|
||||||
|
|
||||||
|
[node name="MarkerRight" type="Node2D" parent="."]
|
||||||
|
position = Vector2(35, -10)
|
||||||
|
|
||||||
|
[node name="MarkerLeft" type="Node2D" parent="."]
|
||||||
|
position = Vector2(-35, -10)
|
14
scripts/bullet.gd
Normal file
14
scripts/bullet.gd
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
extends Area2D
|
||||||
|
|
||||||
|
@export var speed := 700
|
||||||
|
signal hit(bullet, body)
|
||||||
|
|
||||||
|
func set_speed(speedval):
|
||||||
|
speed = speedval
|
||||||
|
|
||||||
|
func _physics_process(delta):
|
||||||
|
position += transform.x * speed * delta
|
||||||
|
|
||||||
|
|
||||||
|
func _on_body_entered(body):
|
||||||
|
print ("Hit a thing") # Replace with function body.
|
@ -3,7 +3,21 @@ extends CharacterBody2D
|
|||||||
|
|
||||||
const SPEED = 500.0
|
const SPEED = 500.0
|
||||||
const JUMP_VELOCITY = -600.0
|
const JUMP_VELOCITY = -600.0
|
||||||
@export var PUSH_FORCE = 90
|
@export var BUMP_FORCE = 90
|
||||||
|
@export var PUSH_FORCE = 700
|
||||||
|
|
||||||
|
|
||||||
|
var faceLeft = false
|
||||||
|
var pushLeftEnabled = false
|
||||||
|
var pushRightEnabled = false
|
||||||
|
var pushTarget
|
||||||
|
|
||||||
|
var bullet = preload("res://scenes/bullet.tscn")
|
||||||
|
|
||||||
|
@onready var right_ray = $RightRay
|
||||||
|
@onready var left_ray = $LeftRay
|
||||||
|
@onready var marker_right = $MarkerRight
|
||||||
|
@onready var marker_left = $MarkerLeft
|
||||||
|
|
||||||
|
|
||||||
func _physics_process(delta: float) -> void:
|
func _physics_process(delta: float) -> void:
|
||||||
@ -15,9 +29,41 @@ func _physics_process(delta: float) -> void:
|
|||||||
if Input.is_action_just_pressed("ui_accept") and is_on_floor():
|
if Input.is_action_just_pressed("ui_accept") and is_on_floor():
|
||||||
velocity.y = JUMP_VELOCITY
|
velocity.y = JUMP_VELOCITY
|
||||||
|
|
||||||
|
if pushTarget:
|
||||||
|
if Input.is_action_just_pressed("Shove") && pushLeftEnabled && faceLeft:
|
||||||
|
print("shove left")
|
||||||
|
pushTarget.apply_central_impulse(Vector2(-1,0) * PUSH_FORCE * 10)
|
||||||
|
pushLeftEnabled = false
|
||||||
|
|
||||||
|
if Input.is_action_just_pressed("Shove") && pushRightEnabled && not faceLeft:
|
||||||
|
print("shove right")
|
||||||
|
pushTarget.apply_central_impulse(Vector2(1,0) * PUSH_FORCE * 15)
|
||||||
|
pushRightEnabled = false
|
||||||
|
|
||||||
|
if Input.is_action_just_pressed("Shoot"):
|
||||||
|
var mybullet = bullet.instantiate()
|
||||||
|
print("I will shoot")
|
||||||
|
if faceLeft:
|
||||||
|
print("shoot left")
|
||||||
|
mybullet.set_speed(-700)
|
||||||
|
mybullet.transform = marker_right.global_transform
|
||||||
|
else:
|
||||||
|
print("shoot right")
|
||||||
|
mybullet.transform = marker_right.global_transform
|
||||||
|
|
||||||
|
owner.add_child(mybullet)
|
||||||
|
|
||||||
# Get the input direction and handle the movement/deceleration.
|
# Get the input direction and handle the movement/deceleration.
|
||||||
# As good practice, you should replace UI actions with custom gameplay actions.
|
# As good practice, you should replace UI actions with custom gameplay actions.
|
||||||
var direction := Input.get_axis("ui_left", "ui_right")
|
var direction := Input.get_axis("ui_left", "ui_right")
|
||||||
|
if direction < 0:
|
||||||
|
faceLeft = true
|
||||||
|
if direction > 0:
|
||||||
|
faceLeft = false
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if direction:
|
if direction:
|
||||||
velocity.x = direction * SPEED
|
velocity.x = direction * SPEED
|
||||||
else:
|
else:
|
||||||
@ -27,4 +73,25 @@ func _physics_process(delta: float) -> void:
|
|||||||
for i in (get_slide_collision_count()):
|
for i in (get_slide_collision_count()):
|
||||||
var c = get_slide_collision(i)
|
var c = get_slide_collision(i)
|
||||||
if c.get_collider() is RigidBody2D:
|
if c.get_collider() is RigidBody2D:
|
||||||
c.get_collider().apply_central_impulse(-c.get_normal()*PUSH_FORCE)
|
c.get_collider().apply_central_impulse(-c.get_normal()*BUMP_FORCE)
|
||||||
|
|
||||||
|
pushTarget = false
|
||||||
|
if left_ray.is_colliding():
|
||||||
|
print("Left ray collision")
|
||||||
|
var collider = left_ray.get_collider()
|
||||||
|
if collider is Node:
|
||||||
|
if collider.is_in_group("pushables"):
|
||||||
|
pushLeftEnabled = true
|
||||||
|
pushTarget = collider
|
||||||
|
else:
|
||||||
|
pushLeftEnabled = false
|
||||||
|
|
||||||
|
if right_ray.is_colliding():
|
||||||
|
print("Right ray collision")
|
||||||
|
var collider = right_ray.get_collider()
|
||||||
|
if collider is Node:
|
||||||
|
if collider.is_in_group("pushables"):
|
||||||
|
pushRightEnabled = true
|
||||||
|
pushTarget = collider
|
||||||
|
else:
|
||||||
|
pushRightEnabled = false
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
extends Node2D
|
extends Node2D
|
||||||
|
|
||||||
var boxTotal = 4
|
var boxTotal = 3
|
||||||
var timer:= Timer.new()
|
var timer:= Timer.new()
|
||||||
@export var secondCount= 15
|
@export var secondCount= 15
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user