mirror of
https://github.com/Relintai/broken_seals_roguelike.git
synced 2025-01-11 23:51:08 +01:00
Mobs will hide their bodies when not visible on screen. Also small tweaks/fixes.
This commit is contained in:
parent
8ce6ce4688
commit
c4a191d166
@ -71,7 +71,7 @@ var casting_anim : bool = false
|
||||
|
||||
var last_mouse_over : Entity = null
|
||||
|
||||
var world : Node2D = null
|
||||
var world : Node = null
|
||||
|
||||
var _controlled : bool = false
|
||||
|
||||
@ -83,10 +83,10 @@ var death_timer : float = 0
|
||||
var entity : Entity
|
||||
var character_skeleton : CharacterSkeleton2D
|
||||
|
||||
var visibility_update_timer : float = 0
|
||||
var visibility_update_timer : float = randi()
|
||||
|
||||
func _enter_tree() -> void:
|
||||
world = get_node(world_path) as Node2D
|
||||
world = get_node(world_path) as Node
|
||||
camera = get_node_or_null("Camera") as Camera2D
|
||||
|
||||
character_skeleton = get_node(character_skeleton_path)
|
||||
@ -113,33 +113,20 @@ func _process(delta : float) -> void:
|
||||
return
|
||||
|
||||
visibility_update_timer = 0
|
||||
|
||||
# var camera : Camera = get_tree().get_root().get_camera() as Camera
|
||||
#
|
||||
# if camera == null:
|
||||
# return
|
||||
#
|
||||
# var cam_pos : Vector3 = camera.global_transform.xform(Vector3())
|
||||
# var dstv : Vector3 = cam_pos - translation
|
||||
# dstv.y = 0
|
||||
# var dst : float = dstv.length_squared()
|
||||
#
|
||||
# if dst > max_visible_distance_squared:
|
||||
# if visible:
|
||||
# hide()
|
||||
# return
|
||||
# else:
|
||||
## var lod_level : int = int(dst / max_visible_distance_squared * 3.0)
|
||||
#
|
||||
# if dst < 400: #20^2
|
||||
# character_skeleton.set_lod_level(0)
|
||||
# elif dst > 400 and dst < 900: #20^2, 30^2
|
||||
# character_skeleton.set_lod_level(1)
|
||||
# else:
|
||||
# character_skeleton.set_lod_level(2)
|
||||
#
|
||||
# if not visible:
|
||||
# show()
|
||||
|
||||
var vpos : Vector2 = -get_tree().root.canvas_transform.get_origin() + (get_tree().root.get_visible_rect().size / 2) - position
|
||||
var l : float = vpos.length_squared()
|
||||
var rs : float = get_tree().root.size.x * get_tree().root.size.x
|
||||
rs *= 0.3
|
||||
|
||||
if l < rs:
|
||||
if not visible:
|
||||
show()
|
||||
set_physics_process(true)
|
||||
else:
|
||||
if visible:
|
||||
hide()
|
||||
set_physics_process(false)
|
||||
|
||||
|
||||
func _physics_process(delta : float) -> void:
|
||||
@ -197,7 +184,7 @@ func process_input(delta: float) -> void:
|
||||
|
||||
if input_length > 0.1:
|
||||
#handle_graphic_facing(abs(dir.dot(Vector2(0, 1))) > 0.9)
|
||||
character_skeleton.update_facing(dir)
|
||||
character_skeleton.update_facing(input_dir)
|
||||
|
||||
character_skeleton.get_animation_tree().set("parameters/walking/blend_amount", input_dir.length())
|
||||
|
||||
@ -427,18 +414,18 @@ func cmouseover(event):
|
||||
|
||||
if last_mouse_over != null and last_mouse_over != mo:
|
||||
if is_instance_valid(last_mouse_over):
|
||||
last_mouse_over.onc_mouse_exit()
|
||||
last_mouse_over.notification_cmouse_exit()
|
||||
|
||||
last_mouse_over = null
|
||||
|
||||
if last_mouse_over == null:
|
||||
mo.onc_mouse_enter()
|
||||
mo.notification_cmouse_enter()
|
||||
last_mouse_over = mo
|
||||
|
||||
return
|
||||
|
||||
if last_mouse_over != null:
|
||||
last_mouse_over.onc_mouse_exit()
|
||||
last_mouse_over.notification_cmouse_exit()
|
||||
last_mouse_over = null
|
||||
|
||||
|
||||
@ -518,4 +505,3 @@ remote func sset_position(pposition : Vector2) -> void:
|
||||
remote func cset_position(pposition : Vector2) -> void:
|
||||
pposition = pposition
|
||||
|
||||
|
||||
|
@ -214,12 +214,12 @@ _global_script_classes=[ {
|
||||
"language": "GDScript",
|
||||
"path": "res://scripts/items/ItemTemplateGD.gd"
|
||||
}, {
|
||||
"base": "ItemVisual",
|
||||
"base": "SkeletonModelEntry",
|
||||
"class": "ItemVisual2D",
|
||||
"language": "GDScript",
|
||||
"path": "res://scripts/item_visuals/ItemVisual2D.gd"
|
||||
}, {
|
||||
"base": "ItemVisualEntry",
|
||||
"base": "SkeletonModelEntry",
|
||||
"class": "ItemVisualEntry2D",
|
||||
"language": "GDScript",
|
||||
"path": "res://scripts/item_visuals/ItemVisualEntry2D.gd"
|
||||
|
@ -1,4 +1,4 @@
|
||||
extends Node2D
|
||||
extends Node
|
||||
|
||||
# Copyright (c) 2019 Péter Magyar
|
||||
#
|
||||
@ -22,6 +22,7 @@ extends Node2D
|
||||
|
||||
export(PackedScene) var world_layer : PackedScene
|
||||
|
||||
export(bool) var spawn_mobs : bool = true
|
||||
export(bool) var editor_generate : bool = false setget set_editor_generate, get_editor_generate
|
||||
export(bool) var show_loading_screen : bool = true
|
||||
export(bool) var generate_on_ready : bool = false
|
||||
@ -56,10 +57,8 @@ func load_character(file_name: String) -> void:
|
||||
|
||||
Server.sset_seed(_player.sseed)
|
||||
|
||||
generate()
|
||||
|
||||
|
||||
|
||||
if spawn_mobs:
|
||||
generate()
|
||||
|
||||
func generate() -> void:
|
||||
for x in range(-5, 5):
|
||||
|
File diff suppressed because one or more lines are too long
@ -1,4 +1,4 @@
|
||||
extends ItemVisual
|
||||
extends SkeletonModelEntry
|
||||
class_name ItemVisual2D
|
||||
|
||||
# Copyright (c) 2019 Péter Magyar
|
||||
@ -21,4 +21,4 @@ class_name ItemVisual2D
|
||||
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
# SOFTWARE.
|
||||
|
||||
export(Array, ItemVisualEntry) var entries : Array
|
||||
export(Array, ModelVisualEntry) var entries : Array
|
||||
|
@ -1,5 +1,5 @@
|
||||
tool
|
||||
extends ItemVisualEntry
|
||||
extends SkeletonModelEntry
|
||||
class_name ItemVisualEntry2D
|
||||
|
||||
# Copyright (c) 2019 Péter Magyar
|
||||
|
Loading…
Reference in New Issue
Block a user