2024-04-16 22:55:17 +00:00
|
|
|
@icon("res://behaviours/priority.svg")
|
|
|
|
extends Node
|
|
|
|
class_name Priority
|
|
|
|
|
|
|
|
|
2024-04-18 23:22:03 +00:00
|
|
|
## Keeps track of the object's priority for [SamplerPriority] purposes.
|
2024-04-17 02:52:11 +00:00
|
|
|
|
|
|
|
|
2024-04-18 23:22:03 +00:00
|
|
|
## Emitted when the priority is changed.
|
2024-04-17 02:52:11 +00:00
|
|
|
signal priority_changed(new: int, old: int)
|
2024-04-18 23:22:03 +00:00
|
|
|
|
|
|
|
## Emitted when the priority is changed. No args are provided to work around a Godot bug.
|
2024-04-17 02:52:11 +00:00
|
|
|
signal priority_changed_no_args
|
|
|
|
|
|
|
|
|
2024-04-18 23:22:03 +00:00
|
|
|
@export var default_priority: int = 0
|
|
|
|
@export var alternative_priority: int = 1
|
|
|
|
|
|
|
|
var priority: int = 0
|
|
|
|
|
|
|
|
|
|
|
|
## Set [field priority] to [field default_priority].
|
|
|
|
func default() -> void:
|
|
|
|
set_priority(default_priority)
|
2024-04-16 22:55:17 +00:00
|
|
|
|
2024-04-18 23:22:03 +00:00
|
|
|
## Set [field priority] to [field alternative_priority]
|
|
|
|
func alternative() -> void:
|
|
|
|
set_priority(alternative_priority)
|
2024-04-16 22:55:17 +00:00
|
|
|
|
2024-04-18 23:22:03 +00:00
|
|
|
## Toggle [field priority] between [field default_priority] and [field alternative_priority].
|
|
|
|
func toggle_priority() -> void:
|
|
|
|
if priority == default_priority:
|
|
|
|
set_priority(alternative_priority)
|
|
|
|
else:
|
|
|
|
set_priority(default_priority)
|
|
|
|
|
|
|
|
## Set the [field priority] to a specific value.
|
2024-04-17 02:52:11 +00:00
|
|
|
func set_priority(value: int):
|
|
|
|
var old = priority
|
|
|
|
priority = value
|
|
|
|
priority_changed.emit(priority, old)
|
|
|
|
|
2024-04-18 23:22:03 +00:00
|
|
|
## Set the [field priority] to a specific value if the [param variant] is truthy, otherwise set it to a different value.
|
2024-04-17 02:52:11 +00:00
|
|
|
func set_priority_if_truthy(variant: Variant, truthy: int, falsy: int = 0):
|
|
|
|
if variant:
|
|
|
|
set_priority(truthy)
|
|
|
|
else:
|
|
|
|
set_priority(falsy)
|
|
|
|
|
2024-04-18 23:22:03 +00:00
|
|
|
## Get the node to which the [field priority] of this one applies to.
|
2024-04-16 22:55:17 +00:00
|
|
|
func get_ref() -> Node:
|
|
|
|
return get_parent()
|
2024-04-17 02:52:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
func _on_priority_changed(new: int, _old: int) -> void:
|
|
|
|
Log.p(self, "Priority changed to: %s" % new)
|
|
|
|
priority_changed_no_args.emit()
|
2024-04-18 23:22:03 +00:00
|
|
|
|
|
|
|
func _ready() -> void:
|
|
|
|
priority = default_priority
|