1
0
mirror of https://github.com/borgesdan/xn65 synced 2024-12-29 21:54:47 +01:00
xn65/framework/platform/adapter-dx.cpp

142 lines
3.4 KiB
C++
Raw Normal View History

2024-03-18 15:41:46 -03:00
#include "adapter-dx.hpp"
#include "../helpers.hpp"
namespace xna {
String GraphicsAdapter::Description() const {
DXGI_ADAPTER_DESC1 desc;
2024-03-21 16:01:47 -03:00
_adapter->GetDesc1(&desc);
2024-03-18 15:41:46 -03:00
String description = WStringToString(desc.Description);
return description;
}
Uint GraphicsAdapter::DeviceId() const {
DXGI_ADAPTER_DESC1 desc;
2024-03-21 16:01:47 -03:00
_adapter->GetDesc1(&desc);
2024-03-18 15:41:46 -03:00
return static_cast<Uint>(desc.DeviceId);
}
String GraphicsAdapter::DeviceName() const {
IDXGIOutput* pOutput = nullptr;
DXGI_OUTPUT_DESC outputDesc;
2024-03-21 16:01:47 -03:00
if (_adapter->EnumOutputs(0, &pOutput) != DXGI_ERROR_NOT_FOUND) {
2024-03-18 15:41:46 -03:00
pOutput->GetDesc(&outputDesc);
String deviceName = WStringToString(outputDesc.DeviceName);
pOutput->Release();
pOutput = nullptr;
return deviceName;
}
return String();
}
intptr_t GraphicsAdapter::MonitorHandle() const {
IDXGIOutput* pOutput = nullptr;
DXGI_OUTPUT_DESC outputDesc;
2024-03-21 16:01:47 -03:00
if (_adapter->EnumOutputs(0, &pOutput) != DXGI_ERROR_NOT_FOUND) {
2024-03-18 15:41:46 -03:00
pOutput->GetDesc(&outputDesc);
pOutput->Release();
pOutput = nullptr;
return reinterpret_cast<intptr_t>(outputDesc.Monitor);
}
return 0;
}
Uint GraphicsAdapter::Revision() const {
DXGI_ADAPTER_DESC1 desc;
2024-03-21 16:01:47 -03:00
_adapter->GetDesc1(&desc);
2024-03-18 15:41:46 -03:00
return static_cast<Uint>(desc.Revision);
}
Uint GraphicsAdapter::SubSystemId() const {
DXGI_ADAPTER_DESC1 desc;
2024-03-21 16:01:47 -03:00
_adapter->GetDesc1(&desc);
2024-03-18 15:41:46 -03:00
return static_cast<Uint>(desc.SubSysId);
}
Uint GraphicsAdapter::VendorId() const {
DXGI_ADAPTER_DESC1 desc;
2024-03-21 16:01:47 -03:00
_adapter->GetDesc1(&desc);
2024-03-18 15:41:46 -03:00
return static_cast<Uint>(desc.VendorId);
}
PDisplayModeCollection GraphicsAdapter::SupportedDisplayModes() const {
IDXGIOutput* pOutput = nullptr;
UINT numModes = 0;
UINT totalModes = 0;
std::vector<DXGI_MODE_DESC> buffer(250);
2024-03-21 16:01:47 -03:00
if (_adapter->EnumOutputs(0, &pOutput) != DXGI_ERROR_NOT_FOUND) {
2024-03-18 15:41:46 -03:00
for (size_t f = 0; f < SURFACE_FORMAT_COUNT; ++f) {
const auto currentSurface = static_cast<SurfaceFormat>(f);
DXGI_FORMAT format = SurfaceFormatMapper::ParseToDXGI(currentSurface);
pOutput->GetDisplayModeList(format, 0, &numModes, nullptr);
if (numModes == 0)
continue;
2024-03-21 16:01:47 -03:00
if (buffer.size() < static_cast<size_t>(totalModes) + numModes)
buffer.resize(static_cast<size_t>(totalModes * 2));
2024-03-18 15:41:46 -03:00
pOutput->GetDisplayModeList(format, 0, &numModes, buffer.data() + totalModes);
totalModes += numModes;
}
pOutput->Release();
buffer.resize(totalModes);
std::vector<DisplayMode> dmodes;
for (size_t i = 0; i < buffer.size(); ++i) {
const auto& modedesc = buffer[i];
const auto surface = SurfaceFormatMapper::ParseToSurface(modedesc.Format);
dmodes[0] = DisplayMode(modedesc.Width, modedesc.Height, surface);
}
dmodes.resize(buffer.size());
return New<DisplayModeCollection>(dmodes);
}
return New<DisplayModeCollection>();
}
2024-03-21 16:01:47 -03:00
std::vector<PGraphicsAdapter> IGraphicsAdapter::getAllAdapters() {
2024-03-18 15:41:46 -03:00
IDXGIFactory1* pFactory = nullptr;
std::vector<PGraphicsAdapter> adapters;
if FAILED(CreateDXGIFactory1(__uuidof(IDXGIFactory1), (void**)&pFactory)) {
return adapters;
}
IDXGIAdapter1* pAdapter = nullptr;
UINT count = 0;
for (; pFactory->EnumAdapters1(count, &pAdapter) != DXGI_ERROR_NOT_FOUND; ++count) {
auto adp = New<GraphicsAdapter>();
2024-03-21 16:01:47 -03:00
adp->_index = count;
adp->_adapter = pAdapter;
2024-03-18 15:41:46 -03:00
adapters.push_back(adp);
}
if (!adapters.empty())
adapters.resize(count);
return adapters;
}
}