1
0
mirror of https://github.com/ppy/osu.git synced 2024-09-22 01:27:29 +08:00
osu-lazer/osu.Game/OsuGameBase.cs

98 lines
2.9 KiB
C#
Raw Normal View History

2016-10-28 18:55:48 +08:00
using System;
using osu.Framework;
using osu.Framework.Configuration;
2016-10-10 16:17:26 +08:00
using osu.Framework.GameModes;
2016-09-30 17:45:27 +08:00
using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Cursor;
using osu.Framework.Graphics.Textures;
using osu.Framework.IO.Stores;
2016-10-28 18:55:48 +08:00
using osu.Game.Beatmaps;
2016-10-08 03:09:52 +08:00
using osu.Game.Beatmaps.IO;
using osu.Game.Configuration;
2016-10-04 23:31:10 +08:00
using osu.Game.Database;
using osu.Game.Graphics.Cursor;
using osu.Game.Graphics.Processing;
using osu.Game.IPC;
using osu.Game.Online.API;
2016-09-29 19:13:58 +08:00
using osu.Game.Overlays;
namespace osu.Game
{
public class OsuGameBase : BaseGame
{
internal OsuConfigManager Config = new OsuConfigManager();
public BeatmapDatabase Beatmaps { get; private set; }
protected override string MainResourceFile => @"osu.Game.Resources.dll";
2016-09-29 19:13:58 +08:00
public Options Options;
public APIAccess API;
protected override Container Content => ratioContainer;
private RatioAdjust ratioContainer;
2016-10-06 20:09:18 +08:00
public CursorContainer Cursor;
2016-10-28 18:55:48 +08:00
public readonly Bindable<WorkingBeatmap> Beatmap = new Bindable<WorkingBeatmap>();
public OsuGameBase()
{
AddInternal(ratioContainer = new RatioAdjust());
Children = new Drawable[]
{
Options = new Options(),
Cursor = new OsuCursorContainer()
};
2016-10-28 18:55:48 +08:00
Beatmap.ValueChanged += Beatmap_ValueChanged;
}
private void Beatmap_ValueChanged(object sender, EventArgs e)
{
throw new NotImplementedException();
}
2016-10-10 16:17:26 +08:00
public override void Load(BaseGame game)
{
2016-10-10 16:17:26 +08:00
base.Load(game);
2016-10-08 03:09:52 +08:00
OszArchiveReader.Register();
Beatmaps = new BeatmapDatabase(Host.Storage, Host);
//this completely overrides the framework default. will need to change once we make a proper FontStore.
Fonts = new TextureStore() { ScaleAdjust = 0.01f };
Fonts.AddStore(new GlyphStore(Resources, @"Fonts/Exo2.0-Regular"));
Fonts.AddStore(new GlyphStore(Resources, @"Fonts/FontAwesome"));
Fonts.AddStore(new GlyphStore(Resources, @"Fonts/osuFont"));
API = new APIAccess()
{
Username = Config.Get<string>(OsuConfig.Username),
Password = Config.Get<string>(OsuConfig.Password),
Token = Config.Get<string>(OsuConfig.Token)
};
}
2016-09-27 18:22:02 +08:00
protected override void Update()
{
base.Update();
API.Update();
}
protected override void Dispose(bool isDisposing)
{
//refresh token may have changed.
if (Config != null && API != null)
{
Config.Set(OsuConfig.Token, API.Token);
Config.Save();
}
base.Dispose(isDisposing);
}
}
}