using Microsoft.Xna.Framework; using Microsoft.Xna.Framework.Graphics; using Microsoft.Xna.Framework.Input; using RhythmBullet.Zer01HD.Game; using RhythmBullet.Zer01HD.Game.ContentResolvers; using RhythmBullet.Zer01HD.Game.Preferences; using RhythmBullet.Zer01HD.UI; using RhythmBullet.Zer01HD.Utilities; using RhythmBullet.Zer01HD.Utilities.ContentSystem; using RhythmBullet.Zer01HD.Utilities.UI; using System; namespace RhythmBullet { /// /// This is the main type for your game. /// public class RhythmBulletGame : Game { public GraphicsDeviceManager Graphics; SpriteBatch spriteBatch; public readonly ContentSystem Assets; readonly ResolutionContentResolver resolutionContentResolver; public PreferencesManager preferencesManager; private Screen currentScreen; public RhythmBulletGame() { Graphics = new GraphicsDeviceManager(this); Graphics.PreferredBackBufferWidth = 320; Graphics.PreferredBackBufferHeight = 320; Window.IsBorderless = true; Content.RootDirectory = "Content"; Assets = new ContentSystem(Content); resolutionContentResolver = new ResolutionContentResolver(); FontContentResolver fcr = new FontContentResolver(resolutionContentResolver); Assets.contentResolver.Add(typeof(Texture2D), resolutionContentResolver); Assets.contentResolver.Add(typeof(SpriteFont), fcr); preferencesManager = new PreferencesManager(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData) + "/RhythmBullet", new Controls(), new General()); } public Screen Screen { get { return currentScreen; } set { if (currentScreen != null) { Screen.Hide(); } currentScreen = value; Screen.Show(); } } /// /// Allows the game to perform any initialization it needs to before starting to run. /// This is where it can query for any required services and load any non-graphic /// related content. Calling base.Initialize will enumerate through any components /// and initialize them as well. /// protected override void Initialize() { // TODO: Add your initialization logic here base.Initialize(); } /// /// LoadContent will be called once per game and is the place to load /// all of your content. /// protected override void LoadContent() { // Create a new SpriteBatch, which can be used to draw textures. spriteBatch = new SpriteBatch(GraphicsDevice); Screen = new LoadingScreen(Content.Load("recrown")); // TODO: use this.Content to load your game content here } /// /// UnloadContent will be called once per game and is the place to unload /// game-specific content. /// protected override void UnloadContent() { // TODO: Unload any non ContentManager content here } /// /// Allows the game to run logic such as updating the world, /// checking for collisions, gathering input, and playing audio. /// /// Provides a snapshot of timing values. protected override void Update(GameTime gameTime) { Screen.Update(gameTime); base.Update(gameTime); } /// /// This is called when the game should draw itself. /// /// Provides a snapshot of timing values. protected override void Draw(GameTime gameTime) { GraphicsDevice.Clear(Color.White); spriteBatch.Begin(); Screen.Draw(spriteBatch); spriteBatch.End(); base.Draw(gameTime); } public void PreAssetLoad() { Assets.UnloadAll(); resolutionContentResolver.Width = Graphics.PreferredBackBufferWidth; resolutionContentResolver.Height = Graphics.PreferredBackBufferHeight; QueueContent(); } public void PostAssetLoad() { } void QueueContent() { } } }