mirror of
https://github.com/ppy/osu.git
synced 2024-12-15 09:02:55 +08:00
Merge pull request #179 from Tom94/beatmap-backgrounds
Update the background according to the currently selected beatmap and…
This commit is contained in:
commit
0e27d2ba2f
@ -1 +1 @@
|
|||||||
Subproject commit 3163342d5b00f7cd125fdca71f8cc1590a6237cf
|
Subproject commit 37d53e32e58104c8e743efad855019c39edeb6b2
|
@ -15,19 +15,19 @@ using osu.Framework.Allocation;
|
|||||||
|
|
||||||
namespace osu.Game.Graphics.Background
|
namespace osu.Game.Graphics.Background
|
||||||
{
|
{
|
||||||
class Background : Container
|
public class Background : BufferedContainer
|
||||||
{
|
{
|
||||||
protected Sprite BackgroundSprite;
|
public Sprite Sprite;
|
||||||
|
|
||||||
string textureName;
|
string textureName;
|
||||||
|
|
||||||
public Background(string textureName = @"Backgrounds/bg1")
|
public Background(string textureName = @"")
|
||||||
{
|
{
|
||||||
this.textureName = textureName;
|
this.textureName = textureName;
|
||||||
RelativeSizeAxes = Axes.Both;
|
RelativeSizeAxes = Axes.Both;
|
||||||
Depth = float.MinValue;
|
Depth = float.MinValue;
|
||||||
|
|
||||||
Add(BackgroundSprite = new Sprite
|
Add(Sprite = new Sprite
|
||||||
{
|
{
|
||||||
Anchor = Anchor.Centre,
|
Anchor = Anchor.Centre,
|
||||||
Origin = Anchor.Centre,
|
Origin = Anchor.Centre,
|
||||||
@ -38,13 +38,14 @@ namespace osu.Game.Graphics.Background
|
|||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(TextureStore textures)
|
private void load(TextureStore textures)
|
||||||
{
|
{
|
||||||
BackgroundSprite.Texture = textures.Get(textureName);
|
if (!string.IsNullOrEmpty(textureName))
|
||||||
|
Sprite.Texture = textures.Get(textureName);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void Update()
|
protected override void Update()
|
||||||
{
|
{
|
||||||
base.Update();
|
base.Update();
|
||||||
BackgroundSprite.Scale = new Vector2(Math.Max(DrawSize.X / BackgroundSprite.DrawSize.X, DrawSize.Y / BackgroundSprite.DrawSize.Y));
|
Sprite.Scale = new Vector2(Math.Max(DrawSize.X / Sprite.DrawSize.X, DrawSize.Y / Sprite.DrawSize.Y));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
76
osu.Game/Screens/Backgrounds/BackgroundModeBeatmap.cs
Normal file
76
osu.Game/Screens/Backgrounds/BackgroundModeBeatmap.cs
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
//Copyright (c) 2007-2016 ppy Pty Ltd <contact@ppy.sh>.
|
||||||
|
//Licensed under the MIT Licence - https://raw.githubusercontent.com/ppy/osu/master/LICENCE
|
||||||
|
|
||||||
|
using OpenTK;
|
||||||
|
using osu.Framework.Graphics;
|
||||||
|
using osu.Framework.Graphics.Containers;
|
||||||
|
using osu.Framework.Graphics.Transformations;
|
||||||
|
using osu.Game.Beatmaps;
|
||||||
|
using osu.Game.Graphics.Background;
|
||||||
|
|
||||||
|
namespace osu.Game.Screens.Backgrounds
|
||||||
|
{
|
||||||
|
public class BackgroundModeBeatmap : BackgroundMode
|
||||||
|
{
|
||||||
|
private Background background;
|
||||||
|
|
||||||
|
private WorkingBeatmap beatmap;
|
||||||
|
|
||||||
|
public WorkingBeatmap Beatmap
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
return beatmap;
|
||||||
|
}
|
||||||
|
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if (beatmap == value)
|
||||||
|
return;
|
||||||
|
|
||||||
|
beatmap = value;
|
||||||
|
|
||||||
|
Background oldBackground = background;
|
||||||
|
|
||||||
|
addBackground(background = new Background());
|
||||||
|
background.Sprite.Texture = beatmap.Background;
|
||||||
|
|
||||||
|
if (oldBackground != null)
|
||||||
|
{
|
||||||
|
oldBackground.Depth = 1;
|
||||||
|
oldBackground.Flush();
|
||||||
|
oldBackground.FadeOut(500);
|
||||||
|
oldBackground.Expire();
|
||||||
|
|
||||||
|
background.BlurSigma = oldBackground.BlurSigma;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public BackgroundModeBeatmap(WorkingBeatmap beatmap)
|
||||||
|
{
|
||||||
|
Beatmap = beatmap;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addBackground(Background background)
|
||||||
|
{
|
||||||
|
background.CacheDrawnFrameBuffer = true;
|
||||||
|
Add(background);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void BlurTo(Vector2 sigma, double duration)
|
||||||
|
{
|
||||||
|
background?.BlurTo(sigma, duration, EasingTypes.OutExpo);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void Update()
|
||||||
|
{
|
||||||
|
base.Update();
|
||||||
|
}
|
||||||
|
|
||||||
|
public override bool Equals(BackgroundMode other)
|
||||||
|
{
|
||||||
|
return base.Equals(other) && beatmap == ((BackgroundModeBeatmap)other).Beatmap;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -12,7 +12,7 @@ namespace osu.Game.Screens.Backgrounds
|
|||||||
[BackgroundDependencyLoader]
|
[BackgroundDependencyLoader]
|
||||||
private void load(BaseGame game)
|
private void load(BaseGame game)
|
||||||
{
|
{
|
||||||
Add(new Background());
|
Add(new Background(@"Backgrounds/bg1"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -30,13 +30,16 @@ namespace osu.Game.Screens.Play
|
|||||||
private BeatmapDatabase database;
|
private BeatmapDatabase database;
|
||||||
private BeatmapGroup selectedBeatmapGroup;
|
private BeatmapGroup selectedBeatmapGroup;
|
||||||
private BeatmapInfo selectedBeatmapInfo;
|
private BeatmapInfo selectedBeatmapInfo;
|
||||||
// TODO: use currently selected track as bg
|
|
||||||
protected override BackgroundMode CreateBackground() => new BackgroundModeCustom(@"Backgrounds/bg4");
|
protected override BackgroundMode CreateBackground() => new BackgroundModeBeatmap(Beatmap);
|
||||||
|
|
||||||
private ScrollContainer scrollContainer;
|
private ScrollContainer scrollContainer;
|
||||||
private FlowContainer beatmapSetFlow;
|
private FlowContainer beatmapSetFlow;
|
||||||
private TrackManager trackManager;
|
private TrackManager trackManager;
|
||||||
private Container wedgeContainer;
|
private Container wedgeContainer;
|
||||||
|
|
||||||
|
private static readonly Vector2 BACKGROUND_BLUR = new Vector2(20);
|
||||||
|
|
||||||
/// <param name="database">Optionally provide a database to use instead of the OsuGame one.</param>
|
/// <param name="database">Optionally provide a database to use instead of the OsuGame one.</param>
|
||||||
public PlaySongSelect(BeatmapDatabase database = null)
|
public PlaySongSelect(BeatmapDatabase database = null)
|
||||||
{
|
{
|
||||||
@ -150,10 +153,14 @@ namespace osu.Game.Screens.Play
|
|||||||
base.OnEntering(last);
|
base.OnEntering(last);
|
||||||
ensurePlayingSelected();
|
ensurePlayingSelected();
|
||||||
wedgeContainer.FadeInFromZero(250);
|
wedgeContainer.FadeInFromZero(250);
|
||||||
|
|
||||||
|
(Background as BackgroundModeBeatmap)?.BlurTo(BACKGROUND_BLUR, 1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void OnResuming(GameMode last)
|
protected override void OnResuming(GameMode last)
|
||||||
{
|
{
|
||||||
|
(Background as BackgroundModeBeatmap)?.BlurTo(BACKGROUND_BLUR, 1000);
|
||||||
|
|
||||||
ensurePlayingSelected();
|
ensurePlayingSelected();
|
||||||
base.OnResuming(last);
|
base.OnResuming(last);
|
||||||
}
|
}
|
||||||
@ -175,6 +182,15 @@ namespace osu.Game.Screens.Play
|
|||||||
protected override void OnBeatmapChanged(WorkingBeatmap beatmap)
|
protected override void OnBeatmapChanged(WorkingBeatmap beatmap)
|
||||||
{
|
{
|
||||||
base.OnBeatmapChanged(beatmap);
|
base.OnBeatmapChanged(beatmap);
|
||||||
|
|
||||||
|
var backgroundModeBeatmap = Background as BackgroundModeBeatmap;
|
||||||
|
if (backgroundModeBeatmap != null)
|
||||||
|
{
|
||||||
|
backgroundModeBeatmap.Beatmap = beatmap;
|
||||||
|
// TODO: Remove this once we have non-nullable Beatmap
|
||||||
|
(Background as BackgroundModeBeatmap)?.BlurTo(BACKGROUND_BLUR, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
selectBeatmap(beatmap.BeatmapInfo);
|
selectBeatmap(beatmap.BeatmapInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -16,6 +16,8 @@ using osu.Game.Modes.Objects.Drawables;
|
|||||||
using osu.Game.Screens.Backgrounds;
|
using osu.Game.Screens.Backgrounds;
|
||||||
using OpenTK.Input;
|
using OpenTK.Input;
|
||||||
using MouseState = osu.Framework.Input.MouseState;
|
using MouseState = osu.Framework.Input.MouseState;
|
||||||
|
using OpenTK;
|
||||||
|
using osu.Framework.GameModes;
|
||||||
|
|
||||||
namespace osu.Game.Screens.Play
|
namespace osu.Game.Screens.Play
|
||||||
{
|
{
|
||||||
@ -23,7 +25,7 @@ namespace osu.Game.Screens.Play
|
|||||||
{
|
{
|
||||||
public bool Autoplay;
|
public bool Autoplay;
|
||||||
|
|
||||||
protected override BackgroundMode CreateBackground() => new BackgroundModeCustom(@"Backgrounds/bg4");
|
protected override BackgroundMode CreateBackground() => null;
|
||||||
|
|
||||||
internal override bool ShowOverlays => false;
|
internal override bool ShowOverlays => false;
|
||||||
|
|
||||||
@ -106,6 +108,13 @@ namespace osu.Game.Screens.Play
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected override void OnEntering(GameMode last)
|
||||||
|
{
|
||||||
|
base.OnEntering(last);
|
||||||
|
|
||||||
|
(Background as BackgroundModeBeatmap)?.BlurTo(Vector2.Zero, 1000);
|
||||||
|
}
|
||||||
|
|
||||||
protected override void Update()
|
protected override void Update()
|
||||||
{
|
{
|
||||||
base.Update();
|
base.Update();
|
||||||
|
@ -86,6 +86,7 @@
|
|||||||
<Compile Include="Beatmaps\Timing\TimingChange.cs" />
|
<Compile Include="Beatmaps\Timing\TimingChange.cs" />
|
||||||
<Compile Include="Configuration\OsuConfigManager.cs" />
|
<Compile Include="Configuration\OsuConfigManager.cs" />
|
||||||
<Compile Include="Screens\BackgroundMode.cs" />
|
<Compile Include="Screens\BackgroundMode.cs" />
|
||||||
|
<Compile Include="Screens\Backgrounds\BackgroundModeBeatmap.cs" />
|
||||||
<Compile Include="Screens\Backgrounds\BackgroundModeCustom.cs" />
|
<Compile Include="Screens\Backgrounds\BackgroundModeCustom.cs" />
|
||||||
<Compile Include="Screens\Backgrounds\BackgroundModeDefault.cs" />
|
<Compile Include="Screens\Backgrounds\BackgroundModeDefault.cs" />
|
||||||
<Compile Include="Screens\Backgrounds\BackgroundModeEmpty.cs" />
|
<Compile Include="Screens\Backgrounds\BackgroundModeEmpty.cs" />
|
||||||
|
Loading…
Reference in New Issue
Block a user