- extended ContentImporter to provide OutputType of imported content - provided a list of available ContentProcessors in current context PlatformSystems are no longer AddIns. This doesn't mean, that you can't load them dynamically. The handling is just different. There's only a single PlatformSystem available for each platform ANX runs on. This one is auto loaded. If it doesn't exist the game doesn't run. The reason for this is, that we will move the AddIn system from ANX.Framework to the specialized PlatformSystem. This is necessary because we want ANX.Framework to become platform independent. The AddIn system is different for some platforms (Android, iOS, Windows 8 Metro) and needs to be specialized. On the other hand we are able to simplify the AddIn system when moving it to the PlatformSystem because we don't need a big AddIn system supporting all platforms with much conditional compiling. THIS COMMIT DOES BREAK SOME FUNCTIONALITY. METRO DOESN'T WORK ANYMORE, AS IT IS NOT TESTED. DON'T USE THIS COMMIT IF YOU ARE NO ANX.FRAMEWORK DEVELOPER. We will catch up soon with a tested and working version.
88 lines
2.1 KiB
C#
88 lines
2.1 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.IO;
|
|
using ANX.Framework;
|
|
using ANX.Framework.Media;
|
|
using ANX.Framework.NonXNA;
|
|
using ANX.Framework.NonXNA.PlatformSystem;
|
|
using ANX.Framework.Storage;
|
|
|
|
// This file is part of the ANX.Framework created by the
|
|
// "ANX.Framework developer group" and released under the Ms-PL license.
|
|
// For details see: http://anxframework.codeplex.com/license
|
|
|
|
namespace ANX.PlatformSystem.Windows
|
|
{
|
|
public class WindowsPlatformSystem : IPlatformSystem
|
|
{
|
|
public WindowsPlatformSystem()
|
|
{
|
|
}
|
|
|
|
#region CreateGameHost
|
|
public GameHost CreateGameHost(Game game)
|
|
{
|
|
Logger.Info("creating Windows GameHost");
|
|
return new WindowsGameHost(game);
|
|
}
|
|
#endregion
|
|
|
|
#region CreateStorageDevice
|
|
public INativeStorageDevice CreateStorageDevice(StorageDevice device,
|
|
PlayerIndex player, int sizeInBytes, int directoryCount)
|
|
{
|
|
return new WindowsStorageDevice(device, player, sizeInBytes, directoryCount);
|
|
}
|
|
#endregion
|
|
|
|
#region CreateStorageContainer
|
|
public INativeStorageContainer CreateStorageContainer(StorageContainer container)
|
|
{
|
|
return new WindowsStorageContainer(container);
|
|
}
|
|
#endregion
|
|
|
|
#region CreateTitleContainer
|
|
public INativeTitleContainer CreateTitleContainer()
|
|
{
|
|
return new WindowsTitleContainer();
|
|
}
|
|
#endregion
|
|
|
|
#region CreateGameTimer
|
|
public INativeGameTimer CreateGameTimer()
|
|
{
|
|
return new WindowsGameTimer();
|
|
}
|
|
#endregion
|
|
|
|
#region CreateContentManager
|
|
public INativeContentManager CreateContentManager()
|
|
{
|
|
return new WindowsContentManager();
|
|
}
|
|
#endregion
|
|
|
|
#region CreateMediaPlayer (TODO)
|
|
public INativeMediaLibrary CreateMediaPlayer()
|
|
{
|
|
throw new NotImplementedException();
|
|
}
|
|
#endregion
|
|
|
|
#region GetAvailableMediaSources (TODO)
|
|
public IList<MediaSource> GetAvailableMediaSources()
|
|
{
|
|
throw new NotImplementedException();
|
|
}
|
|
#endregion
|
|
|
|
#region OpenReadFilestream
|
|
public Stream OpenReadFilestream(string filepath)
|
|
{
|
|
return File.OpenRead(filepath);
|
|
}
|
|
#endregion
|
|
}
|
|
}
|