From 69ce9ebaeca345f4933b91c75879bf6adce33997 Mon Sep 17 00:00:00 2001 From: Alexander Hartmann Date: Tue, 19 Sep 2023 01:21:09 +0200 Subject: [PATCH] 'Navigation Polygon 2D' ported to Godot 4.1.1 --- 2d/navigation/README.md | 11 +++--- 2d/navigation/character.png.import | 2 +- 2d/navigation/character_navigation.gd | 27 +++++++++++++ 2d/navigation/level.tscn | 32 ---------------- 2d/navigation/map.png.import | 2 +- 2d/navigation/navigation.gd | 53 ++++---------------------- 2d/navigation/navigation.tscn | 37 ++++++++++++++++++ 2d/navigation/navigation_polygon.res | Bin 0 -> 1540 bytes 2d/navigation/project.godot | 8 ++-- 9 files changed, 82 insertions(+), 90 deletions(-) create mode 100644 2d/navigation/character_navigation.gd delete mode 100644 2d/navigation/level.tscn create mode 100644 2d/navigation/navigation.tscn create mode 100644 2d/navigation/navigation_polygon.res diff --git a/2d/navigation/README.md b/2d/navigation/README.md index 5020793917b..a06acdbc990 100644 --- a/2d/navigation/README.md +++ b/2d/navigation/README.md @@ -1,14 +1,13 @@ # Navigation Polygon 2D -Example of using 2D navigation using a -[`NavigationPolygon`](https://docs.godotengine.org/en/latest/classes/class_navigationpolygon.html) -in a [`NavigationPolygonInstance`](https://docs.godotengine.org/en/latest/classes/class_navigationpolygoninstance.html) node. -It uses the 2D navigation API to request a path between two points, -and then traverses the resulting path. +Example of using 2D navigation using: +- [`NavigationRegion2D`](https://docs.godotengine.org/en/latest/classes/class_navigationregion2d.html) +- [`NavigationPolygon`](https://docs.godotengine.org/en/latest/classes/class_navigationpolygon.html) +- [`NavigationAgent2D`](https://docs.godotengine.org/en/latest/classes/class_navigationagent2d.html) Language: GDScript -Renderer: GLES 2 +Renderer: Forward+ Check out this demo on the asset library: https://godotengine.org/asset-library/asset/117 diff --git a/2d/navigation/character.png.import b/2d/navigation/character.png.import index 73275cc31f6..c2f105fc58f 100644 --- a/2d/navigation/character.png.import +++ b/2d/navigation/character.png.import @@ -16,9 +16,9 @@ dest_files=["res://.godot/imported/character.png-7a996d3b758d22c506b76a7c1539128 [params] compress/mode=0 +compress/high_quality=false compress/lossy_quality=0.7 compress/hdr_compression=1 -compress/bptc_ldr=0 compress/normal_map=0 compress/channel_pack=0 mipmaps/generate=false diff --git a/2d/navigation/character_navigation.gd b/2d/navigation/character_navigation.gd new file mode 100644 index 00000000000..7e8d8912e91 --- /dev/null +++ b/2d/navigation/character_navigation.gd @@ -0,0 +1,27 @@ +extends CharacterBody2D + + +var movement_speed: float = 200.0 +@onready var navigation_agent: NavigationAgent2D = $NavigationAgent2D + + +func _ready(): + # These values need to be adjusted for the actor's speed + # and the navigation layout. + navigation_agent.path_desired_distance = 2.0 + navigation_agent.target_desired_distance = 2.0 + + +func set_movement_target(movement_target: Vector2): + navigation_agent.target_position = movement_target + + +func _physics_process(_delta): + if navigation_agent.is_navigation_finished(): + return + + var current_agent_position: Vector2 = global_position + var next_path_position: Vector2 = navigation_agent.get_next_path_position() + + velocity = current_agent_position.direction_to(next_path_position) * movement_speed + move_and_slide() diff --git a/2d/navigation/level.tscn b/2d/navigation/level.tscn deleted file mode 100644 index 71d98eaac33..00000000000 --- a/2d/navigation/level.tscn +++ /dev/null @@ -1,32 +0,0 @@ -[gd_scene load_steps=5 format=3 uid="uid://cur17tkfqetf0"] - -[ext_resource type="Script" path="res://navigation.gd" id="1"] -[ext_resource type="Texture2D" uid="uid://bk26gi6qsuh18" path="res://map.png" id="2"] -[ext_resource type="Texture2D" uid="uid://b0wokaenwu7pj" path="res://character.png" id="3"] - -[sub_resource type="NavigationPolygon" id="NavigationPolygon_5ynhe"] -vertices = PackedVector2Array(682, 496, 696, 300, 704, 507, 495, 256, 589, 270, 540, 284, 466, 177, 490, 169, 531, 178, 477, 205, 446, 196, 621, 510, 667, 525, 606, 519, 529, 290, 288, 228, 228, 180, 276, 160, 315, 190, 600, 497, 576, 503, 202, 99, 314, 65, 311, 83, 436, 170, 452, 163, 201, 440, 246, 478, 223, 490, 211, 485, 146, 400, 185, 381, 586, 178, 596, 188, 474, 252, 462, 127, 479, 150, 416, 180, 395, 516, 302, 499, 320, 450, 354, 445, 535, 516, 538, 106, 537, 173, 493, 166, 506, 97, 514, 51, 486, 83, 327, 77, 309, 96, 306, 113, 272, 153, 219, 172, 178, 152, 148, 224, 189, 231, 171, 328, 176, 347, 259, 404, 432, 249, 365, 346, 525, 342, 314, 340, 271, 336, 241, 321, 235, 284, 242, 247, 324, 336, 616, 360, 645, 381, 645, 404, 614, 492) -polygons = [PackedInt32Array(0, 1, 2), PackedInt32Array(3, 4, 5), PackedInt32Array(6, 7, 8, 9, 10), PackedInt32Array(11, 0, 2, 12, 13), PackedInt32Array(3, 5, 14), PackedInt32Array(15, 16, 17, 18), PackedInt32Array(19, 11, 13, 20), PackedInt32Array(21, 22, 23), PackedInt32Array(6, 10, 24, 25), PackedInt32Array(26, 27, 28, 29, 30), PackedInt32Array(31, 26, 30), PackedInt32Array(32, 33, 3, 34), PackedInt32Array(18, 35, 36, 25, 24), PackedInt32Array(18, 24, 37), PackedInt32Array(38, 39, 40, 41, 42), PackedInt32Array(43, 44, 45, 46), PackedInt32Array(47, 43, 46, 48), PackedInt32Array(49, 47, 48, 50, 23), PackedInt32Array(21, 23, 50, 51, 52, 53, 54), PackedInt32Array(55, 54, 53, 56), PackedInt32Array(30, 55, 56, 57), PackedInt32Array(30, 57, 58), PackedInt32Array(31, 30, 58), PackedInt32Array(31, 58, 59, 40), PackedInt32Array(40, 59, 41), PackedInt32Array(18, 37, 60, 15), PackedInt32Array(20, 42, 41, 61, 60, 34, 3, 62), PackedInt32Array(63, 64, 65, 66, 67, 15, 60, 68), PackedInt32Array(61, 68, 60), PackedInt32Array(62, 69, 70, 71, 72, 19, 20), PackedInt32Array(62, 3, 14)] -outlines = [PackedVector2Array(314, 65, 311, 83, 327, 77, 514, 51, 538, 106, 537, 173, 493, 166, 506, 97, 486, 83, 309, 96, 306, 113, 272, 153, 219, 172, 189, 231, 171, 328, 176, 347, 259, 404, 354, 445, 365, 346, 324, 336, 314, 340, 271, 336, 241, 321, 235, 284, 242, 247, 288, 228, 228, 180, 276, 160, 315, 190, 462, 127, 479, 150, 452, 163, 466, 177, 490, 169, 531, 178, 477, 205, 446, 196, 436, 170, 416, 180, 432, 249, 474, 252, 586, 178, 596, 188, 495, 256, 589, 270, 540, 284, 529, 290, 525, 342, 616, 360, 645, 381, 645, 404, 614, 492, 600, 497, 621, 510, 682, 496, 696, 300, 704, 507, 667, 525, 606, 519, 576, 503, 535, 516, 395, 516, 302, 499, 320, 450, 185, 381, 201, 440, 246, 478, 223, 490, 211, 485, 146, 400, 148, 224, 178, 152, 202, 99)] - -[node name="Node2D" type="Node2D"] -script = ExtResource("1") - -[node name="Map" type="Sprite2D" parent="."] -position = Vector2(429.585, 287.32) -texture = ExtResource("2") - -[node name="Camera2D" type="Camera2D" parent="."] -offset = Vector2(420, 300) -current = true - -[node name="Character" type="Sprite2D" parent="."] -position = Vector2(228.464, 132.594) -scale = Vector2(0.5, 0.5) -texture = ExtResource("3") -offset = Vector2(0, -26) - -[node name="NavigationRegion2d" type="NavigationRegion2D" parent="."] -navpoly = SubResource("NavigationPolygon_5ynhe") - -[node name="NavigationAgent2d" type="NavigationAgent2D" parent="."] diff --git a/2d/navigation/map.png.import b/2d/navigation/map.png.import index b57f7a38ef2..c38ee705740 100644 --- a/2d/navigation/map.png.import +++ b/2d/navigation/map.png.import @@ -16,9 +16,9 @@ dest_files=["res://.godot/imported/map.png-9eea34967fae34f4388f4a32a16da936.ctex [params] compress/mode=0 +compress/high_quality=false compress/lossy_quality=0.7 compress/hdr_compression=1 -compress/bptc_ldr=0 compress/normal_map=0 compress/channel_pack=0 mipmaps/generate=false diff --git a/2d/navigation/navigation.gd b/2d/navigation/navigation.gd index bf00912f2b3..0077f3e086f 100644 --- a/2d/navigation/navigation.gd +++ b/2d/navigation/navigation.gd @@ -1,22 +1,6 @@ extends Node2D -@export var character_speed: float = 400.0 -var path = [] - -@onready var character = $Character - -#var navmap = NavigationServer2D.map_create() - - -func _ready(): - pass - #NavigationServer2D.region_set_map(navmap, $NavigationRegion2d.get_rid()) - - -func _process(delta): - character.position = $NavigationAgent2d.get_next_location() - var walk_distance = character_speed * delta - #move_along_path(walk_distance) +var drawpos = Vector2() # The "click" event is a custom input action defined in @@ -24,37 +8,14 @@ func _process(delta): func _unhandled_input(event): if not event.is_action_pressed("click"): return - _update_navigation_path(Vector2(), get_local_mouse_position()) + navigate_to(get_local_mouse_position()) -#func move_along_path(distance): -# return -# var last_point = character.position -# while path.size(): -# var distance_between_points = last_point.distance_to(path[0]) -# # The position to move to falls between two points. -# if distance <= distance_between_points: -# character.position = last_point.lerp(path[0], distance / distance_between_points) -# return -# # The position is past the end of the segment. -# distance -= distance_between_points -# last_point = path[0] -# path.remove(0) -# # The character reached the end of the path. -# character.position = last_point -# set_process(false) -var drawpos = Vector2() -func _update_navigation_path(start_position, end_position): - # get_simple_path is part of the Node2D class. - # It returns a PackedVector2Array of points that lead you - # from the start_position to the end_position. - $NavigationAgent2d.set_target_location(end_position) - drawpos = end_position +func navigate_to(pos): + $Character/NavigationAgent2D.target_position = pos + drawpos = pos queue_redraw() - # The first point is always the start_position. - # We don't need it in this example as it corresponds to the character's position. - #path.remove(0) - #set_process(true) + func _draw(): - draw_circle(drawpos, 10, Color.RED) + draw_circle(drawpos, 5, Color.RED) diff --git a/2d/navigation/navigation.tscn b/2d/navigation/navigation.tscn new file mode 100644 index 00000000000..67ee2527737 --- /dev/null +++ b/2d/navigation/navigation.tscn @@ -0,0 +1,37 @@ +[gd_scene load_steps=7 format=3 uid="uid://bjgad00c2xiuc"] + +[ext_resource type="Script" path="res://navigation.gd" id="1_j3vjp"] +[ext_resource type="Texture2D" uid="uid://bk26gi6qsuh18" path="res://map.png" id="2_nxfkp"] +[ext_resource type="NavigationPolygon" uid="uid://bk5r48dcijlqt" path="res://navigation_polygon.res" id="3_6c0vu"] +[ext_resource type="Script" path="res://character_navigation.gd" id="3_abq88"] +[ext_resource type="Texture2D" uid="uid://b0wokaenwu7pj" path="res://character.png" id="4_55b5j"] + +[sub_resource type="CapsuleShape2D" id="CapsuleShape2D_7hahy"] +radius = 7.0 +height = 22.0 + +[node name="Navigation" type="Node2D"] +script = ExtResource("1_j3vjp") + +[node name="Map" type="Sprite2D" parent="."] +z_index = -1 +position = Vector2(400, 302) +texture = ExtResource("2_nxfkp") + +[node name="NavigationRegion2D" type="NavigationRegion2D" parent="."] +navigation_polygon = ExtResource("3_6c0vu") + +[node name="Character" type="CharacterBody2D" parent="."] +position = Vector2(210, 138) +script = ExtResource("3_abq88") + +[node name="Sprite2D" type="Sprite2D" parent="Character"] +position = Vector2(0, -3) +scale = Vector2(0.3, 0.3) +texture = ExtResource("4_55b5j") + +[node name="CollisionShape2D" type="CollisionShape2D" parent="Character"] +position = Vector2(0, -3) +shape = SubResource("CapsuleShape2D_7hahy") + +[node name="NavigationAgent2D" type="NavigationAgent2D" parent="Character"] diff --git a/2d/navigation/navigation_polygon.res b/2d/navigation/navigation_polygon.res new file mode 100644 index 0000000000000000000000000000000000000000..e42fd471a39ca7028e895c66f2bc6af63120a059 GIT binary patch literal 1540 zcmV+f2K)I^Q$s@n000005C8yw4gdh`1pojjwJ-f(e+?Bc0GdU>3omfAq&d*Gig(k| z2KEuJ!cAg}Nu~y<*5nIU`_pY9wsk=?Edva}jWhrfNGJppDZ&7&0IdKYrfaskHCR7f z*WUbGb!(u0t-3GIPfhnB>OMN%ho}2wbzhzCd-b!^eYAdex(`?P$?0+mZeN>Us_tv_ zQ}lz>eUW~Mew3b{AERHPX+Gis7&Nn$vG5ve(E`VYGcjRhU}m;7VP;-pVm7cRXl5G= z6FVbACdSML7Is!;%xq=1a0637iex71 z2^2yXaEz=A8Zj~@V`O1xUtPk=d?9&+6F7hmINe98`)I#g_a*ts`HlFE`Z@S{>ONbm zx}1aVd-3DceKo!&KTX|72e-!ADiwA^^4O55FXsY8=S#{ zD@btQ0s}mJ#yKqbiTT8?0r@%VBw4Cyn)5*8Hgs!)YH+%>HggHCRpK(xz82lbWsbt_ zoAZ0}^_VMh`%>WfA#w6c^gHYNsru3R)ym}tbYHD52cY}&)AQ@peO`WjxKpdHF&pvuUP$H zb)TN@o7H`#0*^@(CI|4^;OSaW%0ZGDzf=ksHAr#e2sCHR4Ea!|3>gAS27obp*~eVW z$sXon2lM4&Uf$(gZd6)BG5CvKv|Nr-regZPK8 z4jM8X!!J~z@Cldju7P8y!8H*f5fKp?NeWU(2T=rsAsGmva}N>#wjfhf#7WSCvQkj1 zMr#M$S)hUP=4q|tJd>>h%cnQlU~7T;{{Dp(W+jYpoM6EWg%OSuEUrZu(b2Vnu_te9 zPDUq<>ReKXV=m6k7(JSUJ61O)EX+GRaVpOOJNt8A-)4K|u@ybaYjbU;rmtY#Ky6lX zMjhWx;Bd;>V3y;;c$AHOVnfB1m>W6T?39ylGB`SfeGomPFh1b8tYQNG0B)ZDG=4Fi z@_HnjIKqym*236{!0FX^du9%=ET_I0!E_E`=kK~@YcA~^7HlmpU5dsT)s~0M+FyG- z8zXr}&{Z?g%%-)|gC9qB0v@8Q(M$a3o$KfQAV0UEbujE9*{hF9=7ZajqE&;oU)got654)nQ=L{ujDG9ro8RL ziBm)w#BA5G&^TV8u08{B1@meG-M>pvCH)CHi~x6b0KO<)|BCNq`LJZz28Bt_3I1Rd z_X`+&@xvgBnxFQ9{ED2tIg~`0xJ(DxH)_61UWI&D-e>A-5Gy?J*(D$A8g*DpR{