Merge commit '83da4b0f1f490382f9232a380b98546bc6e8e043' into card-board-recovery
This commit is contained in:
commit
21193534b2
|
|
@ -1,9 +1,14 @@
|
|||
@tool
|
||||
|
||||
extends Control
|
||||
extends Area2D
|
||||
class_name Card
|
||||
var compatible_postits: Array[PostIt] = []
|
||||
var own_postits: Array[PostIt] = []
|
||||
var wiggle_pos: float = randf_range(-100, 100)
|
||||
var wiggle_intensity: float = 0
|
||||
var noise: Noise = FastNoiseLite.new()
|
||||
var wiggle_tween
|
||||
var scale_tween
|
||||
|
||||
@export var text: String = "" :
|
||||
set (value):
|
||||
|
|
@ -13,9 +18,39 @@ var own_postits: Array[PostIt] = []
|
|||
$BackgroundSprite.frame = text.hash() % $BackgroundSprite.sprite_frames.get_frame_count($BackgroundSprite.animation)
|
||||
if is_inside_tree():
|
||||
$BackgroundSprite.void_active = value == ""
|
||||
@export var wiggle_strength: float = 0.2
|
||||
@export var wiggle_speed: float = 5
|
||||
@export_range(1, 2) var scale_bump: float = 1.05
|
||||
@export var highlighted: bool = false:
|
||||
set(highlight):
|
||||
if highlight != highlighted:
|
||||
highlighted = highlight
|
||||
|
||||
if is_inside_tree() and is_node_ready():
|
||||
if scale_tween: scale_tween.kill()
|
||||
if wiggle_tween: wiggle_tween.kill()
|
||||
if highlighted:
|
||||
scale_tween = get_tree().create_tween()
|
||||
scale_tween.tween_property(self, "scale", Vector2(scale_bump, scale_bump), 0.1)
|
||||
wiggle_tween = get_tree().create_tween()
|
||||
wiggle_tween.tween_property(self, "wiggle_intensity", 1, 0.2)
|
||||
else:
|
||||
scale_tween = get_tree().create_tween()
|
||||
scale_tween.tween_property(self, "scale", Vector2(1, 1), 0.3)
|
||||
wiggle_tween = get_tree().create_tween()
|
||||
wiggle_tween.tween_property(self, "wiggle_intensity", 0, 0.5)
|
||||
else:
|
||||
if highlighted:
|
||||
scale = Vector2(scale_bump, scale_bump)
|
||||
wiggle_intensity = 1
|
||||
else:
|
||||
scale = Vector2(1,1)
|
||||
wiggle_intensity = 0
|
||||
|
||||
@export var voice_line: AudioStream = null
|
||||
|
||||
func _ready():
|
||||
_handle_wiggle(0)
|
||||
if not Engine.is_editor_hint() and is_inside_tree():
|
||||
for postit in self.get_children():
|
||||
if postit is PostIt: self.own_postits.append(postit as PostIt)
|
||||
|
|
@ -33,7 +68,14 @@ func _ready():
|
|||
$Label.text = self.text
|
||||
|
||||
func _process(delta: float) -> void:
|
||||
pass
|
||||
|
||||
if highlighted:
|
||||
_handle_wiggle(delta)
|
||||
|
||||
func _handle_wiggle(delta):
|
||||
wiggle_pos += delta * wiggle_speed * wiggle_intensity
|
||||
|
||||
rotation = noise.get_noise_1d(wiggle_pos)*wiggle_strength
|
||||
|
||||
func replace_with(card: Card):
|
||||
self.text = card.text
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
[gd_scene load_steps=20 format=3 uid="uid://dy5rd437h5hsw"]
|
||||
[gd_scene load_steps=21 format=3 uid="uid://dy5rd437h5hsw"]
|
||||
|
||||
[ext_resource type="Script" path="res://logic-scenes/board/card.gd" id="1_emip0"]
|
||||
[ext_resource type="Texture2D" uid="uid://sv0nhkkur1tt" path="res://logic-scenes/board/card-textures/cardsheet.png" id="2_ioijn"]
|
||||
|
|
@ -141,23 +141,19 @@ func _process(_delta):
|
|||
self.visible = State.reduce_motion and is_void
|
||||
"
|
||||
|
||||
[node name="card" type="Control"]
|
||||
custom_minimum_size = Vector2(310, 210)
|
||||
layout_mode = 3
|
||||
anchors_preset = 0
|
||||
offset_left = -150.0
|
||||
offset_top = -110.0
|
||||
offset_right = 160.0
|
||||
offset_bottom = 100.0
|
||||
focus_mode = 2
|
||||
[sub_resource type="CapsuleShape2D" id="CapsuleShape2D_foovg"]
|
||||
radius = 110.0
|
||||
height = 336.0
|
||||
|
||||
[node name="card" type="Area2D"]
|
||||
rotation = 0.197177
|
||||
script = ExtResource("1_emip0")
|
||||
|
||||
[node name="BackgroundSprite" type="AnimatedSprite2D" parent="."]
|
||||
clip_children = 2
|
||||
position = Vector2(150, 110)
|
||||
scale = Vector2(0.6, 0.6)
|
||||
sprite_frames = SubResource("SpriteFrames_ckivt")
|
||||
frame = 4
|
||||
frame = 3
|
||||
script = SubResource("GDScript_8bs16")
|
||||
|
||||
[node name="GPUParticles2D" type="GPUParticles2D" parent="BackgroundSprite"]
|
||||
|
|
@ -179,7 +175,6 @@ texture = ExtResource("4_fwm1k")
|
|||
script = SubResource("GDScript_tgc0b")
|
||||
|
||||
[node name="Label" type="Label" parent="."]
|
||||
layout_mode = 1
|
||||
anchors_preset = 8
|
||||
anchor_left = 0.5
|
||||
anchor_top = 0.5
|
||||
|
|
@ -196,12 +191,13 @@ theme_type_variation = &"card_text"
|
|||
autowrap_mode = 3
|
||||
|
||||
[node name="postit anchor" type="Control" parent="."]
|
||||
layout_mode = 3
|
||||
anchors_preset = 0
|
||||
offset_left = 100.0
|
||||
offset_top = 148.0
|
||||
offset_right = 140.0
|
||||
offset_bottom = 188.0
|
||||
|
||||
[connection signal="focus_entered" from="." to="." method="_on_focus_entered"]
|
||||
[connection signal="focus_exited" from="." to="." method="_on_focus_exited"]
|
||||
[connection signal="focus_entered" from="postit anchor" to="." method="_on_postit_anchor_focus_entered"]
|
||||
[node name="CollisionShape2D" type="CollisionShape2D" parent="."]
|
||||
rotation = 1.5708
|
||||
shape = SubResource("CapsuleShape2D_foovg")
|
||||
|
|
|
|||
|
|
@ -1,20 +1,55 @@
|
|||
@tool
|
||||
|
||||
extends Control
|
||||
extends Area2D
|
||||
class_name PostIt
|
||||
var sibling
|
||||
var wiggle_pos: float = randf_range(-100, 100)
|
||||
var wiggle_intensity: float = 0
|
||||
var noise: Noise = FastNoiseLite.new()
|
||||
var shift_tween
|
||||
var modulate_tween
|
||||
|
||||
@export var text: String = "" :
|
||||
set (value):
|
||||
if is_inside_tree() or Engine.is_editor_hint():
|
||||
$Label.text = value
|
||||
$BackgroundSprite.frame = text.hash() % $BackgroundSprite.sprite_frames.get_frame_count($BackgroundSprite.animation)
|
||||
$Content/Label.text = value
|
||||
$Content/BackgroundSprite.frame = text.hash() % $Content/BackgroundSprite.sprite_frames.get_frame_count($Content/BackgroundSprite.animation)
|
||||
text = value
|
||||
|
||||
@export var shift_by: Vector2 = Vector2(-32, 0)
|
||||
@export_color_no_alpha var highlight_color: Color = Color(1.5, 1.5, 1.5)
|
||||
@export var highlighted: bool = false:
|
||||
set(highlight):
|
||||
if highlight != highlighted:
|
||||
highlighted = highlight
|
||||
|
||||
if is_inside_tree() and is_node_ready():
|
||||
if modulate_tween: modulate_tween.kill()
|
||||
if shift_tween: shift_tween.kill()
|
||||
if highlighted:
|
||||
modulate_tween = get_tree().create_tween()
|
||||
modulate_tween.tween_property(self, "modulate", highlight_color, 0.1)
|
||||
shift_tween = get_tree().create_tween()
|
||||
shift_tween.tween_property($Content, "position", shift_by, 0.2)
|
||||
else:
|
||||
modulate_tween = get_tree().create_tween()
|
||||
modulate_tween.tween_property(self, "modulate", Color(1, 1, 1), 0.3)
|
||||
shift_tween = get_tree().create_tween()
|
||||
shift_tween.tween_property($Content, "position", Vector2.ZERO, 0.5)
|
||||
else:
|
||||
if highlighted:
|
||||
modulate = Color(1, 1, 1)
|
||||
wiggle_intensity = 1
|
||||
else:
|
||||
modulate = Color(1, 1, 1)
|
||||
wiggle_intensity = 0
|
||||
|
||||
@export var voice_line: AudioStream = null
|
||||
|
||||
func _ready() -> void:
|
||||
$Label.text = self.text
|
||||
$BackgroundSprite.frame = text.hash() % $BackgroundSprite.sprite_frames.get_frame_count($BackgroundSprite.animation)
|
||||
$Content/Label.text = self.text
|
||||
$Content/BackgroundSprite.frame = text.hash() % $Content/BackgroundSprite.sprite_frames.get_frame_count($Content/BackgroundSprite.animation)
|
||||
|
||||
|
||||
func replace_with(postit: PostIt):
|
||||
self.text = postit.text
|
||||
|
|
|
|||
|
|
@ -1,9 +1,13 @@
|
|||
[gd_scene load_steps=17 format=3 uid="uid://vkcdj8c3ytbq"]
|
||||
[gd_scene load_steps=18 format=3 uid="uid://vkcdj8c3ytbq"]
|
||||
|
||||
[ext_resource type="Script" path="res://logic-scenes/board/post-it.gd" id="1_yvh5n"]
|
||||
[ext_resource type="Texture2D" uid="uid://c8ckkjmdegyis" path="res://logic-scenes/board/card-textures/postitsheet.png" id="2_j17jn"]
|
||||
[ext_resource type="Theme" uid="uid://b056fn288p8ha" path="res://logic-scenes/themes/messy.theme" id="3_hu2as"]
|
||||
|
||||
[sub_resource type="CapsuleShape2D" id="CapsuleShape2D_ml4q7"]
|
||||
radius = 48.0
|
||||
height = 312.0
|
||||
|
||||
[sub_resource type="AtlasTexture" id="AtlasTexture_nj16s"]
|
||||
atlas = ExtResource("2_j17jn")
|
||||
region = Rect2(0, 0, 500, 220)
|
||||
|
|
@ -96,39 +100,38 @@ animations = [{
|
|||
"speed": 5.0
|
||||
}]
|
||||
|
||||
[node name="post-it" type="Control"]
|
||||
layout_mode = 3
|
||||
anchors_preset = 0
|
||||
offset_left = -150.0
|
||||
offset_top = -50.0
|
||||
offset_right = 150.0
|
||||
offset_bottom = 50.0
|
||||
focus_mode = 2
|
||||
[node name="post-it" type="Area2D"]
|
||||
script = ExtResource("1_yvh5n")
|
||||
text = "Test"
|
||||
highlight_color = Color(1.2, 1.2, 1.2, 1)
|
||||
|
||||
[node name="BackgroundSprite" type="AnimatedSprite2D" parent="."]
|
||||
position = Vector2(150, 50)
|
||||
[node name="CollisionShape2D" type="CollisionShape2D" parent="."]
|
||||
position = Vector2(99.5, 0)
|
||||
rotation = 1.5708
|
||||
shape = SubResource("CapsuleShape2D_ml4q7")
|
||||
|
||||
[node name="Content" type="Node2D" parent="."]
|
||||
|
||||
[node name="BackgroundSprite" type="AnimatedSprite2D" parent="Content"]
|
||||
position = Vector2(99.5, 0)
|
||||
scale = Vector2(0.65, 0.65)
|
||||
sprite_frames = SubResource("SpriteFrames_2amsi")
|
||||
frame = 5
|
||||
frame = 1
|
||||
|
||||
[node name="Label" type="Label" parent="."]
|
||||
layout_mode = 1
|
||||
[node name="Label" type="Label" parent="Content"]
|
||||
anchors_preset = 8
|
||||
anchor_left = 0.5
|
||||
anchor_top = 0.5
|
||||
anchor_right = 0.5
|
||||
anchor_bottom = 0.5
|
||||
offset_left = -139.5
|
||||
offset_left = -38.0
|
||||
offset_top = -50.0
|
||||
offset_right = 137.5
|
||||
offset_right = 239.0
|
||||
offset_bottom = 47.0
|
||||
grow_horizontal = 2
|
||||
grow_vertical = 2
|
||||
theme = ExtResource("3_hu2as")
|
||||
theme_type_variation = &"card_text"
|
||||
text = "Test"
|
||||
vertical_alignment = 1
|
||||
autowrap_mode = 3
|
||||
|
||||
[connection signal="focus_entered" from="." to="." method="_on_focus_entered"]
|
||||
[connection signal="focus_exited" from="." to="." method="_on_focus_exited"]
|
||||
|
|
|
|||
Loading…
Reference in New Issue