mirror of
https://gitlab.com/MaddoScientisto/cirnogodot.git
synced 2026-06-08 17:25:54 +00:00
Music room music playing
This commit is contained in:
parent
67d7986330
commit
766b04b2ff
9 changed files with 129 additions and 86 deletions
|
|
@ -5,52 +5,56 @@ using Godot.Collections;
|
|||
|
||||
public partial class MusicRoom : MenuBase
|
||||
{
|
||||
[Export]
|
||||
public Array<MusicResource> Tracks { get; private set; } = new();
|
||||
[Export]
|
||||
public Array<MusicResource> Tracks { get; private set; } = new();
|
||||
|
||||
[Export]
|
||||
public ItemList TracksContainer { get; private set; }
|
||||
[Export]
|
||||
public ItemList TracksContainer { get; private set; }
|
||||
|
||||
[Export]
|
||||
public Texture2D Icon { get; private set; }
|
||||
[Export]
|
||||
public Texture2D Icon { get; private set; }
|
||||
|
||||
private Dictionary<long, AudioNameVisualizer> _tracks = new();
|
||||
[Export]
|
||||
public Label DescriptionLabel { get; private set; }
|
||||
|
||||
public override void _Ready()
|
||||
{
|
||||
TracksContainer.Clear();
|
||||
foreach (var track in Tracks)
|
||||
{
|
||||
var index = TracksContainer.AddItem($"{track.TrackName} ({track.AuthorName})", Icon);
|
||||
private Dictionary<long, AudioNameVisualizer> _tracks = new();
|
||||
|
||||
var visualizer = new AudioNameVisualizer();
|
||||
visualizer.MusicData = track;
|
||||
TracksContainer.CallDeferred("add_child", visualizer);
|
||||
public override void _Ready()
|
||||
{
|
||||
DescriptionLabel.Text = string.Empty;
|
||||
TracksContainer.Clear();
|
||||
foreach (var track in Tracks)
|
||||
{
|
||||
var index = TracksContainer.AddItem($"{track.TrackName} ({track.AuthorName})", Icon);
|
||||
|
||||
_tracks.Add((long)index, visualizer);
|
||||
var visualizer = new AudioNameVisualizer();
|
||||
visualizer.MusicData = track;
|
||||
TracksContainer.CallDeferred("add_child", visualizer);
|
||||
|
||||
}
|
||||
_tracks.Add((long)index, visualizer);
|
||||
|
||||
TracksContainer.ItemSelected += (long selectedItem) =>
|
||||
{
|
||||
var vis = _tracks[selectedItem];
|
||||
if (vis.MusicData is null) { return; }
|
||||
StopAllTracks();
|
||||
vis.PlayWithName();
|
||||
UpdateDescription(vis.MusicData.Description);
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
private void StopAllTracks()
|
||||
{
|
||||
foreach (var track in _tracks)
|
||||
{
|
||||
track.Value.Stop();
|
||||
}
|
||||
}
|
||||
TracksContainer.ItemSelected += (long selectedItem) =>
|
||||
{
|
||||
var vis = _tracks[selectedItem];
|
||||
if (vis.MusicData is null) { return; }
|
||||
StopAllTracks();
|
||||
vis.PlayWithName();
|
||||
UpdateDescription(vis.MusicData.Description);
|
||||
};
|
||||
}
|
||||
|
||||
private void UpdateDescription(string name)
|
||||
{
|
||||
private void StopAllTracks()
|
||||
{
|
||||
foreach (var track in _tracks)
|
||||
{
|
||||
track.Value.Stop();
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
private void UpdateDescription(string name)
|
||||
{
|
||||
DescriptionLabel.Text = name;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue