From 74d237648515ae949e79b03e3197b3ed9f446d30 Mon Sep 17 00:00:00 2001 From: ruinthread-games <73795962+ruinthread-games@users.noreply.github.com> Date: Sat, 15 Jun 2024 16:17:55 +0200 Subject: [PATCH] Worked on test for moving platforms --- 3d_platforma/Level1_platforms_medium.tscn | 91 +++++++++++++++++++++++ 3d_platforma/Level1_platforms_slow.tscn | 34 ++++----- 3d_platforma/Player.tscn | 36 ++++++++- BlenderFiles/Level.tscn | 4 +- Obstacles/SwingingAxe.tscn | 2 +- 5 files changed, 144 insertions(+), 23 deletions(-) create mode 100644 3d_platforma/Level1_platforms_medium.tscn diff --git a/3d_platforma/Level1_platforms_medium.tscn b/3d_platforma/Level1_platforms_medium.tscn new file mode 100644 index 0000000..ca0fcbf --- /dev/null +++ b/3d_platforma/Level1_platforms_medium.tscn @@ -0,0 +1,91 @@ +[gd_scene load_steps=7 format=2] + +[ext_resource path="res://3d_platforma/Player.tscn" type="PackedScene" id=1] +[ext_resource path="res://Obstacles/SwingingAxe.tscn" type="PackedScene" id=2] + +[sub_resource type="Animation" id=1] +length = 0.001 +tracks/0/type = "value" +tracks/0/path = NodePath("KinematicBody:translation") +tracks/0/interp = 1 +tracks/0/loop_wrap = true +tracks/0/imported = false +tracks/0/enabled = true +tracks/0/keys = { +"times": PoolRealArray( 0 ), +"transitions": PoolRealArray( 1 ), +"update": 0, +"values": [ Vector3( 0, 0, 0 ) ] +} + +[sub_resource type="Animation" id=2] +resource_name = "platform" +length = 6.0 +loop = true +tracks/0/type = "value" +tracks/0/path = NodePath("KinematicBody:translation") +tracks/0/interp = 1 +tracks/0/loop_wrap = true +tracks/0/imported = false +tracks/0/enabled = true +tracks/0/keys = { +"times": PoolRealArray( 0, 3.1, 6 ), +"transitions": PoolRealArray( 1, 1, 1 ), +"update": 0, +"values": [ Vector3( 0, 0, 0 ), Vector3( 7.22974, 0, 0 ), Vector3( 0, 0, 0 ) ] +} + +[sub_resource type="CubeMesh" id=3] +size = Vector3( 4, 1, 10 ) + +[sub_resource type="ConcavePolygonShape" id=4] +data = PoolVector3Array( -2, 0.5, 5, 2, 0.5, 5, -2, -0.5, 5, 2, 0.5, 5, 2, -0.5, 5, -2, -0.5, 5, 2, 0.5, -5, -2, 0.5, -5, 2, -0.5, -5, -2, 0.5, -5, -2, -0.5, -5, 2, -0.5, -5, 2, 0.5, 5, 2, 0.5, -5, 2, -0.5, 5, 2, 0.5, -5, 2, -0.5, -5, 2, -0.5, 5, -2, 0.5, -5, -2, 0.5, 5, -2, -0.5, -5, -2, 0.5, 5, -2, -0.5, 5, -2, -0.5, -5, 2, 0.5, 5, -2, 0.5, 5, 2, 0.5, -5, -2, 0.5, 5, -2, 0.5, -5, 2, 0.5, -5, -2, -0.5, 5, 2, -0.5, 5, -2, -0.5, -5, 2, -0.5, 5, 2, -0.5, -5, -2, -0.5, -5 ) + +[node name="Spatial" type="Spatial"] + +[node name="CSGBox" type="CSGBox" parent="."] +transform = Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0.739994, 1.55076 ) +use_collision = true +width = 3.33378 +height = 0.276134 +depth = 7.4378 + +[node name="CSGBox2" type="CSGBox" parent="."] +transform = Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 2.63172, -13.8239 ) +use_collision = true +width = 3.33378 +height = 0.276134 +depth = 4.96652 + +[node name="CSGBox3" type="CSGBox" parent="."] +transform = Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, -2.65108, 3.45298, -9.43625 ) +use_collision = true +width = 0.261805 +height = 4.06841 +depth = 9.32074 + +[node name="MovingPlatforms" type="Spatial" parent="."] + +[node name="Player" parent="MovingPlatforms" instance=ExtResource( 1 )] +transform = Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 1.15484, 2 ) + +[node name="SwingingAxe" parent="MovingPlatforms" instance=ExtResource( 2 )] +transform = Transform( 0.50747, -0.861669, 0, 0.861669, 0.50747, 0, 0, 0, 1, 6.52953, 7.68018, -9.53236 ) + +[node name="Spatial" type="Spatial" parent="MovingPlatforms"] +transform = Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, -0.89305, 0.826549 ) + +[node name="AnimationPlayer" type="AnimationPlayer" parent="MovingPlatforms"] +autoplay = "platform" +anims/RESET = SubResource( 1 ) +anims/platform = SubResource( 2 ) + +[node name="KinematicBody" type="KinematicBody" parent="MovingPlatforms"] + +[node name="MeshInstance" type="MeshInstance" parent="MovingPlatforms/KinematicBody"] +transform = Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, -7.21818 ) +mesh = SubResource( 3 ) + +[node name="CollisionShape" type="CollisionShape" parent="MovingPlatforms/KinematicBody"] +transform = Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, -7.21818 ) +shape = SubResource( 4 ) diff --git a/3d_platforma/Level1_platforms_slow.tscn b/3d_platforma/Level1_platforms_slow.tscn index d5cc4ea..45e7255 100644 --- a/3d_platforma/Level1_platforms_slow.tscn +++ b/3d_platforma/Level1_platforms_slow.tscn @@ -3,14 +3,14 @@ [ext_resource path="res://3d_platforma/texture_08.png" type="Texture" id=1] [ext_resource path="res://3d_platforma/sqare_norm.png" type="Texture" id=2] -[sub_resource type="SpatialMaterial" id=36] +[sub_resource type="SpatialMaterial" id=1] resource_name = "CheckerGrid" albedo_color = Color( 0.85, 0.85, 0.85, 1 ) albedo_texture = ExtResource( 1 ) roughness = 0.85 uv1_triplanar = true -[sub_resource type="Animation" id=37] +[sub_resource type="Animation" id=2] resource_name = "move" length = 30.0 loop = true @@ -27,24 +27,24 @@ tracks/0/keys = { "values": [ 0.0, 10.0, 0.0 ] } -[sub_resource type="BoxShape" id=20] +[sub_resource type="BoxShape" id=3] -[sub_resource type="CubeMesh" id=21] +[sub_resource type="CubeMesh" id=4] -[sub_resource type="OpenSimplexNoise" id=28] +[sub_resource type="OpenSimplexNoise" id=5] octaves = 2 period = 0.8 -[sub_resource type="NoiseTexture" id=29] +[sub_resource type="NoiseTexture" id=6] flags = 3 width = 32 height = 32 -noise = SubResource( 28 ) +noise = SubResource( 5 ) -[sub_resource type="SpatialMaterial" id=22] +[sub_resource type="SpatialMaterial" id=7] albedo_color = Color( 0.603922, 0.0235294, 0.619608, 1 ) roughness = 0.25 -roughness_texture = SubResource( 29 ) +roughness_texture = SubResource( 6 ) normal_enabled = true normal_scale = 1.0 normal_texture = ExtResource( 2 ) @@ -60,7 +60,7 @@ use_collision = true width = 4.0 height = 0.2 depth = 10.0 -material = SubResource( 36 ) +material = SubResource( 1 ) [node name="ramp" type="CSGBox" parent="."] transform = Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, -0.4, -22 ) @@ -68,7 +68,7 @@ use_collision = true width = 4.0 height = 1.0 depth = 10.0 -material = SubResource( 36 ) +material = SubResource( 1 ) [node name="lift" type="Spatial" parent="."] transform = Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, 0, -0.4, -30 ) @@ -78,11 +78,11 @@ use_collision = true width = 4.0 height = 1.0 depth = 4.0 -material = SubResource( 36 ) +material = SubResource( 1 ) [node name="AnimationPlayer" type="AnimationPlayer" parent="lift/platform"] autoplay = "move" -anims/move = SubResource( 37 ) +anims/move = SubResource( 2 ) [node name="lego" type="StaticBody" parent="."] transform = Transform( 1, 0, 0, 0, 1, 0, 0, 0, 1, -5, -1.9, -8 ) @@ -91,11 +91,11 @@ __meta__ = { } [node name="CollisionShape" type="CollisionShape" parent="lego"] -shape = SubResource( 20 ) +shape = SubResource( 3 ) [node name="MeshInstance" type="MeshInstance" parent="lego"] -mesh = SubResource( 21 ) -material/0 = SubResource( 22 ) +mesh = SubResource( 4 ) +material/0 = SubResource( 7 ) [node name="CSGPolygon" type="CSGPolygon" parent="."] transform = Transform( 1, 0, 0, 0, -4.37114e-08, -1, 0, 1, -4.37114e-08, 0, 1, -12 ) @@ -104,4 +104,4 @@ polygon = PoolVector2Array( 3, -4, 3, 1, 4.15364, 1.29316, 4, -4 ) mode = 1 spin_degrees = 360.0 spin_sides = 16 -material = SubResource( 36 ) +material = SubResource( 1 ) diff --git a/3d_platforma/Player.tscn b/3d_platforma/Player.tscn index 6cdb9e9..21223e9 100644 --- a/3d_platforma/Player.tscn +++ b/3d_platforma/Player.tscn @@ -25,10 +25,12 @@ func _input(event): if event is InputEventMouseMotion: rotation_degrees.y -= event.relative.x * look_sens_h + if event.is_action_released(\"ui_cancel\"): + get_tree().quit() if event.is_action_pressed(\"ui_end\"): global_translation = Vector3.ZERO -func _physics_process(_delta): +func _physics_process(delta): var move_vec = Vector3() if Input.is_action_pressed(\"move_forward\"): move_vec.z -= 1 @@ -39,12 +41,33 @@ func _physics_process(_delta): if Input.is_action_pressed(\"move_left\"): move_vec.x -= 1 + $Label.text = 'floor contact: ' + str(is_on_floor()) + str(get_floor_velocity()) + move_vec = move_vec.normalized() move_vec = move_vec.rotated(Vector3(0, 1, 0), rotation.y) move_vec *= move_speed move_vec.y = y_velo - var _vel:Vector3 = move_and_slide(move_vec, Vector3(0, 1, 0)) +# var friction = 0.5 +# move_vec = lerp(Vector3.ZERO, move_vec, friction) +# var _vel:Vector3 = move_and_slide(move_vec, Vector3(0, 1, 0)) +# var _vel:Vector3 = move_and_slide_with_snap(move_vec, Vector3(0, 1, 0)) +# var is_on_platform = platform_detector.is_colliding() + var snap_length = 0.2 + var floor_normal = Vector3.UP + var snap = Vector3.ZERO + if is_on_floor(): + floor_normal = get_floor_normal() + snap = -floor_normal * snap_length + +# move_vec -= gravity * floor_normal * delta + +# var _vel = move_and_slide_with_snap( +# move_vec, snap, Vector3.UP)#, not is_on_floor(), 4, 0.9, false) +# if move_vec.y > 0: + move_vec = move_and_slide(move_vec,Vector3.UP) + + # questionable??? if is_on_floor_prev and not is_on_floor(): @@ -74,6 +97,8 @@ func _physics_process(_delta): play_anim(\"idle\") else: play_anim(\"walk\") + + func play_anim(name): if anim.current_animation == name: @@ -405,3 +430,10 @@ cast_to = Vector3( 0, -50, 0 ) [node name="CoyoteJump" type="Timer" parent="."] wait_time = 0.16 one_shot = true + +[node name="Label" type="Label" parent="."] +margin_left = 178.0 +margin_top = 109.0 +margin_right = 218.0 +margin_bottom = 123.0 +text = "floor contact" diff --git a/BlenderFiles/Level.tscn b/BlenderFiles/Level.tscn index c89a94d..cd93369 100644 --- a/BlenderFiles/Level.tscn +++ b/BlenderFiles/Level.tscn @@ -1,6 +1,5 @@ -[gd_scene load_steps=38 format=2] +[gd_scene load_steps=37 format=2] -[ext_resource path="res://scripts/OnMusicChangedSlowTrigger.gd" type="Script" id=1] [ext_resource path="res://3d_platforma/golden_bay_512.hdr" type="Texture" id=2] [ext_resource path="res://Obstacles/SwingingAxe.tscn" type="PackedScene" id=3] [ext_resource path="res://3d_platforma/sqare_norm.png" type="Texture" id=4] @@ -612,7 +611,6 @@ light_energy = 0.65 environment = SubResource( 24 ) [node name="MusicChangedSlowAction" type="Node" parent="."] -script = ExtResource( 1 ) [node name="Obstacles" type="Spatial" parent="."] diff --git a/Obstacles/SwingingAxe.tscn b/Obstacles/SwingingAxe.tscn index bb1a007..b7bcd18 100644 --- a/Obstacles/SwingingAxe.tscn +++ b/Obstacles/SwingingAxe.tscn @@ -26,7 +26,7 @@ tracks/0/keys = { } [node name="SwingingAxe" type="Spatial"] -transform = Transform( 0.50747, -0.861669, 0, 0.861669, 0.50747, 0, 0, 0, 1, 0, 0, 0 ) +transform = Transform( 0.173648, -0.984807, 0, 0.984807, 0.173648, 0, 0, 0, 1, 0, 0, 0 ) [node name="MeshInstance" type="MeshInstance" parent="."] mesh = ExtResource( 1 )