1
0
mirror of https://github.com/borgesdan/xn65 synced 2024-12-29 21:54:47 +01:00
xn65/includes/xna/graphics/adapter.hpp

101 lines
3.3 KiB
C++

#ifndef XNA_GRAPHICS_ADAPTER_HPP
#define XNA_GRAPHICS_ADAPTER_HPP
#include "../default.hpp"
#include "displaymode.hpp"
namespace xna {
//Provides methods to retrieve and manipulate graphics adapters.
class GraphicsAdapter {
public:
//Collection of available adapters on the system.
static void Adapters(std::vector<uptr<GraphicsAdapter>>& adapters);
//Gets the current display mode.
inline sptr<DisplayMode> CurrentDisplayMode() const { return currentDisplayMode; }
//Gets the default adapter.
static uptr<GraphicsAdapter> DefaultAdapter();
//Retrieves a string used for presentation to the user.
constexpr String Description() const { return description; }
//Retrieves a value that is used to help identify a particular chip set.
constexpr Uint DeviceId() const { return deviceId; }
//Retrieves a string that contains the device name.
constexpr String DeviceName() const { return deviceName; }
//Determines if this instance of GraphicsAdapter is the default adapter.
constexpr bool IsDefaultAdapter() const { return isDefault; }
//Determines if the graphics adapter is in widescreen mode.
inline bool IsWideScreen() const {
return currentDisplayMode->AspectRatio() > 1.6000000238418579;
}
//Retrieves the handle of the monitor
constexpr intptr_t MonitorHandle() const { return monitorHandle; }
//Retrieves a value used to help identify the revision level of a particular chip set.
constexpr Uint Revision() const { return revision; }
//Retrieves a value used to identify the subsystem.
constexpr Uint SubSystemId() const { return subSystemId; }
//Returns a collection of supported display modes for the current adapter.
inline sptr<DisplayModeCollection> SupportedDisplayModes() const { return supportedDisplayModes; }
//Retrieves a value used to identify the manufacturer.
constexpr Uint VendorId() const { return vendorId; }
//Gets or sets a NULL device.
static bool UseNullDevice() { return useNullDevice; }
//Gets or sets a NULL device.
static void UseNullDevice(bool value) { useNullDevice = value; }
//Gets or sets a reference device.
constexpr static bool UseReferenceDevice() { return useReferenceDevice; }
//Gets or sets a reference device.
constexpr static void UseReferenceDevice(bool value) { useReferenceDevice = value; }
//Tests to see if the adapter supports the requested profile.
bool IsProfileSupported(GraphicsProfile graphicsProfile) {
return true;
}
//Queries the adapter for support for the requested back buffer format.
bool QueryBackBufferFormat(
GraphicsProfile graphicsProfile,
SurfaceFormat format,
DepthFormat depthFormat,
Int multiSampleCount,
SurfaceFormat& selectedFormat,
DepthFormat& selectedDepthFormat,
Int& selectedMultiSampleCount
) const;
private:
String description;
Uint deviceId{0};
String deviceName;
bool isDefault{ false };
intptr_t monitorHandle{ 0 };
Uint revision{ 0 };
Uint subSystemId{ 0 };
Uint vendorId{ 0 };
sptr<DisplayMode> currentDisplayMode{ nullptr };
sptr<DisplayModeCollection> supportedDisplayModes{ nullptr };
inline static bool useNullDevice = false;
inline static bool useReferenceDevice = false;
GraphicsAdapter();
public:
struct PlatformImplementation;
uptr<PlatformImplementation> impl = nullptr;
};
}
#endif