This commit is contained in:
karl 2019-11-23 15:55:37 +01:00
commit ae3a1a6e29
9 changed files with 97 additions and 36 deletions

File diff suppressed because one or more lines are too long

View File

@ -2,12 +2,12 @@
[ext_resource path="res://Player/Player.tscn" type="PackedScene" id=1]
[sub_resource type="NavigationMesh" id=1]
[sub_resource type="NavigationMesh" id=3]
[sub_resource type="BoxShape" id=2]
extents = Vector3( 10, 1, 10 )
[sub_resource type="PlaneMesh" id=3]
[sub_resource type="PlaneMesh" id=4]
size = Vector2( 20, 20 )
[node name="Level" type="Spatial"]
@ -18,7 +18,7 @@ size = Vector2( 20, 20 )
editor/display_folded = true
[node name="NavigationMeshInstance" type="NavigationMeshInstance" parent="Navigation"]
navmesh = SubResource( 1 )
navmesh = SubResource( 3 )
[node name="StaticBody" type="StaticBody" parent="Navigation/NavigationMeshInstance"]
@ -27,6 +27,6 @@ transform = Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, -1, 0 )
shape = SubResource( 2 )
[node name="MeshInstance" type="MeshInstance" parent="Navigation/NavigationMeshInstance"]
mesh = SubResource( 3 )
mesh = SubResource( 4 )
skeleton = NodePath("")
material/0 = null

View File

@ -0,0 +1,5 @@
extends Spatial
func _ready():
Collector.addCollectible(self)

View File

@ -0,0 +1,20 @@
[gd_scene load_steps=4 format=2]
[ext_resource path="res://Level/Objects/Crystal.gd" type="Script" id=1]
[sub_resource type="CapsuleShape" id=2]
[sub_resource type="CapsuleMesh" id=1]
[node name="Crystal" type="Spatial"]
transform = Transform( 1, 0, 0, 0, -4.37114e-008, -1, 0, 1, -4.37114e-008, 0, 2, 0 )
script = ExtResource( 1 )
[node name="CrystalBody" type="StaticBody" parent="."]
[node name="CollisionShape" type="CollisionShape" parent="CrystalBody"]
shape = SubResource( 2 )
[node name="MeshInstance" type="MeshInstance" parent="CrystalBody"]
mesh = SubResource( 1 )
material/0 = null

View File

@ -2,10 +2,9 @@ extends KinematicBody
# export variables
export(NodePath) var body_nodepath
#export(NodePath) var lookingAt_nodepath
export(NodePath) var camera_nodepath
export(NodePath) var animation_nodepath
export(NodePath) var ui_nodepath
export(NodePath) var camera_nodepath
# const
const GRAVITY = -24.8
@ -20,7 +19,6 @@ const INTERACT_DISTANCE = 4
# private members
var _body: Spatial
var _camera: Camera
#var _lookCast: RayCast
var _animation: AnimationPlayer
var _interface: Control
var _dir = Vector3();
@ -39,23 +37,24 @@ func _ready():
_animation = get_node(animation_nodepath) as AnimationPlayer
assert(null != _animation)
# Setup mouse look
Input.set_mouse_mode(Input.MOUSE_MODE_CAPTURED)
#_lookCast = get_node(lookingAt_nodepath) as RayCast
#_lookCast.cast_to = Vector3(0, 0, INTERACT_DISTANCE)
_interface = get_node(ui_nodepath) as Control
assert(null != _interface)
# Setup mouse look
Input.set_mouse_mode(Input.MOUSE_MODE_CAPTURED)
func _physics_process(delta):
process_input()
process_movement(delta)
_process_input()
_process_movement(delta)
_process_collision()
func _process(_delta):
process_animations()
_process_animations()
func process_input():
func _process_input():
# Walking
var input_movement_vector = Vector2()
if Input.is_action_pressed("move_fwrd"):
@ -81,7 +80,7 @@ func process_input():
_is_sprinting = Input.is_action_pressed("move_sprint")
func process_movement(delta):
func _process_movement(delta):
_vel.y += delta * GRAVITY
# set movement speed
@ -94,10 +93,24 @@ func process_movement(delta):
_vel = move_and_slide(_vel, Vector3(0, 1, 0), 0.05, 4, deg2rad(MAX_SLOPE_ANGLE))
func process_animations():
func _process_animations():
_animation.playback_speed = _vel.length() / MOVE_SPEED
func _process_collision():
var collCount = get_slide_count()
if collCount > 0:
#Logger.debug("Collide count: ", collCount)
for i in collCount:
var collision = get_slide_collision(i)
#Logger.debug("Collided with: ", collision.collider.name)
#TODO: replace with groups
if collision.collider.name == "CrystalBody":
#Logger.debug("removing crystal...")
collision.collider.queue_free()
_interface.increaseScore()
func _input(event):
# capture mouse movement
if event is InputEventMouseMotion:

View File

@ -42,12 +42,12 @@ tracks/1/keys = {
} ]
}
[node name="Spatial" type="KinematicBody"]
[node name="Player" type="KinematicBody"]
script = ExtResource( 1 )
body_nodepath = NodePath("Body")
camera_nodepath = NodePath("Camera")
animation_nodepath = NodePath("WalkAnimationPlayer")
ui_nodepath = NodePath("HUD")
camera_nodepath = NodePath("Camera")
[node name="Body" type="Spatial" parent="."]
@ -73,6 +73,7 @@ pitch_scale = 1.5
[node name="HUD" parent="." instance=ExtResource( 4 )]
script = ExtResource( 5 )
label_nodepath = NodePath("LabelScore")
[node name="LabelScore" type="Label" parent="HUD"]
margin_left = 15.0

View File

@ -1,13 +1,21 @@
extends Control
# Declare member variables here. Examples:
# var a = 2
# var b = "text"
export(NodePath) var label_nodepath
const SCORE = 100
var _labelScore: Label
var _score: int = 0
# Called when the node enters the scene tree for the first time.
func _ready():
pass # Replace with function body.
_labelScore = get_node(label_nodepath) as Label
assert(null != _labelScore)
# Called every frame. 'delta' is the elapsed time since the previous frame.
#func _process(delta):
# pass
func increaseScore():
_score += SCORE
_labelScore.text = "Score: " + String(_score)
if (_score / SCORE == Collector.getCount()):
Logger.info("YOU WON!")

13
WikiJam/Util/Collector.gd Normal file
View File

@ -0,0 +1,13 @@
extends Node
var _collectibles: Array
func addCollectible (coll):
Logger.info("appending new collectible: " + String(coll.get_instance_id()))
Logger.info("current collection count: " + String(Collector.getCount()))
_collectibles.append(coll)
func getCount ():
return _collectibles.size()

View File

@ -63,6 +63,7 @@ config/icon="res://icon.png"
[autoload]
Logger="*res://Util/gs_logger/logger.gd"
Collector="*res://Util/Collector.gd"
[input]