Fix music install crash.
This commit is contained in:
@@ -27,13 +27,19 @@ namespace OpenRA.Mods.Cnc.Widgets
|
|||||||
Widget panel;
|
Widget panel;
|
||||||
MusicInfo[] music;
|
MusicInfo[] music;
|
||||||
MusicInfo[] random;
|
MusicInfo[] random;
|
||||||
|
|
||||||
|
ScrollItemWidget itemTemplate;
|
||||||
|
|
||||||
[ObjectCreator.UseCtor]
|
[ObjectCreator.UseCtor]
|
||||||
public CncMusicPlayerLogic([ObjectCreator.Param] Widget widget,
|
public CncMusicPlayerLogic([ObjectCreator.Param] Widget widget,
|
||||||
[ObjectCreator.Param] Action onExit)
|
[ObjectCreator.Param] Action onExit)
|
||||||
{
|
{
|
||||||
panel = widget.GetWidget("MUSIC_PANEL");
|
panel = widget.GetWidget("MUSIC_PANEL");
|
||||||
BuildMusicTable(panel);
|
|
||||||
|
var ml = panel.GetWidget<ScrollPanelWidget>("MUSIC_LIST");
|
||||||
|
itemTemplate = ml.GetWidget<ScrollItemWidget>("MUSIC_TEMPLATE");
|
||||||
|
|
||||||
|
BuildMusicTable(ml);
|
||||||
|
|
||||||
currentSong = Sound.CurrentMusic ?? GetNextSong();
|
currentSong = Sound.CurrentMusic ?? GetNextSong();
|
||||||
installed = Rules.Music.Where(m => m.Value.Exists).Any();
|
installed = Rules.Music.Where(m => m.Value.Exists).Any();
|
||||||
@@ -52,7 +58,7 @@ namespace OpenRA.Mods.Cnc.Widgets
|
|||||||
catch (Exception) { }
|
catch (Exception) { }
|
||||||
|
|
||||||
installed = Rules.Music.Where(m => m.Value.Exists).Any();
|
installed = Rules.Music.Where(m => m.Value.Exists).Any();
|
||||||
BuildMusicTable(panel);
|
BuildMusicTable(ml);
|
||||||
};
|
};
|
||||||
|
|
||||||
var installButton = panel.GetWidget<ButtonWidget>("INSTALL_BUTTON");
|
var installButton = panel.GetWidget<ButtonWidget>("INSTALL_BUTTON");
|
||||||
@@ -101,15 +107,12 @@ namespace OpenRA.Mods.Cnc.Widgets
|
|||||||
musicSlider.SetOffset(Sound.MusicVolume);
|
musicSlider.SetOffset(Sound.MusicVolume);
|
||||||
}
|
}
|
||||||
|
|
||||||
void BuildMusicTable(Widget panel)
|
void BuildMusicTable(Widget list)
|
||||||
{
|
{
|
||||||
music = Rules.Music.Where(a => a.Value.Exists).Select(a => a.Value).ToArray();
|
music = Rules.Music.Where(a => a.Value.Exists).Select(a => a.Value).ToArray();
|
||||||
random = music.Shuffle(Game.CosmeticRandom).ToArray();
|
random = music.Shuffle(Game.CosmeticRandom).ToArray();
|
||||||
|
|
||||||
var ml = panel.GetWidget<ScrollPanelWidget>("MUSIC_LIST");
|
list.RemoveChildren();
|
||||||
var itemTemplate = ml.GetWidget<ScrollItemWidget>("MUSIC_TEMPLATE");
|
|
||||||
ml.RemoveChildren();
|
|
||||||
|
|
||||||
foreach (var s in music)
|
foreach (var s in music)
|
||||||
{
|
{
|
||||||
var song = s;
|
var song = s;
|
||||||
@@ -119,7 +122,7 @@ namespace OpenRA.Mods.Cnc.Widgets
|
|||||||
var item = ScrollItemWidget.Setup(itemTemplate, () => currentSong == song, () => { currentSong = song; Play(); });
|
var item = ScrollItemWidget.Setup(itemTemplate, () => currentSong == song, () => { currentSong = song; Play(); });
|
||||||
item.GetWidget<LabelWidget>("TITLE").GetText = () => song.Title;
|
item.GetWidget<LabelWidget>("TITLE").GetText = () => song.Title;
|
||||||
item.GetWidget<LabelWidget>("LENGTH").GetText = () => SongLengthLabel(song);
|
item.GetWidget<LabelWidget>("LENGTH").GetText = () => SongLengthLabel(song);
|
||||||
ml.AddChild(item);
|
list.AddChild(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user