WIP: audio clip controls and UI

This commit is contained in:
2025-02-16 17:17:53 +01:00
parent 60282fc89c
commit ec16023158
5 changed files with 138 additions and 1 deletions

View File

@@ -2677,6 +2677,8 @@ AssetLib/colors/status_color = Color(0.5, 0.5, 0.5, 1)
AssetLib/icons/dismiss = null
AssetLib/styles/bg = SubResource("StyleBoxEmpty_6c8sw")
AssetLib/styles/panel = SubResource("StyleBoxFlat_0c4py")
AudioClip/colors/deselected_modulate = Color(0.552941, 0.552941, 0.552941, 1)
AudioClip/colors/selected_modulate = Color(1, 1, 1, 1)
BottomPanelButton/styles/hover = SubResource("StyleBoxFlat_jduyo")
BottomPanelButton/styles/hover_pressed = SubResource("StyleBoxFlat_jduyo")
BottomPanelButton/styles/normal = SubResource("StyleBoxFlat_sxnkh")

42
Controls/AudioClip.tscn Normal file
View File

@@ -0,0 +1,42 @@
[gd_scene load_steps=3 format=3 uid="uid://dmmgalpx4fcc7"]
[ext_resource type="Script" path="res://Scripts/AudioClip.gd" id="1_iy5jd"]
[sub_resource type="StyleBoxFlat" id="StyleBoxFlat_8tb17"]
border_width_left = 2
border_width_top = 2
border_width_right = 2
border_width_bottom = 2
border_color = Color(0.273873, 0.273873, 0.273873, 1)
border_blend = true
[node name="AudioClip" type="Panel"]
modulate = Color(0.552956, 0.552956, 0.552956, 1)
clip_contents = true
custom_minimum_size = Vector2(4, 64)
anchors_preset = -1
anchor_right = 0.104
anchor_bottom = 0.059
offset_right = 0.319992
offset_bottom = 0.279995
theme_override_styles/panel = SubResource("StyleBoxFlat_8tb17")
script = ExtResource("1_iy5jd")
[node name="Panel" type="Panel" parent="."]
custom_minimum_size = Vector2(0, 14)
layout_mode = 1
anchors_preset = 10
anchor_right = 1.0
grow_horizontal = 2
[node name="Label" type="Label" parent="Panel"]
layout_mode = 1
anchors_preset = 15
anchor_right = 1.0
anchor_bottom = 1.0
grow_horizontal = 2
grow_vertical = 2
theme_override_font_sizes/font_size = 8
text = "New Audio Clip"
vertical_alignment = 1
text_overrun_behavior = 3

63
Scripts/AudioClip.gd Normal file
View File

@@ -0,0 +1,63 @@
class_name AudioClip
extends Panel
@export var start_time: float = 0.0
@export var end_time: float = 0.0
@export var track_idx: int = 0
var timeline: Timeline
var dragging: bool
var selected: bool
func _ready():
timeline = get_parent()
func _input(event):
var rect = get_global_rect()
var mouse_position = get_global_mouse_position()
if event is InputEventMouseButton:
if event.pressed and event.button_mask == MOUSE_BUTTON_LEFT:
if selected:
mouse_default_cursor_shape = CURSOR_MOVE
dragging = true
else:
dragging = false
mouse_default_cursor_shape = CURSOR_ARROW
if rect.has_point(mouse_position):
selected = true
make_selected()
return
else:
selected = false
make_deselected()
return
if !event.pressed and dragging:
dragging = false
mouse_default_cursor_shape = CURSOR_ARROW
if selected and dragging:
if event is InputEventMouseMotion:
var movement = event.relative.x / timeline.get_pixels_per_unit() * timeline.time_interval
start_time += movement
end_time += movement
if event.is_command_or_control_pressed():
start_time = snapped(start_time, timeline.time_interval)
end_time = snapped(end_time, timeline.time_interval)
timeline.queue_sort()
pass
func make_selected():
var color = get_theme_color("selected_modulate", "AudioClip")
modulate = color
pass
func make_deselected():
var color = get_theme_color("deselected_modulate", "AudioClip")
modulate = color
pass

View File

@@ -34,6 +34,10 @@ func format_time_ms_minutes(ms: float) -> String:
var milliseconds = fmod(ms, 1000.0)
return "%02d:%02d.%03d" % [minutes, seconds, milliseconds]
func get_pixels_per_unit() -> float:
return 50.0 * zoom
func _draw():
var primary_color = get_theme_color("line_primary_color", "Timeline")
var secondary_color = get_theme_color("line_secondary_color", "Timeline")
@@ -70,8 +74,21 @@ func _draw():
draw_string(font, Vector2(x - time_label_offset_x, time_label_offset_y), format_time_ms_minutes(time), HORIZONTAL_ALIGNMENT_CENTER, -1, font_size, primary_color)
else:
draw_line(Vector2(x, 28.0), Vector2(x, timeline_y), secondary_color, 1)
queue_sort()
pass
func _notification(what):
if what == NOTIFICATION_SORT_CHILDREN:
for c in get_children():
if c is not AudioClip: continue
var pixels_per_unit := 50.0 * zoom
var start = ((c.start_time / time_interval) * pixels_per_unit) - time_offset
var width = (c.end_time - c.start_time) / time_interval * pixels_per_unit
c.position = Vector2(start, 0.0)
c.size = Vector2(width, c.size.y)
func _gui_input(event):
var zoom_factor = 1.1
if event is InputEventMouseButton and event.button_index == MOUSE_BUTTON_WHEEL_DOWN:

View File

@@ -1,14 +1,17 @@
[gd_scene load_steps=2 format=3 uid="uid://v4oljx3qrk5q"]
[gd_scene load_steps=3 format=3 uid="uid://v4oljx3qrk5q"]
[ext_resource type="Script" path="res://Scripts/Timeline.gd" id="1_h2mev"]
[ext_resource type="PackedScene" uid="uid://dmmgalpx4fcc7" path="res://Controls/AudioClip.tscn" id="2_an2hv"]
[node name="Timeline" type="Container"]
clip_children = 2
anchors_preset = 15
anchor_right = 1.0
anchor_bottom = 1.0
grow_horizontal = 2
grow_vertical = 2
size_flags_horizontal = 3
size_flags_vertical = 3
script = ExtResource("1_h2mev")
end_time = 4000.0
@@ -16,3 +19,13 @@ end_time = 4000.0
visible = false
custom_minimum_size = Vector2(0, 20)
layout_mode = 2
[node name="AudioClip" parent="." instance=ExtResource("2_an2hv")]
layout_mode = 2
start_time = 4000.0
end_time = 8000.0
[node name="AudioClip2" parent="." instance=ExtResource("2_an2hv")]
layout_mode = 2
start_time = 8000.0
end_time = 12000.0