1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-16 00:52:55 +08:00
osu-lazer/osu.Game/Overlays/Chat/Selection/ChannelSelectionOverlay.cs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

195 lines
6.9 KiB
C#
Raw Normal View History

// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.
2018-04-13 17:19:50 +08:00
using System;
using System.Collections.Generic;
2018-11-20 15:51:59 +08:00
using osuTK;
using osuTK.Graphics;
2017-05-21 05:06:25 +08:00
using osu.Framework.Allocation;
using osu.Framework.Extensions.Color4Extensions;
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Shapes;
2018-10-02 11:02:47 +08:00
using osu.Framework.Input.Events;
2017-05-21 05:06:25 +08:00
using osu.Game.Graphics;
using osu.Game.Graphics.Backgrounds;
2017-05-21 05:06:25 +08:00
using osu.Game.Graphics.Sprites;
using osu.Game.Graphics.UserInterface;
using osu.Game.Online.Chat;
using osu.Game.Graphics.Containers;
2018-04-13 17:19:50 +08:00
namespace osu.Game.Overlays.Chat.Selection
2017-05-21 05:06:25 +08:00
{
public class ChannelSelectionOverlay : WaveOverlayContainer
2017-05-21 05:06:25 +08:00
{
2020-09-03 15:28:14 +08:00
public new const float WIDTH_PADDING = 170;
2018-04-13 17:19:50 +08:00
2017-06-01 17:10:26 +08:00
private const float transition_duration = 500;
2018-04-13 17:19:50 +08:00
2017-05-21 05:06:25 +08:00
private readonly Box bg;
private readonly Triangles triangles;
2017-05-21 05:06:25 +08:00
private readonly Box headerBg;
private readonly SearchTextBox search;
2017-05-21 07:22:55 +08:00
private readonly SearchContainer<ChannelSection> sectionsFlow;
2018-04-13 17:19:50 +08:00
2019-07-01 17:49:36 +08:00
protected override bool DimMainContent => false;
public Action<Channel> OnRequestJoin;
2017-05-26 14:56:10 +08:00
public Action<Channel> OnRequestLeave;
2018-04-13 17:19:50 +08:00
2017-05-21 05:06:25 +08:00
public ChannelSelectionOverlay()
{
RelativeSizeAxes = Axes.X;
2018-04-13 17:19:50 +08:00
Waves.FirstWaveColour = Color4Extensions.FromHex("353535");
Waves.SecondWaveColour = Color4Extensions.FromHex("434343");
Waves.ThirdWaveColour = Color4Extensions.FromHex("515151");
Waves.FourthWaveColour = Color4Extensions.FromHex("595959");
2017-05-21 05:06:25 +08:00
Children = new Drawable[]
{
new Container
{
RelativeSizeAxes = Axes.Both,
Masking = true,
Children = new Drawable[]
2017-05-21 05:06:25 +08:00
{
bg = new Box
{
RelativeSizeAxes = Axes.Both,
},
triangles = new Triangles
{
RelativeSizeAxes = Axes.Both,
TriangleScale = 5,
},
},
},
new Container
{
RelativeSizeAxes = Axes.Both,
2017-05-30 09:00:15 +08:00
Padding = new MarginPadding { Top = 85, Right = WIDTH_PADDING },
Children = new[]
{
new OsuScrollContainer
{
RelativeSizeAxes = Axes.Both,
Children = new[]
{
sectionsFlow = new SearchContainer<ChannelSection>
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Direction = FillDirection.Vertical,
LayoutDuration = 200,
2017-07-23 02:50:25 +08:00
LayoutEasing = Easing.OutQuint,
Spacing = new Vector2(0f, 20f),
2017-05-30 09:00:15 +08:00
Padding = new MarginPadding { Vertical = 20, Left = WIDTH_PADDING },
},
},
},
2017-05-21 05:06:25 +08:00
},
},
new Container
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Children = new Drawable[]
{
headerBg = new Box
{
RelativeSizeAxes = Axes.Both,
},
new FillFlowContainer
{
RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y,
Direction = FillDirection.Vertical,
Spacing = new Vector2(0f, 10f),
Padding = new MarginPadding { Top = 10f, Bottom = 10f, Left = WIDTH_PADDING, Right = WIDTH_PADDING },
Children = new Drawable[]
{
new OsuSpriteText
{
Text = @"Chat Channels",
Font = OsuFont.GetFont(size: 20),
Shadow = false,
2017-05-21 05:06:25 +08:00
},
search = new HeaderSearchTextBox { RelativeSizeAxes = Axes.X },
2017-05-21 05:06:25 +08:00
},
},
},
},
};
2018-04-13 17:19:50 +08:00
search.Current.ValueChanged += term => sectionsFlow.SearchTerm = term.NewValue;
2017-05-21 05:06:25 +08:00
}
2018-04-13 17:19:50 +08:00
public void UpdateAvailableChannels(IEnumerable<Channel> channels)
{
Scheduler.Add(() =>
{
sectionsFlow.ChildrenEnumerable = new[]
{
new ChannelSection { Channels = channels, },
};
foreach (ChannelSection s in sectionsFlow.Children)
{
foreach (ChannelListItem c in s.ChannelFlow.Children)
{
c.OnRequestJoin = channel => { OnRequestJoin?.Invoke(channel); };
c.OnRequestLeave = channel => { OnRequestLeave?.Invoke(channel); };
}
}
});
}
2017-05-21 05:06:25 +08:00
[BackgroundDependencyLoader]
private void load(OsuColour colours)
{
bg.Colour = colours.Gray3;
triangles.ColourDark = colours.Gray3;
triangles.ColourLight = Color4Extensions.FromHex(@"353535");
2018-04-13 17:19:50 +08:00
2017-05-21 05:06:25 +08:00
headerBg.Colour = colours.Gray2.Opacity(0.75f);
}
2018-04-13 17:19:50 +08:00
2018-10-02 11:02:47 +08:00
protected override void OnFocus(FocusEvent e)
2017-05-21 05:06:25 +08:00
{
search.TakeFocus();
2018-10-02 11:02:47 +08:00
base.OnFocus(e);
2017-06-01 09:39:03 +08:00
}
2018-04-13 17:19:50 +08:00
2017-06-01 09:39:03 +08:00
protected override void PopIn()
{
if (Alpha == 0) this.MoveToY(DrawHeight);
2018-04-13 17:19:50 +08:00
2017-07-23 02:50:25 +08:00
this.FadeIn(transition_duration, Easing.OutQuint);
this.MoveToY(0, transition_duration, Easing.OutQuint);
2018-04-13 17:19:50 +08:00
2017-06-01 09:39:03 +08:00
search.HoldFocus = true;
base.PopIn();
2017-05-21 05:06:25 +08:00
}
2018-04-13 17:19:50 +08:00
2017-05-21 05:06:25 +08:00
protected override void PopOut()
{
2017-07-23 02:50:25 +08:00
this.FadeOut(transition_duration, Easing.InSine);
this.MoveToY(DrawHeight, transition_duration, Easing.InSine);
2018-04-13 17:19:50 +08:00
2017-06-01 09:39:03 +08:00
search.HoldFocus = false;
base.PopOut();
2017-05-21 05:06:25 +08:00
}
2018-04-13 17:19:50 +08:00
2017-05-21 05:06:25 +08:00
private class HeaderSearchTextBox : SearchTextBox
{
2019-03-23 00:44:05 +08:00
[BackgroundDependencyLoader]
private void load()
{
BackgroundFocused = Color4.Black.Opacity(0.2f);
BackgroundUnfocused = Color4.Black.Opacity(0.2f);
}
2017-05-21 05:06:25 +08:00
}
}
}